mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-05-01 04:10:18 +02:00
* include/lightning/jit_private.h: Add new register classes to flag float registers and double only registers, required for sparc64 where only low 32 bit fpr registers can be used for single precision operations. Add new 128 bit jit_regset_t type for sparc64 register set. * include/lightning/jit_sparc.h, lib/jit_sparc-cpu.c, lib/jit_sparc-fpu.c, lib/jit_sparc-sz.c, lib/jit_sparc.c: Update for 64 bits sparc. * lib/lightning.c: Update for new jit_regset_t required for sparc64.
102 lines
2.8 KiB
C
102 lines
2.8 KiB
C
/*
|
|
* Copyright (C) 2013-2017 Free Software Foundation, Inc.
|
|
*
|
|
* This file is part of GNU lightning.
|
|
*
|
|
* GNU lightning is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU Lesser General Public License as published
|
|
* by the Free Software Foundation; either version 3, or (at your option)
|
|
* any later version.
|
|
*
|
|
* GNU lightning is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
|
* License for more details.
|
|
*
|
|
* Authors:
|
|
* Paulo Cesar Pereira de Andrade
|
|
*/
|
|
|
|
#ifndef _jit_sparc_h
|
|
#define _jit_sparc_h
|
|
|
|
#define JIT_HASH_CONSTS 1
|
|
#define JIT_NUM_OPERANDS 3
|
|
|
|
/*
|
|
* Types
|
|
*/
|
|
#define JIT_FP _FP
|
|
typedef enum {
|
|
#define jit_r(i) (_G2 + (i))
|
|
#define jit_r_num() 3
|
|
#define jit_v(i) (_L0 + (i))
|
|
#define jit_v_num() 8
|
|
#if __WORDSIZE == 32
|
|
# define jit_f(i) (_F0 + ((i) << 1))
|
|
# define jit_f_num() 8
|
|
#else
|
|
# define jit_f(i) (_F32 - (i))
|
|
# define jit_f_num() 16
|
|
#endif
|
|
#define JIT_R0 _G2
|
|
#define JIT_R1 _G3
|
|
#define JIT_R2 _G4
|
|
#define JIT_V0 _L0
|
|
#define JIT_V1 _L1
|
|
#define JIT_V2 _L2
|
|
#define JIT_V3 _L3
|
|
#define JIT_V4 _L4
|
|
#define JIT_V5 _L5
|
|
#define JIT_V6 _L6
|
|
#define JIT_V7 _L7
|
|
_G0, _G1, _G2, _G3, _G4, _G5, _G6, _G7,
|
|
_O0, _O1, _O2, _O3, _O4, _O5, _SP, _O7,
|
|
_L0, _L1, _L2, _L3, _L4, _L5, _L6, _L7,
|
|
_I0, _I1, _I2, _I3, _I4, _I5, _FP, _I7,
|
|
#if __WORDSIZE == 32
|
|
# define JIT_F0 _F0
|
|
# define JIT_F1 _F2
|
|
# define JIT_F2 _F4
|
|
# define JIT_F3 _F6
|
|
# define JIT_F4 _F8
|
|
# define JIT_F5 _F10
|
|
# define JIT_F6 _F12
|
|
# define JIT_F7 _F14
|
|
_F0, _F1, _F2, _F3, _F4, _F5, _F6, _F7,
|
|
_F8, _F9, _F10, _F11, _F12, _F13, _F14, _F15,
|
|
#else
|
|
/* All single precision operations have a high cost due to being
|
|
* stored on registers only encodable as double precision.
|
|
* The cost is due to needing to move values to a register with
|
|
* value <= 31.
|
|
* This is a limitation due to using fixed named registers in
|
|
* lightning. */
|
|
# define JIT_F0 _F32
|
|
# define JIT_F1 _F34
|
|
# define JIT_F2 _F36
|
|
# define JIT_F3 _F38
|
|
# define JIT_F4 _F40
|
|
# define JIT_F5 _F42
|
|
# define JIT_F6 _F44
|
|
# define JIT_F7 _F46
|
|
# define JIT_F8 _F48
|
|
# define JIT_F9 _F50
|
|
# define JIT_F10 _F52
|
|
# define JIT_F11 _F54
|
|
# define JIT_F12 _F56
|
|
# define JIT_F13 _F58
|
|
# define JIT_F14 _F60
|
|
# define JIT_F15 _F62
|
|
_F62, _F60, _F58, _F56, _F54, _F52, _F50, _F48,
|
|
_F46, _F44, _F42, _F40, _F38, _F36, _F34, _F32,
|
|
_F31, _F30, _F29, _F28, _F27, _F26, _F25, _F24,
|
|
_F23, _F22, _F21, _F20, _F19, _F18, _F17, _F16,
|
|
_F15, _F14, _F13, _F12, _F11, _F10, _F9, _F8,
|
|
_F7, _F6, _F5, _F4, _F3, _F2, _F1, _F0,
|
|
#endif
|
|
#define JIT_NOREG _NOREG
|
|
_NOREG,
|
|
} jit_reg_t;
|
|
|
|
#endif /* _jit_sparc_h */
|