diff options
author | Daniel Baumann <mail@daniel-baumann.ch> | 2025-06-06 10:05:23 +0000 |
---|---|---|
committer | Daniel Baumann <mail@daniel-baumann.ch> | 2025-06-06 10:05:23 +0000 |
commit | 755cc582a2473d06f3a2131d506d0311cc70e9f9 (patch) | |
tree | 3efb1ddb8d57bbb4539ac0d229b384871c57820f /hw/misc/pvpanic.c | |
parent | Initial commit. (diff) | |
download | qemu-upstream.tar.xz qemu-upstream.zip |
Adding upstream version 1:7.2+dfsg.upstream/1%7.2+dfsgupstream
Signed-off-by: Daniel Baumann <mail@daniel-baumann.ch>
Diffstat (limited to 'hw/misc/pvpanic.c')
-rw-r--r-- | hw/misc/pvpanic.c | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/hw/misc/pvpanic.c b/hw/misc/pvpanic.c new file mode 100644 index 00000000..1540e909 --- /dev/null +++ b/hw/misc/pvpanic.c @@ -0,0 +1,71 @@ +/* + * QEMU simulated pvpanic device. + * + * Copyright Fujitsu, Corp. 2013 + * + * Authors: + * Wen Congyang <wency@cn.fujitsu.com> + * Hu Tao <hutao@cn.fujitsu.com> + * + * This work is licensed under the terms of the GNU GPL, version 2 or later. + * See the COPYING file in the top-level directory. + * + */ + +#include "qemu/osdep.h" +#include "qemu/log.h" +#include "qemu/module.h" +#include "sysemu/runstate.h" + +#include "hw/nvram/fw_cfg.h" +#include "hw/qdev-properties.h" +#include "hw/misc/pvpanic.h" +#include "qom/object.h" +#include "standard-headers/linux/pvpanic.h" + +static void handle_event(int event) +{ + static bool logged; + + if (event & ~(PVPANIC_PANICKED | PVPANIC_CRASH_LOADED) && !logged) { + qemu_log_mask(LOG_GUEST_ERROR, "pvpanic: unknown event %#x.\n", event); + logged = true; + } + + if (event & PVPANIC_PANICKED) { + qemu_system_guest_panicked(NULL); + return; + } + + if (event & PVPANIC_CRASH_LOADED) { + qemu_system_guest_crashloaded(NULL); + return; + } +} + +/* return supported events on read */ +static uint64_t pvpanic_read(void *opaque, hwaddr addr, unsigned size) +{ + PVPanicState *pvp = opaque; + return pvp->events; +} + +static void pvpanic_write(void *opaque, hwaddr addr, uint64_t val, + unsigned size) +{ + handle_event(val); +} + +static const MemoryRegionOps pvpanic_ops = { + .read = pvpanic_read, + .write = pvpanic_write, + .impl = { + .min_access_size = 1, + .max_access_size = 1, + }, +}; + +void pvpanic_setup_io(PVPanicState *s, DeviceState *dev, unsigned size) +{ + memory_region_init_io(&s->mr, OBJECT(dev), &pvpanic_ops, s, "pvpanic", size); +} |