2018-02-09 13:40:29 +03:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2017, Impinj, Inc.
|
|
|
|
*
|
|
|
|
* i.MX7 CCM, PMU and ANALOG IP blocks emulation code
|
|
|
|
*
|
|
|
|
* Author: Andrey Smirnov <andrew.smirnov@gmail.com>
|
|
|
|
*
|
|
|
|
* 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_CCM_H
|
|
|
|
#define IMX7_CCM_H
|
|
|
|
|
|
|
|
#include "hw/misc/imx_ccm.h"
|
|
|
|
#include "qemu/bitops.h"
|
2020-09-03 23:43:22 +03:00
|
|
|
#include "qom/object.h"
|
2018-02-09 13:40:29 +03:00
|
|
|
|
|
|
|
enum IMX7AnalogRegisters {
|
|
|
|
ANALOG_PLL_ARM,
|
|
|
|
ANALOG_PLL_ARM_SET,
|
|
|
|
ANALOG_PLL_ARM_CLR,
|
|
|
|
ANALOG_PLL_ARM_TOG,
|
|
|
|
ANALOG_PLL_DDR,
|
|
|
|
ANALOG_PLL_DDR_SET,
|
|
|
|
ANALOG_PLL_DDR_CLR,
|
|
|
|
ANALOG_PLL_DDR_TOG,
|
|
|
|
ANALOG_PLL_DDR_SS,
|
|
|
|
ANALOG_PLL_DDR_SS_SET,
|
|
|
|
ANALOG_PLL_DDR_SS_CLR,
|
|
|
|
ANALOG_PLL_DDR_SS_TOG,
|
|
|
|
ANALOG_PLL_DDR_NUM,
|
|
|
|
ANALOG_PLL_DDR_NUM_SET,
|
|
|
|
ANALOG_PLL_DDR_NUM_CLR,
|
|
|
|
ANALOG_PLL_DDR_NUM_TOG,
|
|
|
|
ANALOG_PLL_DDR_DENOM,
|
|
|
|
ANALOG_PLL_DDR_DENOM_SET,
|
|
|
|
ANALOG_PLL_DDR_DENOM_CLR,
|
|
|
|
ANALOG_PLL_DDR_DENOM_TOG,
|
|
|
|
ANALOG_PLL_480,
|
|
|
|
ANALOG_PLL_480_SET,
|
|
|
|
ANALOG_PLL_480_CLR,
|
|
|
|
ANALOG_PLL_480_TOG,
|
|
|
|
ANALOG_PLL_480A,
|
|
|
|
ANALOG_PLL_480A_SET,
|
|
|
|
ANALOG_PLL_480A_CLR,
|
|
|
|
ANALOG_PLL_480A_TOG,
|
|
|
|
ANALOG_PLL_480B,
|
|
|
|
ANALOG_PLL_480B_SET,
|
|
|
|
ANALOG_PLL_480B_CLR,
|
|
|
|
ANALOG_PLL_480B_TOG,
|
|
|
|
ANALOG_PLL_ENET,
|
|
|
|
ANALOG_PLL_ENET_SET,
|
|
|
|
ANALOG_PLL_ENET_CLR,
|
|
|
|
ANALOG_PLL_ENET_TOG,
|
|
|
|
ANALOG_PLL_AUDIO,
|
|
|
|
ANALOG_PLL_AUDIO_SET,
|
|
|
|
ANALOG_PLL_AUDIO_CLR,
|
|
|
|
ANALOG_PLL_AUDIO_TOG,
|
|
|
|
ANALOG_PLL_AUDIO_SS,
|
|
|
|
ANALOG_PLL_AUDIO_SS_SET,
|
|
|
|
ANALOG_PLL_AUDIO_SS_CLR,
|
|
|
|
ANALOG_PLL_AUDIO_SS_TOG,
|
|
|
|
ANALOG_PLL_AUDIO_NUM,
|
|
|
|
ANALOG_PLL_AUDIO_NUM_SET,
|
|
|
|
ANALOG_PLL_AUDIO_NUM_CLR,
|
|
|
|
ANALOG_PLL_AUDIO_NUM_TOG,
|
|
|
|
ANALOG_PLL_AUDIO_DENOM,
|
|
|
|
ANALOG_PLL_AUDIO_DENOM_SET,
|
|
|
|
ANALOG_PLL_AUDIO_DENOM_CLR,
|
|
|
|
ANALOG_PLL_AUDIO_DENOM_TOG,
|
|
|
|
ANALOG_PLL_VIDEO,
|
|
|
|
ANALOG_PLL_VIDEO_SET,
|
|
|
|
ANALOG_PLL_VIDEO_CLR,
|
|
|
|
ANALOG_PLL_VIDEO_TOG,
|
|
|
|
ANALOG_PLL_VIDEO_SS,
|
|
|
|
ANALOG_PLL_VIDEO_SS_SET,
|
|
|
|
ANALOG_PLL_VIDEO_SS_CLR,
|
|
|
|
ANALOG_PLL_VIDEO_SS_TOG,
|
|
|
|
ANALOG_PLL_VIDEO_NUM,
|
|
|
|
ANALOG_PLL_VIDEO_NUM_SET,
|
|
|
|
ANALOG_PLL_VIDEO_NUM_CLR,
|
|
|
|
ANALOG_PLL_VIDEO_NUM_TOG,
|
|
|
|
ANALOG_PLL_VIDEO_DENOM,
|
|
|
|
ANALOG_PLL_VIDEO_DENOM_SET,
|
|
|
|
ANALOG_PLL_VIDEO_DENOM_CLR,
|
|
|
|
ANALOG_PLL_VIDEO_DENOM_TOG,
|
|
|
|
ANALOG_PLL_MISC0,
|
|
|
|
ANALOG_PLL_MISC0_SET,
|
|
|
|
ANALOG_PLL_MISC0_CLR,
|
|
|
|
ANALOG_PLL_MISC0_TOG,
|
|
|
|
|
|
|
|
ANALOG_DIGPROG = 0x800 / sizeof(uint32_t),
|
|
|
|
ANALOG_MAX,
|
|
|
|
|
|
|
|
ANALOG_PLL_LOCK = BIT(31)
|
|
|
|
};
|
|
|
|
|
|
|
|
enum IMX7CCMRegisters {
|
|
|
|
CCM_MAX = 0xBE00 / sizeof(uint32_t) + 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum IMX7PMURegisters {
|
|
|
|
PMU_MAX = 0x140 / sizeof(uint32_t),
|
|
|
|
};
|
|
|
|
|
|
|
|
#define TYPE_IMX7_CCM "imx7.ccm"
|
2020-09-03 23:43:22 +03:00
|
|
|
typedef struct IMX7CCMState IMX7CCMState;
|
2020-09-01 00:07:33 +03:00
|
|
|
DECLARE_INSTANCE_CHECKER(IMX7CCMState, IMX7_CCM,
|
|
|
|
TYPE_IMX7_CCM)
|
2018-02-09 13:40:29 +03:00
|
|
|
|
2020-09-03 23:43:22 +03:00
|
|
|
struct IMX7CCMState {
|
2018-02-09 13:40:29 +03:00
|
|
|
/* <private> */
|
|
|
|
IMXCCMState parent_obj;
|
|
|
|
|
|
|
|
/* <public> */
|
|
|
|
MemoryRegion iomem;
|
|
|
|
|
|
|
|
uint32_t ccm[CCM_MAX];
|
2020-09-03 23:43:22 +03:00
|
|
|
};
|
2018-02-09 13:40:29 +03:00
|
|
|
|
|
|
|
|
|
|
|
#define TYPE_IMX7_ANALOG "imx7.analog"
|
2020-09-03 23:43:22 +03:00
|
|
|
typedef struct IMX7AnalogState IMX7AnalogState;
|
2020-09-01 00:07:33 +03:00
|
|
|
DECLARE_INSTANCE_CHECKER(IMX7AnalogState, IMX7_ANALOG,
|
|
|
|
TYPE_IMX7_ANALOG)
|
2018-02-09 13:40:29 +03:00
|
|
|
|
2020-09-03 23:43:22 +03:00
|
|
|
struct IMX7AnalogState {
|
2018-02-09 13:40:29 +03:00
|
|
|
/* <private> */
|
|
|
|
IMXCCMState parent_obj;
|
|
|
|
|
|
|
|
/* <public> */
|
|
|
|
struct {
|
|
|
|
MemoryRegion container;
|
|
|
|
MemoryRegion analog;
|
|
|
|
MemoryRegion digprog;
|
|
|
|
MemoryRegion pmu;
|
|
|
|
} mmio;
|
|
|
|
|
|
|
|
uint32_t analog[ANALOG_MAX];
|
|
|
|
uint32_t pmu[PMU_MAX];
|
2020-09-03 23:43:22 +03:00
|
|
|
};
|
2018-02-09 13:40:29 +03:00
|
|
|
|
|
|
|
#endif /* IMX7_CCM_H */
|