/* | |
* 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 */ |