aboutsummaryrefslogtreecommitdiff
path: root/hw
diff options
context:
space:
mode:
authorbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>2004-03-14 21:41:34 +0000
committerbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>2004-03-14 21:41:34 +0000
commit7d977de7e19b04c4bb0c95d5afe6d4350d4068e5 (patch)
tree68830a4d6ae437e5fa927a6edab355e60f2c6951 /hw
parent07d898662d9aa173ac2d5c0aa4c9a1cf39caa703 (diff)
downloadqemu-7d977de7e19b04c4bb0c95d5afe6d4350d4068e5.zip
qemu-7d977de7e19b04c4bb0c95d5afe6d4350d4068e5.tar.gz
qemu-7d977de7e19b04c4bb0c95d5afe6d4350d4068e5.tar.bz2
io port API change
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@661 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'hw')
-rw-r--r--hw/dma.c24
-rw-r--r--hw/sb16.c20
2 files changed, 22 insertions, 22 deletions
diff --git a/hw/dma.c b/hw/dma.c
index 2c85b6e..3d010f3 100644
--- a/hw/dma.c
+++ b/hw/dma.c
@@ -78,7 +78,7 @@ enum {
};
-static void write_page (CPUState *env, uint32_t nport, uint32_t data)
+static void write_page (void *opaque, uint32_t nport, uint32_t data)
{
int ichan;
int ncont;
@@ -113,7 +113,7 @@ static inline int getff (int ncont)
return ff;
}
-static uint32_t read_chan (CPUState *env, uint32_t nport)
+static uint32_t read_chan (void *opaque, uint32_t nport)
{
int ff;
int ncont, ichan, nreg;
@@ -135,7 +135,7 @@ static uint32_t read_chan (CPUState *env, uint32_t nport)
return (val >> (ncont + (ff << 3))) & 0xff;
}
-static void write_chan (CPUState *env, uint32_t nport, uint32_t data)
+static void write_chan (void *opaque, uint32_t nport, uint32_t data)
{
int ncont, ichan, nreg;
struct dma_regs *r;
@@ -153,7 +153,7 @@ static void write_chan (CPUState *env, uint32_t nport, uint32_t data)
}
}
-static void write_cont (CPUState *env, uint32_t nport, uint32_t data)
+static void write_cont (void *opaque, uint32_t nport, uint32_t data)
{
int iport, ichan, ncont;
struct dma_cont *d;
@@ -345,22 +345,22 @@ void DMA_init (void)
int page_port_list[] = { 0x1, 0x2, 0x3, 0x7 };
for (i = 0; i < 8; i++) {
- register_ioport_write (i, 1, write_chan, 1);
+ register_ioport_write (i, 1, 1, write_chan, NULL);
- register_ioport_write (0xc0 + (i << 1), 1, write_chan, 1);
+ register_ioport_write (0xc0 + (i << 1), 1, 1, write_chan, NULL);
- register_ioport_read (i, 1, read_chan, 1);
- register_ioport_read (0xc0 + (i << 1), 1, read_chan, 1);
+ register_ioport_read (i, 1, 1, read_chan, NULL);
+ register_ioport_read (0xc0 + (i << 1), 1, 1, read_chan, NULL);
}
for (i = 0; i < LENOFA (page_port_list); i++) {
- register_ioport_write (page_port_list[i] + 0x80, 1, write_page, 1);
- register_ioport_write (page_port_list[i] + 0x88, 1, write_page, 1);
+ register_ioport_write (page_port_list[i] + 0x80, 1, 1, write_page, NULL);
+ register_ioport_write (page_port_list[i] + 0x88, 1, 1, write_page, NULL);
}
for (i = 0; i < 8; i++) {
- register_ioport_write (i + 8, 1, write_cont, 1);
- register_ioport_write (0xd0 + (i << 1), 1, write_cont, 1);
+ register_ioport_write (i + 8, 1, 1, write_cont, NULL);
+ register_ioport_write (0xd0 + (i << 1), 1, 1, write_cont, NULL);
}
write_cont (NULL, 0x0d, 0);
diff --git a/hw/sb16.c b/hw/sb16.c
index 9fbf085..aee1d5f 100644
--- a/hw/sb16.c
+++ b/hw/sb16.c
@@ -50,9 +50,9 @@
#endif
#define IO_READ_PROTO(name) \
- uint32_t name (struct CPUState *env, uint32_t nport)
+ uint32_t name (void *opaque, uint32_t nport)
#define IO_WRITE_PROTO(name) \
- void name (struct CPUState *env, uint32_t nport, uint32_t val)
+ void name (void *opaque, uint32_t nport, uint32_t val)
static struct {
int ver_lo;
@@ -550,8 +550,8 @@ static IO_WRITE_PROTO(mixer_write_datab)
static IO_WRITE_PROTO(mixer_write_indexw)
{
- mixer_write_indexb (env, nport, val & 0xff);
- mixer_write_datab (env, nport, (val >> 8) & 0xff);
+ mixer_write_indexb (opaque, nport, val & 0xff);
+ mixer_write_datab (opaque, nport, (val >> 8) & 0xff);
}
static IO_READ_PROTO(mixer_read)
@@ -718,17 +718,17 @@ void SB16_init (void)
}
for (i = 0; i < LENOFA (dsp_write_ports); i++) {
- register_ioport_write (sb.port + dsp_write_ports[i], 1, dsp_write, 1);
+ register_ioport_write (sb.port + dsp_write_ports[i], 1, 1, dsp_write, NULL);
}
for (i = 0; i < LENOFA (dsp_read_ports); i++) {
- register_ioport_read (sb.port + dsp_read_ports[i], 1, dsp_read, 1);
+ register_ioport_read (sb.port + dsp_read_ports[i], 1, 1, dsp_read, NULL);
}
- register_ioport_write (sb.port + 0x4, 1, mixer_write_indexb, 1);
- register_ioport_write (sb.port + 0x4, 1, mixer_write_indexw, 2);
- register_ioport_read (sb.port + 0x5, 1, mixer_read, 1);
- register_ioport_write (sb.port + 0x5, 1, mixer_write_datab, 1);
+ register_ioport_write (sb.port + 0x4, 1, 1, mixer_write_indexb, NULL);
+ register_ioport_write (sb.port + 0x4, 1, 2, mixer_write_indexw, NULL);
+ register_ioport_read (sb.port + 0x5, 1, 1, mixer_read, NULL);
+ register_ioport_write (sb.port + 0x5, 1, 1, mixer_write_datab, NULL);
DMA_register_channel (sb.hdma, SB_read_DMA, NULL);
DMA_register_channel (sb.dma, SB_read_DMA, NULL);