|  | /* | 
|  | * IMX7 System Reset Controller | 
|  | * | 
|  | * Copyright (C) 2023 Jean-Christophe Dubois <jcd@tribudubois.net> | 
|  | * | 
|  | * This work is licensed under the terms of the GNU GPL, version 2 or later. | 
|  | * See the COPYING file in the top-level directory. | 
|  | */ | 
|  |  | 
|  | #ifndef IMX7_SRC_H | 
|  | #define IMX7_SRC_H | 
|  |  | 
|  | #include "hw/sysbus.h" | 
|  | #include "qemu/bitops.h" | 
|  | #include "qom/object.h" | 
|  |  | 
|  | #define SRC_SCR 0 | 
|  | #define SRC_A7RCR0 1 | 
|  | #define SRC_A7RCR1 2 | 
|  | #define SRC_M4RCR 3 | 
|  | #define SRC_ERCR 5 | 
|  | #define SRC_HSICPHY_RCR 7 | 
|  | #define SRC_USBOPHY1_RCR 8 | 
|  | #define SRC_USBOPHY2_RCR 9 | 
|  | #define SRC_MPIPHY_RCR 10 | 
|  | #define SRC_PCIEPHY_RCR 11 | 
|  | #define SRC_SBMR1 22 | 
|  | #define SRC_SRSR 23 | 
|  | #define SRC_SISR 26 | 
|  | #define SRC_SIMR 27 | 
|  | #define SRC_SBMR2 28 | 
|  | #define SRC_GPR1 29 | 
|  | #define SRC_GPR2 30 | 
|  | #define SRC_GPR3 31 | 
|  | #define SRC_GPR4 32 | 
|  | #define SRC_GPR5 33 | 
|  | #define SRC_GPR6 34 | 
|  | #define SRC_GPR7 35 | 
|  | #define SRC_GPR8 36 | 
|  | #define SRC_GPR9 37 | 
|  | #define SRC_GPR10 38 | 
|  | #define SRC_MAX 39 | 
|  |  | 
|  | /* SRC_A7SCR1 */ | 
|  | #define R_CORE1_ENABLE_SHIFT     1 | 
|  | #define R_CORE1_ENABLE_LENGTH    1 | 
|  | /* SRC_A7SCR0 */ | 
|  | #define R_CORE1_RST_SHIFT        5 | 
|  | #define R_CORE1_RST_LENGTH       1 | 
|  | #define R_CORE0_RST_SHIFT        4 | 
|  | #define R_CORE0_RST_LENGTH       1 | 
|  |  | 
|  | #define TYPE_IMX7_SRC "imx7.src" | 
|  | OBJECT_DECLARE_SIMPLE_TYPE(IMX7SRCState, IMX7_SRC) | 
|  |  | 
|  | struct IMX7SRCState { | 
|  | /* <private> */ | 
|  | SysBusDevice parent_obj; | 
|  |  | 
|  | /* <public> */ | 
|  | MemoryRegion iomem; | 
|  |  | 
|  | uint32_t regs[SRC_MAX]; | 
|  | }; | 
|  |  | 
|  | #endif /* IMX7_SRC_H */ |