mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-30 13:31:52 -06:00

The SSE-300 has a new PWRCTRL register at offset 0x1fc (previously reserved). This register controls accessibility of some registers in the Power Policy Units (PPUs). Since QEMU doesn't implement the PPUs, we don't need to implement any real behaviour for this register, so we just handle the UNLOCK bit which controls whether writes to the register itself are permitted and otherwise make it be reads-as-written. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Tested-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20210219144617.4782-17-peter.maydell@linaro.org
70 lines
1.8 KiB
C
70 lines
1.8 KiB
C
/*
|
|
* ARM IoTKit system control element
|
|
*
|
|
* Copyright (c) 2018 Linaro Limited
|
|
* Written by Peter Maydell
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 or
|
|
* (at your option) any later version.
|
|
*/
|
|
|
|
/*
|
|
* This is a model of the "system control element" which is part of the
|
|
* Arm IoTKit and documented in
|
|
* https://developer.arm.com/documentation/ecm0601256/latest
|
|
* Specifically, it implements the "system information block" and
|
|
* "system control register" blocks.
|
|
*
|
|
* QEMU interface:
|
|
* + QOM property "sse-version": indicates which SSE version this is part of
|
|
* (used to identify whether to provide SSE-200-only registers, etc)
|
|
* + sysbus MMIO region 0: the system information register bank
|
|
* + sysbus MMIO region 1: the system control register bank
|
|
*/
|
|
|
|
#ifndef HW_MISC_IOTKIT_SYSCTL_H
|
|
#define HW_MISC_IOTKIT_SYSCTL_H
|
|
|
|
#include "hw/sysbus.h"
|
|
#include "qom/object.h"
|
|
|
|
#define TYPE_IOTKIT_SYSCTL "iotkit-sysctl"
|
|
OBJECT_DECLARE_SIMPLE_TYPE(IoTKitSysCtl, IOTKIT_SYSCTL)
|
|
|
|
struct IoTKitSysCtl {
|
|
/*< private >*/
|
|
SysBusDevice parent_obj;
|
|
|
|
/*< public >*/
|
|
MemoryRegion iomem;
|
|
|
|
uint32_t secure_debug;
|
|
uint32_t reset_syndrome;
|
|
uint32_t reset_mask;
|
|
uint32_t gretreg;
|
|
uint32_t initsvtor0;
|
|
uint32_t cpuwait;
|
|
uint32_t wicctrl;
|
|
uint32_t scsecctrl;
|
|
uint32_t fclk_div;
|
|
uint32_t sysclk_div;
|
|
uint32_t clock_force;
|
|
uint32_t initsvtor1;
|
|
uint32_t nmi_enable;
|
|
uint32_t ewctrl;
|
|
uint32_t pwrctrl;
|
|
uint32_t pdcm_pd_sys_sense;
|
|
uint32_t pdcm_pd_sram0_sense;
|
|
uint32_t pdcm_pd_sram1_sense;
|
|
uint32_t pdcm_pd_sram2_sense;
|
|
uint32_t pdcm_pd_sram3_sense;
|
|
|
|
/* Properties */
|
|
uint32_t sse_version;
|
|
uint32_t cpuwait_rst;
|
|
uint32_t initsvtor0_rst;
|
|
uint32_t initsvtor1_rst;
|
|
};
|
|
|
|
#endif
|