67 lines
1.4 KiB
C
67 lines
1.4 KiB
C
|
/*
|
||
|
* 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 */
|