xref: /qemu/target/alpha/sys_helper.c (revision d6ea423635958b0aaa1d58462d1603fd35194acf)
169163fbbSRichard Henderson /*
269163fbbSRichard Henderson  *  Helpers for system instructions.
369163fbbSRichard Henderson  *
469163fbbSRichard Henderson  *  Copyright (c) 2007 Jocelyn Mayer
569163fbbSRichard Henderson  *
669163fbbSRichard Henderson  * This library is free software; you can redistribute it and/or
769163fbbSRichard Henderson  * modify it under the terms of the GNU Lesser General Public
869163fbbSRichard Henderson  * License as published by the Free Software Foundation; either
9*d6ea4236SChetan Pant  * version 2.1 of the License, or (at your option) any later version.
1069163fbbSRichard Henderson  *
1169163fbbSRichard Henderson  * This library is distributed in the hope that it will be useful,
1269163fbbSRichard Henderson  * but WITHOUT ANY WARRANTY; without even the implied warranty of
1369163fbbSRichard Henderson  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
1469163fbbSRichard Henderson  * Lesser General Public License for more details.
1569163fbbSRichard Henderson  *
1669163fbbSRichard Henderson  * You should have received a copy of the GNU Lesser General Public
1769163fbbSRichard Henderson  * License along with this library; if not, see <http://www.gnu.org/licenses/>.
1869163fbbSRichard Henderson  */
1969163fbbSRichard Henderson 
20e2e5e114SPeter Maydell #include "qemu/osdep.h"
2169163fbbSRichard Henderson #include "cpu.h"
2263c91552SPaolo Bonzini #include "exec/exec-all.h"
232ef6175aSRichard Henderson #include "exec/helper-proto.h"
2454d31236SMarkus Armbruster #include "sysemu/runstate.h"
259c17d615SPaolo Bonzini #include "sysemu/sysemu.h"
261de7afc9SPaolo Bonzini #include "qemu/timer.h"
2769163fbbSRichard Henderson 
2869163fbbSRichard Henderson 
2969163fbbSRichard Henderson uint64_t helper_load_pcc(CPUAlphaState *env)
3069163fbbSRichard Henderson {
3169163fbbSRichard Henderson #ifndef CONFIG_USER_ONLY
3269163fbbSRichard Henderson     /* In system mode we have access to a decent high-resolution clock.
3369163fbbSRichard Henderson        In order to make OS-level time accounting work with the RPCC,
3469163fbbSRichard Henderson        present it with a well-timed clock fixed at 250MHz.  */
3569163fbbSRichard Henderson     return (((uint64_t)env->pcc_ofs << 32)
36bc72ad67SAlex Bligh             | (uint32_t)(qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL) >> 2));
3769163fbbSRichard Henderson #else
38bc72ad67SAlex Bligh     /* In user-mode, QEMU_CLOCK_VIRTUAL doesn't exist.  Just pass through the host cpu
3969163fbbSRichard Henderson        clock ticks.  Also, don't bother taking PCC_OFS into account.  */
404a7428c5SChristopher Covington     return (uint32_t)cpu_get_host_ticks();
4169163fbbSRichard Henderson #endif
4269163fbbSRichard Henderson }
4369163fbbSRichard Henderson 
4469163fbbSRichard Henderson /* PALcode support special instructions */
4569163fbbSRichard Henderson #ifndef CONFIG_USER_ONLY
4669163fbbSRichard Henderson void helper_tbia(CPUAlphaState *env)
4769163fbbSRichard Henderson {
481c7ad260SRichard Henderson     tlb_flush(env_cpu(env));
4969163fbbSRichard Henderson }
5069163fbbSRichard Henderson 
5169163fbbSRichard Henderson void helper_tbis(CPUAlphaState *env, uint64_t p)
5269163fbbSRichard Henderson {
531c7ad260SRichard Henderson     tlb_flush_page(env_cpu(env), p);
5469163fbbSRichard Henderson }
5569163fbbSRichard Henderson 
56a9ead832SRichard Henderson void helper_tb_flush(CPUAlphaState *env)
57a9ead832SRichard Henderson {
581c7ad260SRichard Henderson     tb_flush(env_cpu(env));
59a9ead832SRichard Henderson }
60a9ead832SRichard Henderson 
6169163fbbSRichard Henderson void helper_halt(uint64_t restart)
6269163fbbSRichard Henderson {
6369163fbbSRichard Henderson     if (restart) {
64cf83f140SEric Blake         qemu_system_reset_request(SHUTDOWN_CAUSE_GUEST_RESET);
6569163fbbSRichard Henderson     } else {
66cf83f140SEric Blake         qemu_system_shutdown_request(SHUTDOWN_CAUSE_GUEST_SHUTDOWN);
6769163fbbSRichard Henderson     }
6869163fbbSRichard Henderson }
6969163fbbSRichard Henderson 
7019e0cbb8SRichard Henderson uint64_t helper_get_vmtime(void)
7119e0cbb8SRichard Henderson {
72bc72ad67SAlex Bligh     return qemu_clock_get_ns(QEMU_CLOCK_VIRTUAL);
7319e0cbb8SRichard Henderson }
7419e0cbb8SRichard Henderson 
7519e0cbb8SRichard Henderson uint64_t helper_get_walltime(void)
7669163fbbSRichard Henderson {
77884f17c2SAlex Bligh     return qemu_clock_get_ns(rtc_clock);
7869163fbbSRichard Henderson }
7969163fbbSRichard Henderson 
8069163fbbSRichard Henderson void helper_set_alarm(CPUAlphaState *env, uint64_t expire)
8169163fbbSRichard Henderson {
821c7ad260SRichard Henderson     AlphaCPU *cpu = env_archcpu(env);
83c9245853SAndreas Färber 
8469163fbbSRichard Henderson     if (expire) {
8569163fbbSRichard Henderson         env->alarm_expire = expire;
86bc72ad67SAlex Bligh         timer_mod(cpu->alarm_timer, expire);
8769163fbbSRichard Henderson     } else {
88bc72ad67SAlex Bligh         timer_del(cpu->alarm_timer);
8969163fbbSRichard Henderson     }
9069163fbbSRichard Henderson }
91ba96394eSRichard Henderson 
9269163fbbSRichard Henderson #endif /* CONFIG_USER_ONLY */
93