/* * QEMU S/390 Interrupt support * * Copyright IBM Corp. 2012, 2014 * * This work is licensed under the terms of the GNU GPL, version 2 or (at your * option) any later version. See the COPYING file in the top-level directory. */ #include "cpu.h" #include "sysemu/kvm.h" /* * All of the following interrupts are floating, i.e. not per-vcpu. * We just need a dummy cpustate in order to be able to inject in the * non-kvm case. */ #if !defined(CONFIG_USER_ONLY) void s390_sclp_extint(uint32_t parm) { if (kvm_enabled()) { kvm_s390_service_interrupt(parm); } else { S390CPU *dummy_cpu = s390_cpu_addr2state(0); cpu_inject_ext(dummy_cpu, EXT_SERVICE, parm, 0); } } void s390_virtio_irq(int config_change, uint64_t token) { if (kvm_enabled()) { kvm_s390_virtio_irq(config_change, token); } else { S390CPU *dummy_cpu = s390_cpu_addr2state(0); cpu_inject_ext(dummy_cpu, EXT_VIRTIO, config_change, token); } } void s390_io_interrupt(uint16_t subchannel_id, uint16_t subchannel_nr, uint32_t io_int_parm, uint32_t io_int_word) { if (kvm_enabled()) { kvm_s390_io_interrupt(subchannel_id, subchannel_nr, io_int_parm, io_int_word); } else { S390CPU *dummy_cpu = s390_cpu_addr2state(0); cpu_inject_io(dummy_cpu, subchannel_id, subchannel_nr, io_int_parm, io_int_word); } } void s390_crw_mchk(void) { if (kvm_enabled()) { kvm_s390_crw_mchk(); } else { S390CPU *dummy_cpu = s390_cpu_addr2state(0); cpu_inject_crw_mchk(dummy_cpu); } } #endif