target/mips: rationalise softfloat includes
We should avoid including the whole of softfloat headers in cpu.h and explicitly include it only where we will be calling softfloat functions. We can use the -types.h in cpu.h for the few bits that are global. We also move the restore_snan_bit_mode into internal.h and include -helpers.h there. Signed-off-by: Alex Bennée <alex.bennee@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Reviewed-by: Aleksandar Markovic <amarkovic@wavecomp.com>
This commit is contained in:
parent
00f43279a3
commit
502700d067
@ -22,6 +22,7 @@
|
|||||||
#include "qemu.h"
|
#include "qemu.h"
|
||||||
#include "cpu_loop-common.h"
|
#include "cpu_loop-common.h"
|
||||||
#include "elf.h"
|
#include "elf.h"
|
||||||
|
#include "internal.h"
|
||||||
|
|
||||||
# ifdef TARGET_ABI_MIPSO32
|
# ifdef TARGET_ABI_MIPSO32
|
||||||
# define MIPS_SYS(name, args) args,
|
# define MIPS_SYS(name, args) args,
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
#include "cpu-qom.h"
|
#include "cpu-qom.h"
|
||||||
#include "exec/cpu-defs.h"
|
#include "exec/cpu-defs.h"
|
||||||
#include "fpu/softfloat.h"
|
#include "fpu/softfloat-types.h"
|
||||||
#include "mips-defs.h"
|
#include "mips-defs.h"
|
||||||
|
|
||||||
#define TCG_GUEST_DEFAULT_MO (0)
|
#define TCG_GUEST_DEFAULT_MO (0)
|
||||||
@ -1195,12 +1195,6 @@ void itc_reconfigure(struct MIPSITUState *tag);
|
|||||||
/* helper.c */
|
/* helper.c */
|
||||||
target_ulong exception_resume_pc(CPUMIPSState *env);
|
target_ulong exception_resume_pc(CPUMIPSState *env);
|
||||||
|
|
||||||
static inline void restore_snan_bit_mode(CPUMIPSState *env)
|
|
||||||
{
|
|
||||||
set_snan_bit_is_one((env->active_fpu.fcr31 & (1 << FCR31_NAN2008)) == 0,
|
|
||||||
&env->active_fpu.fp_status);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void cpu_get_tb_cpu_state(CPUMIPSState *env, target_ulong *pc,
|
static inline void cpu_get_tb_cpu_state(CPUMIPSState *env, target_ulong *pc,
|
||||||
target_ulong *cs_base, uint32_t *flags)
|
target_ulong *cs_base, uint32_t *flags)
|
||||||
{
|
{
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
#ifndef MIPS_INTERNAL_H
|
#ifndef MIPS_INTERNAL_H
|
||||||
#define MIPS_INTERNAL_H
|
#define MIPS_INTERNAL_H
|
||||||
|
|
||||||
|
#include "fpu/softfloat-helpers.h"
|
||||||
|
|
||||||
/* MMU types, the first four entries have the same layout as the
|
/* MMU types, the first four entries have the same layout as the
|
||||||
CP0C0_MT field. */
|
CP0C0_MT field. */
|
||||||
@ -226,6 +227,12 @@ static inline void restore_flush_mode(CPUMIPSState *env)
|
|||||||
&env->active_fpu.fp_status);
|
&env->active_fpu.fp_status);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void restore_snan_bit_mode(CPUMIPSState *env)
|
||||||
|
{
|
||||||
|
set_snan_bit_is_one((env->active_fpu.fcr31 & (1 << FCR31_NAN2008)) == 0,
|
||||||
|
&env->active_fpu.fp_status);
|
||||||
|
}
|
||||||
|
|
||||||
static inline void restore_fp_status(CPUMIPSState *env)
|
static inline void restore_fp_status(CPUMIPSState *env)
|
||||||
{
|
{
|
||||||
restore_rounding_mode(env);
|
restore_rounding_mode(env);
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
#include "exec/helper-proto.h"
|
#include "exec/helper-proto.h"
|
||||||
|
#include "fpu/softfloat.h"
|
||||||
|
|
||||||
/* Data format min and max values */
|
/* Data format min and max values */
|
||||||
#define DF_BITS(df) (1 << ((df) + 3))
|
#define DF_BITS(df) (1 << ((df) + 3))
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#include "exec/exec-all.h"
|
#include "exec/exec-all.h"
|
||||||
#include "exec/cpu_ldst.h"
|
#include "exec/cpu_ldst.h"
|
||||||
#include "sysemu/kvm.h"
|
#include "sysemu/kvm.h"
|
||||||
|
#include "fpu/softfloat.h"
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
/* Exceptions processing helpers */
|
/* Exceptions processing helpers */
|
||||||
|
Loading…
Reference in New Issue
Block a user