From: Paolo Bonzini <pbonzini@redhat.com>
To: qemu-devel@nongnu.org
Subject: [Qemu-devel] [PULL 47/52] mips: move CP0 functions out of cpu.h
Date: Thu, 19 May 2016 13:18:41 +0200 [thread overview]
Message-ID: <1463656726-35952-48-git-send-email-pbonzini@redhat.com> (raw)
In-Reply-To: <1463656726-35952-1-git-send-email-pbonzini@redhat.com>
These are here for historical reasons: they are needed from both gdbstub.c
and op_helper.c, and the latter was compiled with fixed AREG0. It is
not needed anymore, so uninline them.
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
---
target-mips/cpu.h | 113 ++-------------------------------------------------
target-mips/helper.c | 108 ++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 112 insertions(+), 109 deletions(-)
diff --git a/target-mips/cpu.h b/target-mips/cpu.h
index a7c8660..3cacf37 100644
--- a/target-mips/cpu.h
+++ b/target-mips/cpu.h
@@ -1035,115 +1035,10 @@ static inline void compute_hflags(CPUMIPSState *env)
}
}
-#ifndef CONFIG_USER_ONLY
-static inline void cpu_mips_tlb_flush(CPUMIPSState *env, int flush_global)
-{
- MIPSCPU *cpu = mips_env_get_cpu(env);
-
- /* Flush qemu's TLB and discard all shadowed entries. */
- tlb_flush(CPU(cpu), flush_global);
- env->tlb->tlb_in_use = env->tlb->nb_tlb;
-}
-
-/* Called for updates to CP0_Status. */
-static inline void sync_c0_status(CPUMIPSState *env, CPUMIPSState *cpu, int tc)
-{
- int32_t tcstatus, *tcst;
- uint32_t v = cpu->CP0_Status;
- uint32_t cu, mx, asid, ksu;
- uint32_t mask = ((1 << CP0TCSt_TCU3)
- | (1 << CP0TCSt_TCU2)
- | (1 << CP0TCSt_TCU1)
- | (1 << CP0TCSt_TCU0)
- | (1 << CP0TCSt_TMX)
- | (3 << CP0TCSt_TKSU)
- | (0xff << CP0TCSt_TASID));
-
- cu = (v >> CP0St_CU0) & 0xf;
- mx = (v >> CP0St_MX) & 0x1;
- ksu = (v >> CP0St_KSU) & 0x3;
- asid = env->CP0_EntryHi & 0xff;
-
- tcstatus = cu << CP0TCSt_TCU0;
- tcstatus |= mx << CP0TCSt_TMX;
- tcstatus |= ksu << CP0TCSt_TKSU;
- tcstatus |= asid;
-
- if (tc == cpu->current_tc) {
- tcst = &cpu->active_tc.CP0_TCStatus;
- } else {
- tcst = &cpu->tcs[tc].CP0_TCStatus;
- }
-
- *tcst &= ~mask;
- *tcst |= tcstatus;
- compute_hflags(cpu);
-}
-
-static inline void cpu_mips_store_status(CPUMIPSState *env, target_ulong val)
-{
- uint32_t mask = env->CP0_Status_rw_bitmask;
- target_ulong old = env->CP0_Status;
-
- if (env->insn_flags & ISA_MIPS32R6) {
- bool has_supervisor = extract32(mask, CP0St_KSU, 2) == 0x3;
-#if defined(TARGET_MIPS64)
- uint32_t ksux = (1 << CP0St_KX) & val;
- ksux |= (ksux >> 1) & val; /* KX = 0 forces SX to be 0 */
- ksux |= (ksux >> 1) & val; /* SX = 0 forces UX to be 0 */
- val = (val & ~(7 << CP0St_UX)) | ksux;
-#endif
- if (has_supervisor && extract32(val, CP0St_KSU, 2) == 0x3) {
- mask &= ~(3 << CP0St_KSU);
- }
- mask &= ~(((1 << CP0St_SR) | (1 << CP0St_NMI)) & val);
- }
-
- env->CP0_Status = (old & ~mask) | (val & mask);
-#if defined(TARGET_MIPS64)
- if ((env->CP0_Status ^ old) & (old & (7 << CP0St_UX))) {
- /* Access to at least one of the 64-bit segments has been disabled */
- cpu_mips_tlb_flush(env, 1);
- }
-#endif
- if (env->CP0_Config3 & (1 << CP0C3_MT)) {
- sync_c0_status(env, env, env->current_tc);
- } else {
- compute_hflags(env);
- }
-}
-
-static inline void cpu_mips_store_cause(CPUMIPSState *env, target_ulong val)
-{
- uint32_t mask = 0x00C00300;
- uint32_t old = env->CP0_Cause;
- int i;
-
- if (env->insn_flags & ISA_MIPS32R2) {
- mask |= 1 << CP0Ca_DC;
- }
- if (env->insn_flags & ISA_MIPS32R6) {
- mask &= ~((1 << CP0Ca_WP) & val);
- }
-
- env->CP0_Cause = (env->CP0_Cause & ~mask) | (val & mask);
-
- if ((old ^ env->CP0_Cause) & (1 << CP0Ca_DC)) {
- if (env->CP0_Cause & (1 << CP0Ca_DC)) {
- cpu_mips_stop_count(env);
- } else {
- cpu_mips_start_count(env);
- }
- }
-
- /* Set/reset software interrupts */
- for (i = 0 ; i < 2 ; i++) {
- if ((old ^ env->CP0_Cause) & (1 << (CP0Ca_IP + i))) {
- cpu_mips_soft_irq(env, i, env->CP0_Cause & (1 << (CP0Ca_IP + i)));
- }
- }
-}
-#endif
+void cpu_mips_tlb_flush(CPUMIPSState *env, int flush_global);
+void sync_c0_status(CPUMIPSState *env, CPUMIPSState *cpu, int tc);
+void cpu_mips_store_status(CPUMIPSState *env, target_ulong val);
+void cpu_mips_store_cause(CPUMIPSState *env, target_ulong val);
void QEMU_NORETURN do_raise_exception_err(CPUMIPSState *env, uint32_t exception,
int error_code, uintptr_t pc);
diff --git a/target-mips/helper.c b/target-mips/helper.c
index 1f35e7f..3bbc72c 100644
--- a/target-mips/helper.c
+++ b/target-mips/helper.c
@@ -221,6 +221,114 @@ static int get_physical_address (CPUMIPSState *env, hwaddr *physical,
}
return ret;
}
+
+void cpu_mips_tlb_flush(CPUMIPSState *env, int flush_global)
+{
+ MIPSCPU *cpu = mips_env_get_cpu(env);
+
+ /* Flush qemu's TLB and discard all shadowed entries. */
+ tlb_flush(CPU(cpu), flush_global);
+ env->tlb->tlb_in_use = env->tlb->nb_tlb;
+}
+
+/* Called for updates to CP0_Status. */
+void sync_c0_status(CPUMIPSState *env, CPUMIPSState *cpu, int tc)
+{
+ int32_t tcstatus, *tcst;
+ uint32_t v = cpu->CP0_Status;
+ uint32_t cu, mx, asid, ksu;
+ uint32_t mask = ((1 << CP0TCSt_TCU3)
+ | (1 << CP0TCSt_TCU2)
+ | (1 << CP0TCSt_TCU1)
+ | (1 << CP0TCSt_TCU0)
+ | (1 << CP0TCSt_TMX)
+ | (3 << CP0TCSt_TKSU)
+ | (0xff << CP0TCSt_TASID));
+
+ cu = (v >> CP0St_CU0) & 0xf;
+ mx = (v >> CP0St_MX) & 0x1;
+ ksu = (v >> CP0St_KSU) & 0x3;
+ asid = env->CP0_EntryHi & 0xff;
+
+ tcstatus = cu << CP0TCSt_TCU0;
+ tcstatus |= mx << CP0TCSt_TMX;
+ tcstatus |= ksu << CP0TCSt_TKSU;
+ tcstatus |= asid;
+
+ if (tc == cpu->current_tc) {
+ tcst = &cpu->active_tc.CP0_TCStatus;
+ } else {
+ tcst = &cpu->tcs[tc].CP0_TCStatus;
+ }
+
+ *tcst &= ~mask;
+ *tcst |= tcstatus;
+ compute_hflags(cpu);
+}
+
+void cpu_mips_store_status(CPUMIPSState *env, target_ulong val)
+{
+ uint32_t mask = env->CP0_Status_rw_bitmask;
+ target_ulong old = env->CP0_Status;
+
+ if (env->insn_flags & ISA_MIPS32R6) {
+ bool has_supervisor = extract32(mask, CP0St_KSU, 2) == 0x3;
+#if defined(TARGET_MIPS64)
+ uint32_t ksux = (1 << CP0St_KX) & val;
+ ksux |= (ksux >> 1) & val; /* KX = 0 forces SX to be 0 */
+ ksux |= (ksux >> 1) & val; /* SX = 0 forces UX to be 0 */
+ val = (val & ~(7 << CP0St_UX)) | ksux;
+#endif
+ if (has_supervisor && extract32(val, CP0St_KSU, 2) == 0x3) {
+ mask &= ~(3 << CP0St_KSU);
+ }
+ mask &= ~(((1 << CP0St_SR) | (1 << CP0St_NMI)) & val);
+ }
+
+ env->CP0_Status = (old & ~mask) | (val & mask);
+#if defined(TARGET_MIPS64)
+ if ((env->CP0_Status ^ old) & (old & (7 << CP0St_UX))) {
+ /* Access to at least one of the 64-bit segments has been disabled */
+ cpu_mips_tlb_flush(env, 1);
+ }
+#endif
+ if (env->CP0_Config3 & (1 << CP0C3_MT)) {
+ sync_c0_status(env, env, env->current_tc);
+ } else {
+ compute_hflags(env);
+ }
+}
+
+void cpu_mips_store_cause(CPUMIPSState *env, target_ulong val)
+{
+ uint32_t mask = 0x00C00300;
+ uint32_t old = env->CP0_Cause;
+ int i;
+
+ if (env->insn_flags & ISA_MIPS32R2) {
+ mask |= 1 << CP0Ca_DC;
+ }
+ if (env->insn_flags & ISA_MIPS32R6) {
+ mask &= ~((1 << CP0Ca_WP) & val);
+ }
+
+ env->CP0_Cause = (env->CP0_Cause & ~mask) | (val & mask);
+
+ if ((old ^ env->CP0_Cause) & (1 << CP0Ca_DC)) {
+ if (env->CP0_Cause & (1 << CP0Ca_DC)) {
+ cpu_mips_stop_count(env);
+ } else {
+ cpu_mips_start_count(env);
+ }
+ }
+
+ /* Set/reset software interrupts */
+ for (i = 0 ; i < 2 ; i++) {
+ if ((old ^ env->CP0_Cause) & (1 << (CP0Ca_IP + i))) {
+ cpu_mips_soft_irq(env, i, env->CP0_Cause & (1 << (CP0Ca_IP + i)));
+ }
+ }
+}
#endif
static void raise_mmu_exception(CPUMIPSState *env, target_ulong address,
--
1.8.3.1
next prev parent reply other threads:[~2016-05-19 11:19 UTC|newest]
Thread overview: 55+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-05-19 11:17 [Qemu-devel] [PULL 00/52] NEED_CPU_H cleanups Paolo Bonzini
2016-05-19 11:17 ` [Qemu-devel] [PULL 01/52] scripts: add script to build QEMU and analyze inclusions Paolo Bonzini
2016-05-19 11:17 ` [Qemu-devel] [PULL 02/52] s390x: move .needed functions for subsections to machine.c Paolo Bonzini
2016-05-19 11:17 ` [Qemu-devel] [PULL 03/52] include: move CPU-related definitions out of qemu-common.h Paolo Bonzini
2016-05-19 11:17 ` [Qemu-devel] [PULL 04/52] log: do not use CONFIG_USER_ONLY Paolo Bonzini
2016-05-19 11:17 ` [Qemu-devel] [PULL 05/52] cpu: make cpu-qom.h only include-able from cpu.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 06/52] target-alpha: make cpu-qom.h not target specific Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 07/52] target-arm: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 08/52] target-cris: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 09/52] target-i386: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 10/52] target-lm32: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 11/52] target-m68k: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 12/52] target-microblaze: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 13/52] target-mips: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 14/52] target-ppc: do not use target_ulong in cpu-qom.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 15/52] target-ppc: do not make PowerPCCPUClass depend on target-specific symbols Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 16/52] target-ppc: make cpu-qom.h not target specific Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 17/52] target-s390x: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 18/52] target-sh4: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 19/52] target-sparc: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 20/52] target-tricore: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 21/52] target-unicore32: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 22/52] target-xtensa: " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 23/52] arm: include cpu-qom.h in files that require ARMCPU Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 24/52] m68k: include cpu-qom.h in files that require M68KCPU Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 25/52] sh4: include cpu-qom.h in files that require SuperHCPU Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 26/52] alpha: include cpu-qom.h in files that require AlphaCPU Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 27/52] mips: use MIPSCPU instead of CPUMIPSState Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 28/52] ppc: use PowerPCCPU instead of CPUPPCState Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 29/52] arm: remove useless cpu.h inclusion Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 30/52] explicitly include qom/cpu.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 31/52] explicitly include hw/qdev-core.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 32/52] explicitly include linux/kvm.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 33/52] apic: move target-dependent definitions to cpu.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 34/52] include: poison symbols in osdep.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 35/52] hw: do not use VMSTATE_*TL Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 36/52] hw: move CPU state serialization to migration/cpu.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 37/52] hw: cannot include hw/hw.h from user emulation Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 38/52] cpu: move endian-dependent load/store functions to cpu-all.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 39/52] qemu-common: stop including qemu/bswap.h from qemu-common.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 40/52] qemu-common: stop including qemu/host-utils.h " Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 41/52] gdbstub: remove unnecessary includes from gdbstub-xml.c Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 42/52] dma: do not depend on kvm_enabled() Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 43/52] s390x: reorganize CSS bits between cpu.h and other headers Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 44/52] acpi: do not use TARGET_PAGE_SIZE Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 45/52] qemu-common: push cpu.h inclusion out of qemu-common.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 46/52] arm: move arm_log_exception into .c file Paolo Bonzini
2016-05-19 11:18 ` Paolo Bonzini [this message]
2016-05-19 11:18 ` [Qemu-devel] [PULL 48/52] hw: explicitly include qemu/log.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 49/52] exec: extract exec/tb-context.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 50/52] cpu: move exec-all.h inclusion out of cpu.h Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 51/52] hw: remove pio_addr_t Paolo Bonzini
2016-05-19 11:18 ` [Qemu-devel] [PULL 52/52] hw: clean up hw/hw.h includes Paolo Bonzini
2016-05-19 11:59 ` [Qemu-devel] [PULL 00/52] NEED_CPU_H cleanups Peter Maydell
2016-05-19 12:08 ` Paolo Bonzini
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1463656726-35952-48-git-send-email-pbonzini@redhat.com \
--to=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).