10 static void test_device_serial_write(void *opaque
, uint32_t addr
, uint32_t data
)
12 struct testdev
*dev
= opaque
;
13 uint8_t buf
[1] = { data
};
16 qemu_chr_write(dev
->chr
, buf
, 1);
20 static void test_device_exit(void *opaque
, uint32_t addr
, uint32_t data
)
25 static uint32_t test_device_memsize_read(void *opaque
, uint32_t addr
)
30 extern qemu_irq
*ioapic_irq_hack
;
32 static void test_device_irq_line(void *opaque
, uint32_t addr
, uint32_t data
)
34 qemu_set_irq(ioapic_irq_hack
[addr
- 0x2000], !!data
);
37 static uint32 test_device_ioport_data
;
39 static void test_device_ioport_write(void *opaque
, uint32_t addr
, uint32_t data
)
41 test_device_ioport_data
= data
;
44 static uint32_t test_device_ioport_read(void *opaque
, uint32_t addr
)
46 return test_device_ioport_data
;
49 static char *iomem_buf
;
51 static uint32_t test_iomem_readb(void *opaque
, target_phys_addr_t addr
)
53 return iomem_buf
[addr
];
56 static uint32_t test_iomem_readw(void *opaque
, target_phys_addr_t addr
)
58 return *(uint16_t*)(iomem_buf
+ addr
);
61 static uint32_t test_iomem_readl(void *opaque
, target_phys_addr_t addr
)
63 return *(uint32_t*)(iomem_buf
+ addr
);
66 static void test_iomem_writeb(void *opaque
, target_phys_addr_t addr
, uint32_t val
)
68 iomem_buf
[addr
] = val
;
71 static void test_iomem_writew(void *opaque
, target_phys_addr_t addr
, uint32_t val
)
73 *(uint16_t*)(iomem_buf
+ addr
) = val
;
76 static void test_iomem_writel(void *opaque
, target_phys_addr_t addr
, uint32_t val
)
78 *(uint32_t*)(iomem_buf
+ addr
) = val
;
81 static CPUReadMemoryFunc
* const test_iomem_read
[3] = {
87 static CPUWriteMemoryFunc
* const test_iomem_write
[3] = {
93 static int init_test_device(ISADevice
*isa
)
95 struct testdev
*dev
= DO_UPCAST(struct testdev
, dev
, isa
);
98 register_ioport_write(0xf1, 1, 1, test_device_serial_write
, dev
);
99 register_ioport_write(0xf4, 1, 4, test_device_exit
, dev
);
100 register_ioport_read(0xd1, 1, 4, test_device_memsize_read
, dev
);
101 register_ioport_read(0xe0, 1, 1, test_device_ioport_read
, dev
);
102 register_ioport_write(0xe0, 1, 1, test_device_ioport_write
, dev
);
103 register_ioport_read(0xe0, 1, 2, test_device_ioport_read
, dev
);
104 register_ioport_write(0xe0, 1, 2, test_device_ioport_write
, dev
);
105 register_ioport_read(0xe0, 1, 4, test_device_ioport_read
, dev
);
106 register_ioport_write(0xe0, 1, 4, test_device_ioport_write
, dev
);
107 register_ioport_write(0x2000, 24, 1, test_device_irq_line
, NULL
);
108 iomem_buf
= qemu_mallocz(0x10000);
109 iomem
= cpu_register_io_memory(test_iomem_read
, test_iomem_write
, NULL
);
110 cpu_register_physical_memory(0xff000000, 0x10000, iomem
);
114 static ISADeviceInfo testdev_info
= {
115 .qdev
.name
= "testdev",
116 .qdev
.size
= sizeof(struct testdev
),
117 .init
= init_test_device
,
118 .qdev
.props
= (Property
[]) {
119 DEFINE_PROP_CHR("chardev", struct testdev
, chr
),
120 DEFINE_PROP_END_OF_LIST(),
124 static void testdev_register_devices(void)
126 isa_qdev_register(&testdev_info
);
129 device_init(testdev_register_devices
)