]> git.proxmox.com Git - mirror_qemu.git/blame - target-alpha/sys_helper.c
virtio: decrement vq->inuse in virtqueue_discard()
[mirror_qemu.git] / target-alpha / sys_helper.c
CommitLineData
69163fbb
RH
1/*
2 * Helpers for system instructions.
3 *
4 * Copyright (c) 2007 Jocelyn Mayer
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
e2e5e114 20#include "qemu/osdep.h"
69163fbb 21#include "cpu.h"
63c91552 22#include "exec/exec-all.h"
2ef6175a 23#include "exec/helper-proto.h"
9c17d615 24#include "sysemu/sysemu.h"
1de7afc9 25#include "qemu/timer.h"
69163fbb
RH
26
27
28uint64_t helper_load_pcc(CPUAlphaState *env)
29{
30#ifndef CONFIG_USER_ONLY
31 /* In system mode we have access to a decent high-resolution clock.
32 In order to make OS-level time accounting work with the RPCC,
33 present it with a well-timed clock fixed at 250MHz. */
34 return (((uint64_t)env->pcc_ofs << 32)
bc72ad67 35 | (uint32_t)(qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL) >> 2));
69163fbb 36#else
bc72ad67 37 /* In user-mode, QEMU_CLOCK_VIRTUAL doesn't exist. Just pass through the host cpu
69163fbb 38 clock ticks. Also, don't bother taking PCC_OFS into account. */
4a7428c5 39 return (uint32_t)cpu_get_host_ticks();
69163fbb
RH
40#endif
41}
42
43/* PALcode support special instructions */
44#ifndef CONFIG_USER_ONLY
69163fbb
RH
45void helper_tbia(CPUAlphaState *env)
46{
00c8cb0a 47 tlb_flush(CPU(alpha_env_get_cpu(env)), 1);
69163fbb
RH
48}
49
50void helper_tbis(CPUAlphaState *env, uint64_t p)
51{
31b030d4 52 tlb_flush_page(CPU(alpha_env_get_cpu(env)), p);
69163fbb
RH
53}
54
a9ead832
RH
55void helper_tb_flush(CPUAlphaState *env)
56{
bbd77c18 57 tb_flush(CPU(alpha_env_get_cpu(env)));
a9ead832
RH
58}
59
69163fbb
RH
60void helper_halt(uint64_t restart)
61{
62 if (restart) {
63 qemu_system_reset_request();
64 } else {
65 qemu_system_shutdown_request();
66 }
67}
68
19e0cbb8
RH
69uint64_t helper_get_vmtime(void)
70{
bc72ad67 71 return qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL);
19e0cbb8
RH
72}
73
74uint64_t helper_get_walltime(void)
69163fbb 75{
884f17c2 76 return qemu_clock_get_ns(rtc_clock);
69163fbb
RH
77}
78
79void helper_set_alarm(CPUAlphaState *env, uint64_t expire)
80{
c9245853
AF
81 AlphaCPU *cpu = alpha_env_get_cpu(env);
82
69163fbb
RH
83 if (expire) {
84 env->alarm_expire = expire;
bc72ad67 85 timer_mod(cpu->alarm_timer, expire);
69163fbb 86 } else {
bc72ad67 87 timer_del(cpu->alarm_timer);
69163fbb
RH
88 }
89}
ba96394e 90
69163fbb 91#endif /* CONFIG_USER_ONLY */