blob: 40fe5a19bb3c2ec14f0f2ac58e78db95cbc89aea [file] [log] [blame]
Peter Crosthwaite9b68a772015-09-10 22:39:33 -07001/*
2 * Host code generation common components
3 *
4 * Copyright (c) 2015 Peter Crosthwaite <crosthwaite.peter@gmail.com>
5 *
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2 of the License, or (at your option) any later version.
10 *
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
18 */
19
Peter Maydell7b31bbc2016-01-26 18:16:56 +000020#include "qemu/osdep.h"
Peter Crosthwaite9b68a772015-09-10 22:39:33 -070021#include "qemu-common.h"
22#include "qom/cpu.h"
Paolo Bonzini4b4629d2016-03-15 16:47:38 +010023#include "sysemu/cpus.h"
Jan Kiszka8d04fb52017-02-23 18:29:11 +000024#include "qemu/main-loop.h"
Peter Crosthwaite9b68a772015-09-10 22:39:33 -070025
Peter Crosthwaite5f12a782015-09-10 22:39:36 -070026uintptr_t qemu_real_host_page_size;
Paolo Bonzini0c2d70c2015-12-02 13:00:54 +010027intptr_t qemu_real_host_page_mask;
Peter Crosthwaite5f12a782015-09-10 22:39:36 -070028
Peter Crosthwaite9b68a772015-09-10 22:39:33 -070029#ifndef CONFIG_USER_ONLY
30/* mask must never be zero, except for A20 change call */
31static void tcg_handle_interrupt(CPUState *cpu, int mask)
32{
33 int old_mask;
Jan Kiszka8d04fb52017-02-23 18:29:11 +000034 g_assert(qemu_mutex_iothread_locked());
Peter Crosthwaite9b68a772015-09-10 22:39:33 -070035
36 old_mask = cpu->interrupt_request;
37 cpu->interrupt_request |= mask;
38
39 /*
40 * If called from iothread context, wake the target cpu in
41 * case its halted.
42 */
43 if (!qemu_cpu_is_self(cpu)) {
44 qemu_cpu_kick(cpu);
Peter Crosthwaite9b68a772015-09-10 22:39:33 -070045 } else {
Paolo Bonzini30f3dda2017-03-03 16:39:18 +010046 cpu->icount_decr.u16.high = -1;
47 if (use_icount &&
48 !cpu->can_do_io
49 && (mask & ~old_mask) != 0) {
50 cpu_abort(cpu, "Raised interrupt while not in I/O function");
Jan Kiszka8d04fb52017-02-23 18:29:11 +000051 }
Peter Crosthwaite9b68a772015-09-10 22:39:33 -070052 }
53}
54
55CPUInterruptHandler cpu_interrupt_handler = tcg_handle_interrupt;
56#endif