OpenBSD-4.6/usr.bin/pcc/mips/macdefs.h
/* $OpenBSD: macdefs.h,v 1.5 2008/04/11 20:45:52 stefan Exp $ */
/*
* Copyright (c) 2003 Anders Magnusson (ragge@ludd.luth.se).
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/*
* MIPS port by Jan Enoksson (janeno-1@student.ltu.se) and
* Simon Olsson (simols-1@student.ltu.se) 2005.
*/
/*
* Machine-dependent defines for both passes.
*/
#if TARGOS == netbsd
#define USE_GAS
#endif
/*
* Convert (multi-)character constant to integer.
* Assume: If only one value; store at left side (char size), otherwise
* treat it as an integer.
*/
#define makecc(val,i) lastcon = (lastcon<<8)|((val<<24)>>24);
#define ARGINIT (16*8) /* # bits above fp where arguments start */
#define AUTOINIT (0) /* # bits below fp where automatics start */
/*
* Storage space requirements
*/
#define SZCHAR 8
#define SZBOOL 32
#define SZINT 32
#define SZFLOAT 32
#define SZDOUBLE 64
#define SZLDOUBLE 64
#define SZLONG 32
#define SZSHORT 16
#define SZLONGLONG 64
#define SZPOINT(t) 32
/*
* Alignment constraints
*/
#define ALCHAR 8
#define ALBOOL 32
#define ALINT 32
#define ALFLOAT 32
#define ALDOUBLE 64
#define ALLDOUBLE 64
#define ALLONG 32
#define ALLONGLONG 64
#define ALSHORT 16
#define ALPOINT 32
#define ALSTRUCT 32
#define ALSTACK 64
/*
* Min/max values.
*/
#define MIN_CHAR -128
#define MAX_CHAR 127
#define MAX_UCHAR 255
#define MIN_SHORT -32768
#define MAX_SHORT 32767
#define MAX_USHORT 65535
#define MIN_INT -1
#define MAX_INT 0x7fffffff
#define MAX_UNSIGNED 0xffffffff
#define MIN_LONG MIN_INT
#define MAX_LONG MAX_INT
#define MAX_ULONG MAX_UNSIGNED
#define MIN_LONGLONG 0x8000000000000000LL
#define MAX_LONGLONG 0x7fffffffffffffffLL
#define MAX_ULONGLONG 0xffffffffffffffffULL
#undef CHAR_UNSIGNED
#define BOOL_TYPE INT
#define WCHAR_TYPE INT
/*
* Use large-enough types.
*/
typedef long long CONSZ;
typedef unsigned long long U_CONSZ;
typedef long long OFFSZ;
#define CONFMT "%lld" /* format for printing constants */
#ifdef USE_GAS
#define LABFMT "$L%d" /* format for printing labels */
#define STABLBL "$LL%d" /* format for stab (debugging) labels */
#else
#define LABFMT "L%d" /* format for printing labels */
#define STABLBL "LL%d" /* format for stab (debugging) labels */
#endif
#define BACKAUTO /* stack grows negatively for automatics */
#define BACKTEMP /* stack grows negatively for temporaries */
#undef FIELDOPS /* no bit-field instructions */
#define RTOLBYTES /* bytes are numbered right to left */
#define ENUMSIZE(high,low) INT /* enums are always stored in full int */
/* Definitions mostly used in pass2 */
#define BYTEOFF(x) ((x)&03)
#define BITOOR(x) (x) /* bit offset to oreg offset */
#define szty(t) (((t) == DOUBLE || (t) == FLOAT || \
(t) == LONGLONG || (t) == ULONGLONG) ? 2 : 1)
/*
* Register names. These must match rnames[] and rstatus[] in local2.c.
*/
#define ZERO 0
#define AT 1
#define V0 2
#define V1 3
#define A0 4
#define A1 5
#define A2 6
#define A3 7
#define A4 8
#define A5 9
#define A6 10
#define A7 11
#if defined(MIPS_N32) || defined(MIPS_N64)
#define T0 12
#define T1 13
#define T2 14
#define T3 15
#else
#define T0 8
#define T1 9
#define T2 10
#define T3 11
#endif
#define T4 12
#define T5 13
#define T6 14
#define T7 15
#define S0 16
#define S1 17
#define S2 18
#define S3 19
#define S4 20
#define S5 21
#define S6 22
#define S7 23
#define T8 24
#define T9 25
#define K0 26
#define K1 27
#define GP 28
#define SP 29
#define FP 30
#define RA 31
#define V0V1 32
#define A0A1 33
#define A1A2 34
#define A2A3 35
/* we just use o32 naming here, but it works ok for n32/n64 */
#define A3T0 36
#define T0T1 37
#define T1T2 38
#define T2T3 39
#define T3T4 40
#define T4T5 41
#define T5T6 42
#define T6T7 43
#define T7T8 44
#define T8T9 45
#define S0S1 46
#define S1S2 47
#define S2S3 48
#define S3S4 49
#define S4S5 50
#define S5S6 51
#define S6S7 52
#define F0 53
#define F2 54
#define F4 55
#define F6 56
#define F8 57
#define F10 58
#define F12 59
#define F14 60
#define F16 61
#define F18 62
#define F20 63
/* and the rest for later */
#define F22 64
#define F24 65
#define F26 66
#define F28 67
#define F30 68
#define MAXREGS 64
#define NUMCLASS 3
#define RETREG(x) (DEUNSIGN(x) == LONGLONG ? V0V1 : \
(x) == DOUBLE || (x) == LDOUBLE || (x) == FLOAT ? \
F0 : V0)
#define FPREG FP /* frame pointer */
#define MIPS_N32_NARGREGS 8
#define MIPS_O32_NARGREGS 4
#define RSTATUS \
0, 0, \
SAREG|TEMPREG, SAREG|TEMPREG, \
SAREG|TEMPREG, SAREG|TEMPREG, SAREG|TEMPREG, SAREG|TEMPREG, \
SAREG|TEMPREG, SAREG|TEMPREG, SAREG|TEMPREG, SAREG|TEMPREG, \
SAREG|TEMPREG, SAREG|TEMPREG, SAREG|TEMPREG, SAREG|TEMPREG, \
SAREG|PERMREG, SAREG|PERMREG, SAREG|PERMREG, SAREG|PERMREG, \
SAREG|PERMREG, SAREG|PERMREG, SAREG|PERMREG, SAREG|PERMREG, \
SAREG|TEMPREG, SAREG|TEMPREG, \
0, 0, \
0, 0, 0, 0, \
\
SBREG|TEMPREG, \
SBREG|TEMPREG, SBREG|TEMPREG, SBREG|TEMPREG, \
SBREG|TEMPREG, \
SBREG|TEMPREG, SBREG|TEMPREG, SBREG|TEMPREG, \
SBREG|TEMPREG, SBREG|TEMPREG, \
SBREG|TEMPREG, SBREG|TEMPREG, SBREG|TEMPREG, SBREG|TEMPREG, \
SBREG, SBREG, SBREG, SBREG, \
SBREG, SBREG, SBREG, \
SCREG, SCREG, SCREG, SCREG, \
SCREG, SCREG, SCREG, SCREG, \
SCREG, SCREG, SCREG, \
#define ROVERLAP \
{ -1 }, /* $zero */ \
{ -1 }, /* $at */ \
{ V0V1, -1 }, /* $v0 */ \
{ V0V1, -1 }, /* $v1 */ \
{ A0A1, -1 }, /* $a0 */ \
{ A0A1, A1A2, -1 }, /* $a1 */ \
{ A1A2, A2A3, -1 }, /* $a2 */ \
{ A2A3, A3T0, -1 }, /* $a3 */ \
{ A3T0, T0T1, -1 }, /* $t0 */ \
{ T0T1, T1T2, -1 }, /* $t1 */ \
{ T1T2, T2T3, -1 }, /* $t2 */ \
{ T2T3, T3T4, -1 }, /* $t3 */ \
{ T3T4, T4T5, -1 }, /* $t4 */ \
{ T4T5, T5T6, -1 }, /* $t5 */ \
{ T6T7, T7T8, -1 }, /* $t6 */ \
{ T7T8, T8T9, -1 }, /* $t7 */ \
\
{ S0S1, -1 }, /* $s0 */ \
{ S0S1, S1S2, -1 }, /* $s1 */ \
{ S1S2, S2S3, -1 }, /* $s2 */ \
{ S2S3, S3S4, -1 }, /* $s3 */ \
{ S3S4, S4S5, -1 }, /* $s4 */ \
{ S4S5, S5S6, -1 }, /* $s5 */ \
{ S5S6, S6S7, -1 }, /* $s6 */ \
{ S6S7, -1 }, /* $s7 */ \
\
{ T7T8, T8T9, -1 }, /* $t8 */ \
{ T8T9, -1 }, /* $t9 */ \
\
{ -1 }, /* $k0 */ \
{ -1 }, /* $k1 */ \
{ -1 }, /* $gp */ \
{ -1 }, /* $sp */ \
{ -1 }, /* $fp */ \
{ -1 }, /* $ra */ \
\
{ V0, V1, -1 }, /* $v0:$v1 */ \
\
{ A0, A1, A1A2, -1 }, /* $a0:$a1 */ \
{ A1, A2, A0A1, A2A3, -1 }, /* $a1:$a2 */ \
{ A2, A3, A1A2, A3T0, -1 }, /* $a2:$a3 */ \
{ A3, T0, A2A3, T0T1, -1 }, /* $a3:$t0 */ \
{ T0, T1, A3T0, T1T2, -1 }, /* $t0:$t1 */ \
{ T1, T2, T0T1, T2T3, -1 }, /* $t1:$t2 */ \
{ T2, T3, T1T2, T3T4, -1 }, /* $t2:$t3 */ \
{ T3, T4, T2T3, T4T5, -1 }, /* $t3:$t4 */ \
{ T4, T5, T3T4, T5T6, -1 }, /* $t4:$t5 */ \
{ T5, T6, T4T5, T6T7, -1 }, /* $t5:$t6 */ \
{ T6, T7, T5T6, T7T8, -1 }, /* $t6:$t7 */ \
{ T7, T8, T6T7, T8T9, -1 }, /* $t7:$t8 */ \
{ T8, T9, T7T8, -1 }, /* $t8:$t9 */ \
\
{ S0, S1, S1S2, -1 }, /* $s0:$s1 */ \
{ S1, S2, S0S1, S2S3, -1 }, \
{ S2, S3, S1S2, S3S4, -1 }, \
{ S3, S4, S2S3, S4S5, -1 }, \
{ S4, S5, S3S4, S5S6, -1 }, \
{ S5, S6, S4S5, S6S7, -1 }, \
{ S6, S7, S5S6, -1 }, \
\
{ -1 }, { -1 }, { -1 }, { -1 }, \
{ -1 }, { -1 }, { -1 }, { -1 }, \
{ -1 }, { -1 }, { -1 }, \
#define GCLASS(x) (x < 32 ? CLASSA : (x < 52 ? CLASSB : CLASSC))
#define PCLASS(p) (1 << gclass((p)->n_type))
#define DECRA(x,y) (((x) >> (y*6)) & 63) /* decode encoded regs */
#define ENCRA(x,y) ((x) << (6+y*6)) /* encode regs in int */
#define ENCRD(x) (x) /* Encode dest reg in n_reg */
int COLORMAP(int c, int *r);
extern int bigendian;
extern int nargregs;
#define SPCON (MAXSPECIAL+1) /* positive constant */
#define TARGET_STDARGS
#define TARGET_BUILTINS \
{ "__builtin_stdarg_start", mips_builtin_stdarg_start }, \
{ "__builtin_va_arg", mips_builtin_va_arg }, \
{ "__builtin_va_end", mips_builtin_va_end }, \
{ "__builtin_va_copy", mips_builtin_va_copy },
struct node;
struct node *mips_builtin_stdarg_start(struct node *f, struct node *a);
struct node *mips_builtin_va_arg(struct node *f, struct node *a);
struct node *mips_builtin_va_end(struct node *f, struct node *a);
struct node *mips_builtin_va_copy(struct node *f, struct node *a);