xref: /plan9-contrib/sys/src/cmd/gs/mips64.h (revision 75bd9d54e569af3ad5858ae09f19f6b23ee8bf6d)
1*75bd9d54SDavid du Colombier /* Parameters derived from machine and compiler architecture */
2*75bd9d54SDavid du Colombier 
3*75bd9d54SDavid du Colombier 	 /* ---------------- Scalar alignments ---------------- */
4*75bd9d54SDavid du Colombier 
5*75bd9d54SDavid du Colombier #define ARCH_ALIGN_SHORT_MOD 2
6*75bd9d54SDavid du Colombier #define ARCH_ALIGN_INT_MOD 4
7*75bd9d54SDavid du Colombier #define ARCH_ALIGN_LONG_MOD 4
8*75bd9d54SDavid du Colombier #define ARCH_ALIGN_PTR_MOD 8
9*75bd9d54SDavid du Colombier #define ARCH_ALIGN_FLOAT_MOD 4
10*75bd9d54SDavid du Colombier #define ARCH_ALIGN_DOUBLE_MOD 8
11*75bd9d54SDavid du Colombier #define ARCH_ALIGN_STRUCT_MOD 4
12*75bd9d54SDavid du Colombier 
13*75bd9d54SDavid du Colombier 	 /* ---------------- Scalar sizes ---------------- */
14*75bd9d54SDavid du Colombier 
15*75bd9d54SDavid du Colombier #define ARCH_LOG2_SIZEOF_SHORT 1
16*75bd9d54SDavid du Colombier #define ARCH_LOG2_SIZEOF_INT 2
17*75bd9d54SDavid du Colombier #define ARCH_LOG2_SIZEOF_LONG 2
18*75bd9d54SDavid du Colombier #define ARCH_LOG2_SIZEOF_LONG_LONG 3
19*75bd9d54SDavid du Colombier #define ARCH_SIZEOF_PTR 8
20*75bd9d54SDavid du Colombier #define ARCH_SIZEOF_FLOAT 4
21*75bd9d54SDavid du Colombier #define ARCH_SIZEOF_DOUBLE 8
22*75bd9d54SDavid du Colombier #define ARCH_FLOAT_MANTISSA_BITS 24
23*75bd9d54SDavid du Colombier #define ARCH_DOUBLE_MANTISSA_BITS 53
24*75bd9d54SDavid du Colombier 
25*75bd9d54SDavid du Colombier 	 /* ---------------- Unsigned max values ---------------- */
26*75bd9d54SDavid du Colombier 
27*75bd9d54SDavid du Colombier #define ARCH_MAX_UCHAR ((unsigned char)0xff + (unsigned char)0)
28*75bd9d54SDavid du Colombier #define ARCH_MAX_USHORT ((unsigned short)0xffff + (unsigned short)0)
29*75bd9d54SDavid du Colombier #define ARCH_MAX_UINT ((unsigned int)~0 + (unsigned int)0)
30*75bd9d54SDavid du Colombier #define ARCH_MAX_ULONG ((unsigned long)~0L + (unsigned long)0)
31*75bd9d54SDavid du Colombier 
32*75bd9d54SDavid du Colombier 	 /* ---------------- Cache sizes ---------------- */
33*75bd9d54SDavid du Colombier 
34*75bd9d54SDavid du Colombier #define ARCH_CACHE1_SIZE 4096
35*75bd9d54SDavid du Colombier #define ARCH_CACHE2_SIZE 524288
36*75bd9d54SDavid du Colombier 
37*75bd9d54SDavid du Colombier 	 /* ---------------- Miscellaneous ---------------- */
38*75bd9d54SDavid du Colombier 
39*75bd9d54SDavid du Colombier #define ARCH_IS_BIG_ENDIAN 1
40*75bd9d54SDavid du Colombier #define ARCH_PTRS_ARE_SIGNED 0
41*75bd9d54SDavid du Colombier #define ARCH_FLOATS_ARE_IEEE 1
42*75bd9d54SDavid du Colombier #define ARCH_ARITH_RSHIFT 2
43*75bd9d54SDavid du Colombier #define ARCH_CAN_SHIFT_FULL_LONG 0
44*75bd9d54SDavid du Colombier #define ARCH_DIV_NEG_POS_TRUNCATES 1
45