| /* |
| * ARM SSE-200 Message Handling Unit (MHU) |
| * |
| * Copyright (c) 2019 Linaro Limited |
| * Written by Peter Maydell |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 or |
| * (at your option) any later version. |
| */ |
| |
| /* |
| * This is a model of the Message Handling Unit (MHU) which is part of the |
| * Arm SSE-200 and documented in |
| * http://infocenter.arm.com/help/topic/com.arm.doc.101104_0100_00_en/corelink_sse200_subsystem_for_embedded_technical_reference_manual_101104_0100_00_en.pdf |
| * |
| * QEMU interface: |
| * + sysbus MMIO region 0: the system information register bank |
| * + sysbus IRQ 0: interrupt for CPU 0 |
| * + sysbus IRQ 1: interrupt for CPU 1 |
| */ |
| |
| #ifndef HW_MISC_ARMSSE_MHU_H |
| #define HW_MISC_ARMSSE_MHU_H |
| |
| #include "hw/sysbus.h" |
| #include "qom/object.h" |
| |
| #define TYPE_ARMSSE_MHU "armsse-mhu" |
| typedef struct ARMSSEMHU ARMSSEMHU; |
| DECLARE_INSTANCE_CHECKER(ARMSSEMHU, ARMSSE_MHU, |
| TYPE_ARMSSE_MHU) |
| |
| struct ARMSSEMHU { |
| /*< private >*/ |
| SysBusDevice parent_obj; |
| |
| /*< public >*/ |
| MemoryRegion iomem; |
| qemu_irq cpu0irq; |
| qemu_irq cpu1irq; |
| |
| uint32_t cpu0intr; |
| uint32_t cpu1intr; |
| }; |
| |
| #endif |