vt82c686: Fix superio_cfg_{read,write}() functions
These functions are memory region callbacks so we have to check against relative address not the mapped address. Signed-off-by: BALATON Zoltan <balaton@eik.bme.hu> Message-Id: <15b2968fd300a12d06b42368d084f6f80d3c3be5.1610223397.git.balaton@eik.bme.hu> [PMD: Split original patch in 5, this is part 5/5] Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
This commit is contained in:
parent
2c4c556e06
commit
cc2b455011
@ -260,12 +260,13 @@ static void superio_cfg_write(void *opaque, hwaddr addr, uint64_t data,
|
|||||||
SuperIOConfig *sc = opaque;
|
SuperIOConfig *sc = opaque;
|
||||||
uint8_t idx = sc->regs[0];
|
uint8_t idx = sc->regs[0];
|
||||||
|
|
||||||
if (addr == 0x3f0) { /* config index register */
|
if (addr == 0) { /* config index register */
|
||||||
idx = data & 0xff;
|
sc->regs[0] = data;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* 0x3f1, config data register */
|
|
||||||
trace_via_superio_write(idx, data & 0xff);
|
/* config data register */
|
||||||
|
trace_via_superio_write(idx, data);
|
||||||
switch (idx) {
|
switch (idx) {
|
||||||
case 0x00 ... 0xdf:
|
case 0x00 ... 0xdf:
|
||||||
case 0xe4:
|
case 0xe4:
|
||||||
@ -284,7 +285,7 @@ static void superio_cfg_write(void *opaque, hwaddr addr, uint64_t data,
|
|||||||
"via_superio_cfg: unimplemented register 0x%x\n", idx);
|
"via_superio_cfg: unimplemented register 0x%x\n", idx);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
sc->regs[idx] = data & 0xff;
|
sc->regs[idx] = data;
|
||||||
}
|
}
|
||||||
|
|
||||||
static uint64_t superio_cfg_read(void *opaque, hwaddr addr, unsigned size)
|
static uint64_t superio_cfg_read(void *opaque, hwaddr addr, unsigned size)
|
||||||
|
Loading…
Reference in New Issue
Block a user