241
243
pxa2xx_pic_mem_write,
244
static void pxa2xx_pic_save(QEMUFile *f, void *opaque)
246
PXA2xxPICState *s = (PXA2xxPICState *) opaque;
249
for (i = 0; i < 2; i ++)
250
qemu_put_be32s(f, &s->int_enabled[i]);
251
for (i = 0; i < 2; i ++)
252
qemu_put_be32s(f, &s->int_pending[i]);
253
for (i = 0; i < 2; i ++)
254
qemu_put_be32s(f, &s->is_fiq[i]);
255
qemu_put_be32s(f, &s->int_idle);
256
for (i = 0; i < PXA2XX_PIC_SRCS; i ++)
257
qemu_put_be32s(f, &s->priority[i]);
260
static int pxa2xx_pic_load(QEMUFile *f, void *opaque, int version_id)
262
PXA2xxPICState *s = (PXA2xxPICState *) opaque;
265
for (i = 0; i < 2; i ++)
266
qemu_get_be32s(f, &s->int_enabled[i]);
267
for (i = 0; i < 2; i ++)
268
qemu_get_be32s(f, &s->int_pending[i]);
269
for (i = 0; i < 2; i ++)
270
qemu_get_be32s(f, &s->is_fiq[i]);
271
qemu_get_be32s(f, &s->int_idle);
272
for (i = 0; i < PXA2XX_PIC_SRCS; i ++)
273
qemu_get_be32s(f, &s->priority[i]);
246
static int pxa2xx_pic_post_load(void *opaque, int version_id)
275
248
pxa2xx_pic_update(opaque);
279
qemu_irq *pxa2xx_pic_init(target_phys_addr_t base, CPUState *env)
252
DeviceState *pxa2xx_pic_init(target_phys_addr_t base, CPUState *env)
254
DeviceState *dev = qdev_create(NULL, "pxa2xx_pic");
285
s = (PXA2xxPICState *)
286
qemu_mallocz(sizeof(PXA2xxPICState));
256
PXA2xxPICState *s = FROM_SYSBUS(PXA2xxPICState, sysbus_from_qdev(dev));
290
258
s->cpu_env = env;
296
264
s->is_fiq[0] = 0;
297
265
s->is_fiq[1] = 0;
299
qi = qemu_allocate_irqs(pxa2xx_pic_set_irq, s, PXA2XX_PIC_SRCS);
267
qdev_init_nofail(dev);
269
qdev_init_gpio_in(dev, pxa2xx_pic_set_irq, PXA2XX_PIC_SRCS);
301
271
/* Enable IC memory-mapped registers access. */
302
272
iomemtype = cpu_register_io_memory(pxa2xx_pic_readfn,
303
273
pxa2xx_pic_writefn, s, DEVICE_NATIVE_ENDIAN);
304
cpu_register_physical_memory(base, 0x00100000, iomemtype);
274
sysbus_init_mmio(sysbus_from_qdev(dev), 0x00100000, iomemtype);
275
sysbus_mmio_map(sysbus_from_qdev(dev), 0, base);
306
277
/* Enable IC coprocessor access. */
307
278
cpu_arm_set_cp_io(env, 6, pxa2xx_pic_cp_read, pxa2xx_pic_cp_write, s);
309
register_savevm(NULL, "pxa2xx_pic", 0, 0, pxa2xx_pic_save,
283
static VMStateDescription vmstate_pxa2xx_pic_regs = {
284
.name = "pxa2xx_pic",
286
.minimum_version_id = 0,
287
.minimum_version_id_old = 0,
288
.post_load = pxa2xx_pic_post_load,
289
.fields = (VMStateField[]) {
290
VMSTATE_UINT32_ARRAY(int_enabled, PXA2xxPICState, 2),
291
VMSTATE_UINT32_ARRAY(int_pending, PXA2xxPICState, 2),
292
VMSTATE_UINT32_ARRAY(is_fiq, PXA2xxPICState, 2),
293
VMSTATE_UINT32(int_idle, PXA2xxPICState),
294
VMSTATE_UINT32_ARRAY(priority, PXA2xxPICState, PXA2XX_PIC_SRCS),
295
VMSTATE_END_OF_LIST(),
299
static int pxa2xx_pic_initfn(SysBusDevice *dev)
304
static SysBusDeviceInfo pxa2xx_pic_info = {
305
.init = pxa2xx_pic_initfn,
306
.qdev.name = "pxa2xx_pic",
307
.qdev.desc = "PXA2xx PIC",
308
.qdev.size = sizeof(PXA2xxPICState),
309
.qdev.vmsd = &vmstate_pxa2xx_pic_regs,
312
static void pxa2xx_pic_register(void)
314
sysbus_register_withprop(&pxa2xx_pic_info);
316
device_init(pxa2xx_pic_register);