qemu
1/*
2* ARM MPS2 SCC emulation
3*
4* Copyright (c) 2017 Linaro Limited
5* Written by Peter Maydell
6*
7* This program is free software; you can redistribute it and/or modify
8* it under the terms of the GNU General Public License version 2 or
9* (at your option) any later version.
10*/
11
12/* This is a model of the SCC (Serial Communication Controller)
13* found in the FPGA images of MPS2 development boards.
14*
15* Documentation of it can be found in the MPS2 TRM:
16* https://developer.arm.com/documentation/100112/latest/
17* and also in the Application Notes documenting individual FPGA images.
18*/
19
20#include "qemu/osdep.h"21#include "qemu/log.h"22#include "qemu/module.h"23#include "qemu/bitops.h"24#include "trace.h"25#include "hw/sysbus.h"26#include "hw/irq.h"27#include "migration/vmstate.h"28#include "hw/registerfields.h"29#include "hw/misc/mps2-scc.h"30#include "hw/misc/led.h"31#include "hw/qdev-properties.h"32
33REG32(CFG0, 0)34REG32(CFG1, 4)35REG32(CFG2, 8)36REG32(CFG3, 0xc)37REG32(CFG4, 0x10)38REG32(CFG5, 0x14)39REG32(CFG6, 0x18)40REG32(CFG7, 0x1c)41REG32(CFGDATA_RTN, 0xa0)42REG32(CFGDATA_OUT, 0xa4)43REG32(CFGCTRL, 0xa8)44FIELD(CFGCTRL, DEVICE, 0, 12)45FIELD(CFGCTRL, RES1, 12, 8)46FIELD(CFGCTRL, FUNCTION, 20, 6)47FIELD(CFGCTRL, RES2, 26, 4)48FIELD(CFGCTRL, WRITE, 30, 1)49FIELD(CFGCTRL, START, 31, 1)50REG32(CFGSTAT, 0xac)51FIELD(CFGSTAT, DONE, 0, 1)52FIELD(CFGSTAT, ERROR, 1, 1)53REG32(DLL, 0x100)54REG32(AID, 0xFF8)55REG32(ID, 0xFFC)56
57static int scc_partno(MPS2SCC *s)58{
59/* Return the partno field of the SCC_ID (0x524, 0x511, etc) */60return extract32(s->id, 4, 8);61}
62
63/* Is CFG_REG2 present? */
64static bool have_cfg2(MPS2SCC *s)65{
66return scc_partno(s) == 0x524 || scc_partno(s) == 0x547 ||67scc_partno(s) == 0x536;68}
69
70/* Is CFG_REG3 present? */
71static bool have_cfg3(MPS2SCC *s)72{
73return scc_partno(s) != 0x524 && scc_partno(s) != 0x547 &&74scc_partno(s) != 0x536;75}
76
77/* Is CFG_REG5 present? */
78static bool have_cfg5(MPS2SCC *s)79{
80return scc_partno(s) == 0x524 || scc_partno(s) == 0x547 ||81scc_partno(s) == 0x536;82}
83
84/* Is CFG_REG6 present? */
85static bool have_cfg6(MPS2SCC *s)86{
87return scc_partno(s) == 0x524 || scc_partno(s) == 0x536;88}
89
90/* Is CFG_REG7 present? */
91static bool have_cfg7(MPS2SCC *s)92{
93return scc_partno(s) == 0x536;94}
95
96/* Does CFG_REG0 drive the 'remap' GPIO output? */
97static bool cfg0_is_remap(MPS2SCC *s)98{
99return scc_partno(s) != 0x536;100}
101
102/* Is CFG_REG1 driving a set of LEDs? */
103static bool cfg1_is_leds(MPS2SCC *s)104{
105return scc_partno(s) != 0x536;106}
107
108/* Handle a write via the SYS_CFG channel to the specified function/device.
109* Return false on error (reported to guest via SYS_CFGCTRL ERROR bit).
110*/
111static bool scc_cfg_write(MPS2SCC *s, unsigned function,112unsigned device, uint32_t value)113{
114trace_mps2_scc_cfg_write(function, device, value);115
116if (function != 1 || device >= s->num_oscclk) {117qemu_log_mask(LOG_GUEST_ERROR,118"MPS2 SCC config write: bad function %d device %d\n",119function, device);120return false;121}122
123s->oscclk[device] = value;124return true;125}
126
127/* Handle a read via the SYS_CFG channel to the specified function/device.
128* Return false on error (reported to guest via SYS_CFGCTRL ERROR bit),
129* or set *value on success.
130*/
131static bool scc_cfg_read(MPS2SCC *s, unsigned function,132unsigned device, uint32_t *value)133{
134if (function != 1 || device >= s->num_oscclk) {135qemu_log_mask(LOG_GUEST_ERROR,136"MPS2 SCC config read: bad function %d device %d\n",137function, device);138return false;139}140
141*value = s->oscclk[device];142
143trace_mps2_scc_cfg_read(function, device, *value);144return true;145}
146
147static uint64_t mps2_scc_read(void *opaque, hwaddr offset, unsigned size)148{
149MPS2SCC *s = MPS2_SCC(opaque);150uint64_t r;151
152switch (offset) {153case A_CFG0:154r = s->cfg0;155break;156case A_CFG1:157r = s->cfg1;158break;159case A_CFG2:160if (!have_cfg2(s)) {161goto bad_offset;162}163r = s->cfg2;164break;165case A_CFG3:166if (!have_cfg3(s)) {167goto bad_offset;168}169/*170* These are user-settable DIP switches on the board. We don't
171* model that, so just return zeroes.
172*
173* TODO: for AN536 this is MCC_MSB_ADDR "additional MCC addressing
174* bits". These change which part of the DDR4 the motherboard
175* configuration controller can see in its memory map (see the
176* appnote section 2.4). QEMU doesn't model the MCC at all, so these
177* bits are not interesting to us; read-as-zero is as good as anything
178* else.
179*/
180r = 0;181break;182case A_CFG4:183r = s->cfg4;184break;185case A_CFG5:186if (!have_cfg5(s)) {187goto bad_offset;188}189r = s->cfg5;190break;191case A_CFG6:192if (!have_cfg6(s)) {193goto bad_offset;194}195r = s->cfg6;196break;197case A_CFG7:198if (!have_cfg7(s)) {199goto bad_offset;200}201r = s->cfg7;202break;203case A_CFGDATA_RTN:204r = s->cfgdata_rtn;205break;206case A_CFGDATA_OUT:207r = s->cfgdata_out;208break;209case A_CFGCTRL:210r = s->cfgctrl;211break;212case A_CFGSTAT:213r = s->cfgstat;214break;215case A_DLL:216r = s->dll;217break;218case A_AID:219r = s->aid;220break;221case A_ID:222r = s->id;223break;224default:225bad_offset:226qemu_log_mask(LOG_GUEST_ERROR,227"MPS2 SCC read: bad offset %x\n", (int) offset);228r = 0;229break;230}231
232trace_mps2_scc_read(offset, r, size);233return r;234}
235
236static void mps2_scc_write(void *opaque, hwaddr offset, uint64_t value,237unsigned size)238{
239MPS2SCC *s = MPS2_SCC(opaque);240
241trace_mps2_scc_write(offset, value, size);242
243switch (offset) {244case A_CFG0:245/*246* On some boards bit 0 controls board-specific remapping;
247* we always reflect bit 0 in the 'remap' GPIO output line,
248* and let the board wire it up or not as it chooses.
249* TODO on some boards bit 1 is CPU_WAIT.
250*
251* TODO: on the AN536 this register controls reset and halt
252* for both CPUs. For the moment we don't implement this, so the
253* register just reads as written.
254*/
255s->cfg0 = value;256if (cfg0_is_remap(s)) {257qemu_set_irq(s->remap, s->cfg0 & 1);258}259break;260case A_CFG1:261s->cfg1 = value;262/*263* On most boards this register drives LEDs.
264*
265* TODO: for AN536 this controls whether flash and ATCM are
266* enabled or disabled on reset. QEMU doesn't model this, and
267* always wires up RAM in the ATCM area and ROM in the flash area.
268*/
269if (cfg1_is_leds(s)) {270for (size_t i = 0; i < ARRAY_SIZE(s->led); i++) {271led_set_state(s->led[i], extract32(value, i, 1));272}273}274break;275case A_CFG2:276if (!have_cfg2(s)) {277goto bad_offset;278}279/* AN524, AN536: QSPI Select signal */280s->cfg2 = value;281break;282case A_CFG5:283if (!have_cfg5(s)) {284goto bad_offset;285}286/* AN524, AN536: ACLK frequency in Hz */287s->cfg5 = value;288break;289case A_CFG6:290if (!have_cfg6(s)) {291goto bad_offset;292}293/* AN524: Clock divider for BRAM */294/* AN536: Core 0 vector table base address */295s->cfg6 = value;296break;297case A_CFG7:298if (!have_cfg7(s)) {299goto bad_offset;300}301/* AN536: Core 1 vector table base address */302s->cfg6 = value;303break;304case A_CFGDATA_OUT:305s->cfgdata_out = value;306break;307case A_CFGCTRL:308/* Writing to CFGCTRL clears SYS_CFGSTAT */309s->cfgstat = 0;310s->cfgctrl = value & ~(R_CFGCTRL_RES1_MASK |311R_CFGCTRL_RES2_MASK |312R_CFGCTRL_START_MASK);313
314if (value & R_CFGCTRL_START_MASK) {315/* Start bit set -- do a read or write (instantaneously) */316int device = extract32(s->cfgctrl, R_CFGCTRL_DEVICE_SHIFT,317R_CFGCTRL_DEVICE_LENGTH);318int function = extract32(s->cfgctrl, R_CFGCTRL_FUNCTION_SHIFT,319R_CFGCTRL_FUNCTION_LENGTH);320
321s->cfgstat = R_CFGSTAT_DONE_MASK;322if (s->cfgctrl & R_CFGCTRL_WRITE_MASK) {323if (!scc_cfg_write(s, function, device, s->cfgdata_out)) {324s->cfgstat |= R_CFGSTAT_ERROR_MASK;325}326} else {327uint32_t result;328if (!scc_cfg_read(s, function, device, &result)) {329s->cfgstat |= R_CFGSTAT_ERROR_MASK;330} else {331s->cfgdata_rtn = result;332}333}334}335break;336case A_DLL:337/* DLL stands for Digital Locked Loop.338* Bits [31:24] (DLL_LOCK_MASK) are writable, and indicate a
339* mask of which of the DLL_LOCKED bits [16:23] should be ORed
340* together to determine the ALL_UNMASKED_DLLS_LOCKED bit [0].
341* For QEMU, our DLLs are always locked, so we can leave bit 0
342* as 1 always and don't need to recalculate it.
343*/
344s->dll = deposit32(s->dll, 24, 8, extract32(value, 24, 8));345break;346default:347bad_offset:348qemu_log_mask(LOG_GUEST_ERROR,349"MPS2 SCC write: bad offset 0x%x\n", (int) offset);350break;351}352}
353
354static const MemoryRegionOps mps2_scc_ops = {355.read = mps2_scc_read,356.write = mps2_scc_write,357.endianness = DEVICE_LITTLE_ENDIAN,358};359
360static void mps2_scc_reset(DeviceState *dev)361{
362MPS2SCC *s = MPS2_SCC(dev);363int i;364
365trace_mps2_scc_reset();366s->cfg0 = s->cfg0_reset;367s->cfg1 = 0;368s->cfg2 = 0;369s->cfg5 = 0;370s->cfg6 = 0;371s->cfgdata_rtn = 0;372s->cfgdata_out = 0;373s->cfgctrl = 0x100000;374s->cfgstat = 0;375s->dll = 0xffff0001;376for (i = 0; i < s->num_oscclk; i++) {377s->oscclk[i] = s->oscclk_reset[i];378}379for (i = 0; i < ARRAY_SIZE(s->led); i++) {380device_cold_reset(DEVICE(s->led[i]));381}382}
383
384static void mps2_scc_init(Object *obj)385{
386SysBusDevice *sbd = SYS_BUS_DEVICE(obj);387MPS2SCC *s = MPS2_SCC(obj);388
389memory_region_init_io(&s->iomem, obj, &mps2_scc_ops, s, "mps2-scc", 0x1000);390sysbus_init_mmio(sbd, &s->iomem);391qdev_init_gpio_out_named(DEVICE(obj), &s->remap, "remap", 1);392}
393
394static void mps2_scc_realize(DeviceState *dev, Error **errp)395{
396MPS2SCC *s = MPS2_SCC(dev);397
398for (size_t i = 0; i < ARRAY_SIZE(s->led); i++) {399char *name = g_strdup_printf("SCC LED%zu", i);400s->led[i] = led_create_simple(OBJECT(dev), GPIO_POLARITY_ACTIVE_HIGH,401LED_COLOR_GREEN, name);402g_free(name);403}404
405s->oscclk = g_new0(uint32_t, s->num_oscclk);406}
407
408static void mps2_scc_finalize(Object *obj)409{
410MPS2SCC *s = MPS2_SCC(obj);411
412g_free(s->oscclk_reset);413}
414
415static bool cfg7_needed(void *opaque)416{
417MPS2SCC *s = opaque;418
419return have_cfg7(s);420}
421
422static const VMStateDescription vmstate_cfg7 = {423.name = "mps2-scc/cfg7",424.version_id = 1,425.minimum_version_id = 1,426.needed = cfg7_needed,427.fields = (const VMStateField[]) {428VMSTATE_UINT32(cfg7, MPS2SCC),429VMSTATE_END_OF_LIST()430}431};432
433static const VMStateDescription mps2_scc_vmstate = {434.name = "mps2-scc",435.version_id = 3,436.minimum_version_id = 3,437.fields = (const VMStateField[]) {438VMSTATE_UINT32(cfg0, MPS2SCC),439VMSTATE_UINT32(cfg1, MPS2SCC),440VMSTATE_UINT32(cfg2, MPS2SCC),441/* cfg3, cfg4 are read-only so need not be migrated */442VMSTATE_UINT32(cfg5, MPS2SCC),443VMSTATE_UINT32(cfg6, MPS2SCC),444VMSTATE_UINT32(cfgdata_rtn, MPS2SCC),445VMSTATE_UINT32(cfgdata_out, MPS2SCC),446VMSTATE_UINT32(cfgctrl, MPS2SCC),447VMSTATE_UINT32(cfgstat, MPS2SCC),448VMSTATE_UINT32(dll, MPS2SCC),449VMSTATE_VARRAY_UINT32(oscclk, MPS2SCC, num_oscclk,4500, vmstate_info_uint32, uint32_t),451VMSTATE_END_OF_LIST()452},453.subsections = (const VMStateDescription * const []) {454&vmstate_cfg7,455NULL456}457};458
459static Property mps2_scc_properties[] = {460/* Values for various read-only ID registers (which are specific461* to the board model or FPGA image)
462*/
463DEFINE_PROP_UINT32("scc-cfg4", MPS2SCC, cfg4, 0),464DEFINE_PROP_UINT32("scc-aid", MPS2SCC, aid, 0),465DEFINE_PROP_UINT32("scc-id", MPS2SCC, id, 0),466/* Reset value for CFG0 register */467DEFINE_PROP_UINT32("scc-cfg0", MPS2SCC, cfg0_reset, 0),468/*469* These are the initial settings for the source clocks on the board.
470* In hardware they can be configured via a config file read by the
471* motherboard configuration controller to suit the FPGA image.
472*/
473DEFINE_PROP_ARRAY("oscclk", MPS2SCC, num_oscclk, oscclk_reset,474qdev_prop_uint32, uint32_t),475DEFINE_PROP_END_OF_LIST(),476};477
478static void mps2_scc_class_init(ObjectClass *klass, void *data)479{
480DeviceClass *dc = DEVICE_CLASS(klass);481
482dc->realize = mps2_scc_realize;483dc->vmsd = &mps2_scc_vmstate;484dc->reset = mps2_scc_reset;485device_class_set_props(dc, mps2_scc_properties);486}
487
488static const TypeInfo mps2_scc_info = {489.name = TYPE_MPS2_SCC,490.parent = TYPE_SYS_BUS_DEVICE,491.instance_size = sizeof(MPS2SCC),492.instance_init = mps2_scc_init,493.instance_finalize = mps2_scc_finalize,494.class_init = mps2_scc_class_init,495};496
497static void mps2_scc_register_types(void)498{
499type_register_static(&mps2_scc_info);500}
501
502type_init(mps2_scc_register_types);503