xref: /openbmc/qemu/include/hw/misc/iotkit-sysctl.h (revision 50b52b18cdb9294ce83dd49bb60b8e55a6526ea0)
175750e4dSPeter Maydell /*
275750e4dSPeter Maydell  * ARM IoTKit system control element
375750e4dSPeter Maydell  *
475750e4dSPeter Maydell  * Copyright (c) 2018 Linaro Limited
575750e4dSPeter Maydell  * Written by Peter Maydell
675750e4dSPeter Maydell  *
775750e4dSPeter Maydell  *  This program is free software; you can redistribute it and/or modify
875750e4dSPeter Maydell  *  it under the terms of the GNU General Public License version 2 or
975750e4dSPeter Maydell  *  (at your option) any later version.
1075750e4dSPeter Maydell  */
1175750e4dSPeter Maydell 
1275750e4dSPeter Maydell /*
1375750e4dSPeter Maydell  * This is a model of the "system control element" which is part of the
1475750e4dSPeter Maydell  * Arm IoTKit and documented in
15*50b52b18SPeter Maydell  * https://developer.arm.com/documentation/ecm0601256/latest
1675750e4dSPeter Maydell  * Specifically, it implements the "system information block" and
1775750e4dSPeter Maydell  * "system control register" blocks.
1875750e4dSPeter Maydell  *
1975750e4dSPeter Maydell  * QEMU interface:
2004836414SPeter Maydell  *  + QOM property "SYS_VERSION": value of the SYS_VERSION register of the
2104836414SPeter Maydell  *    system information block of the SSE
2204836414SPeter Maydell  *    (used to identify whether to provide SSE-200-only registers)
2375750e4dSPeter Maydell  *  + sysbus MMIO region 0: the system information register bank
2475750e4dSPeter Maydell  *  + sysbus MMIO region 1: the system control register bank
2575750e4dSPeter Maydell  */
2675750e4dSPeter Maydell 
2775750e4dSPeter Maydell #ifndef HW_MISC_IOTKIT_SYSCTL_H
2875750e4dSPeter Maydell #define HW_MISC_IOTKIT_SYSCTL_H
2975750e4dSPeter Maydell 
3075750e4dSPeter Maydell #include "hw/sysbus.h"
31db1015e9SEduardo Habkost #include "qom/object.h"
3275750e4dSPeter Maydell 
3375750e4dSPeter Maydell #define TYPE_IOTKIT_SYSCTL "iotkit-sysctl"
348063396bSEduardo Habkost OBJECT_DECLARE_SIMPLE_TYPE(IoTKitSysCtl, IOTKIT_SYSCTL)
3575750e4dSPeter Maydell 
36db1015e9SEduardo Habkost struct IoTKitSysCtl {
3775750e4dSPeter Maydell     /*< private >*/
3875750e4dSPeter Maydell     SysBusDevice parent_obj;
3975750e4dSPeter Maydell 
4075750e4dSPeter Maydell     /*< public >*/
4175750e4dSPeter Maydell     MemoryRegion iomem;
4275750e4dSPeter Maydell 
4375750e4dSPeter Maydell     uint32_t secure_debug;
4475750e4dSPeter Maydell     uint32_t reset_syndrome;
4575750e4dSPeter Maydell     uint32_t reset_mask;
4675750e4dSPeter Maydell     uint32_t gretreg;
47394e10d2SPeter Maydell     uint32_t initsvtor0;
4875750e4dSPeter Maydell     uint32_t cpuwait;
4975750e4dSPeter Maydell     uint32_t wicctrl;
5004836414SPeter Maydell     uint32_t scsecctrl;
5104836414SPeter Maydell     uint32_t fclk_div;
5204836414SPeter Maydell     uint32_t sysclk_div;
5304836414SPeter Maydell     uint32_t clock_force;
5404836414SPeter Maydell     uint32_t initsvtor1;
5504836414SPeter Maydell     uint32_t nmi_enable;
5604836414SPeter Maydell     uint32_t ewctrl;
5704836414SPeter Maydell     uint32_t pdcm_pd_sys_sense;
5804836414SPeter Maydell     uint32_t pdcm_pd_sram0_sense;
5904836414SPeter Maydell     uint32_t pdcm_pd_sram1_sense;
6004836414SPeter Maydell     uint32_t pdcm_pd_sram2_sense;
6104836414SPeter Maydell     uint32_t pdcm_pd_sram3_sense;
6204836414SPeter Maydell 
6304836414SPeter Maydell     /* Properties */
6404836414SPeter Maydell     uint32_t sys_version;
65aab7a378SPeter Maydell     uint32_t cpuwait_rst;
66aab7a378SPeter Maydell     uint32_t initsvtor0_rst;
67aab7a378SPeter Maydell     uint32_t initsvtor1_rst;
6804836414SPeter Maydell 
6904836414SPeter Maydell     bool is_sse200;
70db1015e9SEduardo Habkost };
7175750e4dSPeter Maydell 
7275750e4dSPeter Maydell #endif
73