提交 afafe4bb 编写于 作者: G Gerd Hoffmann

apci: switch cnt to memory api

Signed-off-by: NGerd Hoffmann <kraxel@redhat.com>
上级 77d58b1e
...@@ -372,13 +372,7 @@ void acpi_pm_tmr_reset(ACPIREGS *ar) ...@@ -372,13 +372,7 @@ void acpi_pm_tmr_reset(ACPIREGS *ar)
} }
/* ACPI PM1aCNT */ /* ACPI PM1aCNT */
void acpi_pm1_cnt_init(ACPIREGS *ar) static void acpi_pm1_cnt_write(ACPIREGS *ar, uint16_t val)
{
ar->wakeup.notify = acpi_notify_wakeup;
qemu_register_wakeup_notifier(&ar->wakeup);
}
void acpi_pm1_cnt_write(ACPIREGS *ar, uint16_t val, char s4)
{ {
ar->pm1.cnt.cnt = val & ~(ACPI_BITMASK_SLEEP_ENABLE); ar->pm1.cnt.cnt = val & ~(ACPI_BITMASK_SLEEP_ENABLE);
...@@ -393,7 +387,7 @@ void acpi_pm1_cnt_write(ACPIREGS *ar, uint16_t val, char s4) ...@@ -393,7 +387,7 @@ void acpi_pm1_cnt_write(ACPIREGS *ar, uint16_t val, char s4)
qemu_system_suspend_request(); qemu_system_suspend_request();
break; break;
default: default:
if (sus_typ == s4) { /* S4 request */ if (sus_typ == ar->pm1.cnt.s4_val) { /* S4 request */
monitor_protocol_event(QEVENT_SUSPEND_DISK, NULL); monitor_protocol_event(QEVENT_SUSPEND_DISK, NULL);
qemu_system_shutdown_request(); qemu_system_shutdown_request();
} }
...@@ -413,6 +407,34 @@ void acpi_pm1_cnt_update(ACPIREGS *ar, ...@@ -413,6 +407,34 @@ void acpi_pm1_cnt_update(ACPIREGS *ar,
} }
} }
static uint64_t acpi_pm_cnt_read(void *opaque, hwaddr addr, unsigned width)
{
ACPIREGS *ar = opaque;
return ar->pm1.cnt.cnt;
}
static void acpi_pm_cnt_write(void *opaque, hwaddr addr, uint64_t val,
unsigned width)
{
acpi_pm1_cnt_write(opaque, val);
}
static const MemoryRegionOps acpi_pm_cnt_ops = {
.read = acpi_pm_cnt_read,
.write = acpi_pm_cnt_write,
.valid.min_access_size = 2,
.valid.max_access_size = 2,
.endianness = DEVICE_LITTLE_ENDIAN,
};
void acpi_pm1_cnt_init(ACPIREGS *ar, MemoryRegion *parent)
{
ar->wakeup.notify = acpi_notify_wakeup;
qemu_register_wakeup_notifier(&ar->wakeup);
memory_region_init_io(&ar->pm1.cnt.io, &acpi_pm_cnt_ops, ar, "acpi-cnt", 2);
memory_region_add_subregion(parent, 4, &ar->pm1.cnt.io);
}
void acpi_pm1_cnt_reset(ACPIREGS *ar) void acpi_pm1_cnt_reset(ACPIREGS *ar)
{ {
ar->pm1.cnt.cnt = 0; ar->pm1.cnt.cnt = 0;
......
...@@ -96,7 +96,9 @@ struct ACPIPM1EVT { ...@@ -96,7 +96,9 @@ struct ACPIPM1EVT {
}; };
struct ACPIPM1CNT { struct ACPIPM1CNT {
MemoryRegion io;
uint16_t cnt; uint16_t cnt;
uint8_t s4_val;
}; };
struct ACPIGPE { struct ACPIGPE {
...@@ -139,8 +141,7 @@ void acpi_pm1_evt_power_down(ACPIREGS *ar); ...@@ -139,8 +141,7 @@ void acpi_pm1_evt_power_down(ACPIREGS *ar);
void acpi_pm1_evt_reset(ACPIREGS *ar); void acpi_pm1_evt_reset(ACPIREGS *ar);
/* PM1a_CNT: piix and ich9 don't implement PM1b CNT. */ /* PM1a_CNT: piix and ich9 don't implement PM1b CNT. */
void acpi_pm1_cnt_init(ACPIREGS *ar); void acpi_pm1_cnt_init(ACPIREGS *ar, MemoryRegion *parent);
void acpi_pm1_cnt_write(ACPIREGS *ar, uint16_t val, char s4);
void acpi_pm1_cnt_update(ACPIREGS *ar, void acpi_pm1_cnt_update(ACPIREGS *ar,
bool sci_enable, bool sci_disable); bool sci_enable, bool sci_disable);
void acpi_pm1_cnt_reset(ACPIREGS *ar); void acpi_pm1_cnt_reset(ACPIREGS *ar);
......
...@@ -116,9 +116,6 @@ static void pm_ioport_writew(void *opaque, uint32_t addr, uint32_t val) ...@@ -116,9 +116,6 @@ static void pm_ioport_writew(void *opaque, uint32_t addr, uint32_t val)
pm->acpi_regs.pm1.evt.en = val; pm->acpi_regs.pm1.evt.en = val;
pm_update_sci(pm); pm_update_sci(pm);
break; break;
case ICH9_PMIO_PM1_CNT:
acpi_pm1_cnt_write(&pm->acpi_regs, val, 0);
break;
default: default:
pm_ioport_write_fallback(opaque, addr, 2, val); pm_ioport_write_fallback(opaque, addr, 2, val);
break; break;
...@@ -138,9 +135,6 @@ static uint32_t pm_ioport_readw(void *opaque, uint32_t addr) ...@@ -138,9 +135,6 @@ static uint32_t pm_ioport_readw(void *opaque, uint32_t addr)
case ICH9_PMIO_PM1_EN: case ICH9_PMIO_PM1_EN:
val = pm->acpi_regs.pm1.evt.en; val = pm->acpi_regs.pm1.evt.en;
break; break;
case ICH9_PMIO_PM1_CNT:
val = pm->acpi_regs.pm1.cnt.cnt;
break;
default: default:
val = pm_ioport_read_fallback(opaque, addr, 2); val = pm_ioport_read_fallback(opaque, addr, 2);
break; break;
...@@ -318,7 +312,7 @@ void ich9_pm_init(ICH9LPCPMRegs *pm, qemu_irq sci_irq, qemu_irq cmos_s3) ...@@ -318,7 +312,7 @@ void ich9_pm_init(ICH9LPCPMRegs *pm, qemu_irq sci_irq, qemu_irq cmos_s3)
memory_region_add_subregion(get_system_io(), 0, &pm->io); memory_region_add_subregion(get_system_io(), 0, &pm->io);
acpi_pm_tmr_init(&pm->acpi_regs, ich9_pm_update_sci_fn, &pm->io); acpi_pm_tmr_init(&pm->acpi_regs, ich9_pm_update_sci_fn, &pm->io);
acpi_pm1_cnt_init(&pm->acpi_regs); acpi_pm1_cnt_init(&pm->acpi_regs, &pm->io);
acpi_gpe_init(&pm->acpi_regs, ICH9_PMIO_GPE0_LEN); acpi_gpe_init(&pm->acpi_regs, ICH9_PMIO_GPE0_LEN);
acpi_gpe_blk(&pm->acpi_regs, ICH9_PMIO_GPE0_STS); acpi_gpe_blk(&pm->acpi_regs, ICH9_PMIO_GPE0_STS);
......
...@@ -129,9 +129,6 @@ static void pm_ioport_write(void *opaque, hwaddr addr, uint64_t val, ...@@ -129,9 +129,6 @@ static void pm_ioport_write(void *opaque, hwaddr addr, uint64_t val,
acpi_pm1_evt_write_en(&s->ar, val); acpi_pm1_evt_write_en(&s->ar, val);
pm_update_sci(s); pm_update_sci(s);
break; break;
case 0x04:
acpi_pm1_cnt_write(&s->ar, val, s->s4_val);
break;
default: default:
break; break;
} }
...@@ -151,9 +148,6 @@ static uint64_t pm_ioport_read(void *opaque, hwaddr addr, unsigned width) ...@@ -151,9 +148,6 @@ static uint64_t pm_ioport_read(void *opaque, hwaddr addr, unsigned width)
case 0x02: case 0x02:
val = s->ar.pm1.evt.en; val = s->ar.pm1.evt.en;
break; break;
case 0x04:
val = s->ar.pm1.cnt.cnt;
break;
default: default:
val = 0; val = 0;
break; break;
...@@ -461,6 +455,7 @@ static int piix4_pm_initfn(PCIDevice *dev) ...@@ -461,6 +455,7 @@ static int piix4_pm_initfn(PCIDevice *dev)
memory_region_add_subregion(get_system_io(), 0, &s->io); memory_region_add_subregion(get_system_io(), 0, &s->io);
acpi_pm_tmr_init(&s->ar, pm_tmr_timer, &s->io); acpi_pm_tmr_init(&s->ar, pm_tmr_timer, &s->io);
acpi_pm1_cnt_init(&s->ar, &s->io);
acpi_gpe_init(&s->ar, GPE_LEN); acpi_gpe_init(&s->ar, GPE_LEN);
s->powerdown_notifier.notify = piix4_pm_powerdown_req; s->powerdown_notifier.notify = piix4_pm_powerdown_req;
...@@ -487,7 +482,6 @@ i2c_bus *piix4_pm_init(PCIBus *bus, int devfn, uint32_t smb_io_base, ...@@ -487,7 +482,6 @@ i2c_bus *piix4_pm_init(PCIBus *bus, int devfn, uint32_t smb_io_base,
s = DO_UPCAST(PIIX4PMState, dev, dev); s = DO_UPCAST(PIIX4PMState, dev, dev);
s->irq = sci_irq; s->irq = sci_irq;
acpi_pm1_cnt_init(&s->ar);
s->smi_irq = smi_irq; s->smi_irq = smi_irq;
s->kvm_enabled = kvm_enabled; s->kvm_enabled = kvm_enabled;
......
...@@ -211,9 +211,6 @@ static void pm_ioport_writew(void *opaque, uint32_t addr, uint32_t val) ...@@ -211,9 +211,6 @@ static void pm_ioport_writew(void *opaque, uint32_t addr, uint32_t val)
acpi_pm1_evt_write_en(&s->ar, val); acpi_pm1_evt_write_en(&s->ar, val);
pm_update_sci(s); pm_update_sci(s);
break; break;
case 0x04:
acpi_pm1_cnt_write(&s->ar, val, 0);
break;
default: default:
break; break;
} }
...@@ -233,9 +230,6 @@ static uint32_t pm_ioport_readw(void *opaque, uint32_t addr) ...@@ -233,9 +230,6 @@ static uint32_t pm_ioport_readw(void *opaque, uint32_t addr)
case 0x02: case 0x02:
val = s->ar.pm1.evt.en; val = s->ar.pm1.evt.en;
break; break;
case 0x04:
val = s->ar.pm1.cnt.cnt;
break;
default: default:
val = 0; val = 0;
break; break;
...@@ -443,7 +437,7 @@ static int vt82c686b_pm_initfn(PCIDevice *dev) ...@@ -443,7 +437,7 @@ static int vt82c686b_pm_initfn(PCIDevice *dev)
memory_region_add_subregion(get_system_io(), 0, &s->io); memory_region_add_subregion(get_system_io(), 0, &s->io);
acpi_pm_tmr_init(&s->ar, pm_tmr_timer, &s->io); acpi_pm_tmr_init(&s->ar, pm_tmr_timer, &s->io);
acpi_pm1_cnt_init(&s->ar); acpi_pm1_cnt_init(&s->ar, &s->io);
pm_smbus_init(&s->dev.qdev, &s->smb); pm_smbus_init(&s->dev.qdev, &s->smb);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部