Home | History | Annotate | Download | only in sparc
      1 /*
      2  * SPARC assembly matrix code.
      3  */
      4 
      5 #ifndef _SPARC_MATRIX_H
      6 #define _SPARC_MATRIX_H
      7 
      8 #ifdef __arch64__
      9 #define LDPTR		ldx
     10 #define MAT_M		0x00
     11 #define MAT_INV		0x08
     12 #define V4F_DATA	0x00
     13 #define V4F_START	0x08
     14 #define V4F_COUNT	0x10
     15 #define V4F_STRIDE	0x14
     16 #define V4F_SIZE	0x18
     17 #define V4F_FLAGS	0x1c
     18 #else
     19 #define LDPTR		ld
     20 #define MAT_M		0x00
     21 #define MAT_INV		0x04
     22 #define V4F_DATA	0x00
     23 #define V4F_START	0x04
     24 #define V4F_COUNT	0x08
     25 #define V4F_STRIDE	0x0c
     26 #define V4F_SIZE	0x10
     27 #define V4F_FLAGS	0x14
     28 #endif
     29 
     30 #define VEC_SIZE_1   	1
     31 #define VEC_SIZE_2   	3
     32 #define VEC_SIZE_3   	7
     33 #define VEC_SIZE_4   	15
     34 
     35 #define M0		%f16
     36 #define M1		%f17
     37 #define M2		%f18
     38 #define M3		%f19
     39 #define M4		%f20
     40 #define M5		%f21
     41 #define M6		%f22
     42 #define M7		%f23
     43 #define M8		%f24
     44 #define M9		%f25
     45 #define M10		%f26
     46 #define M11		%f27
     47 #define M12		%f28
     48 #define M13		%f29
     49 #define M14		%f30
     50 #define M15		%f31
     51 
     52 #define LDMATRIX_0_1_2_3_12_13_14_15(BASE)	\
     53 	ldd	[BASE + ( 0 * 0x4)], M0;	\
     54 	ldd	[BASE + ( 2 * 0x4)], M2;	\
     55 	ldd	[BASE + (12 * 0x4)], M12;	\
     56 	ldd	[BASE + (14 * 0x4)], M14
     57 
     58 #define LDMATRIX_0_1_12_13(BASE)		\
     59 	ldd	[BASE + ( 0 * 0x4)], M0;	\
     60 	ldd	[BASE + (12 * 0x4)], M12
     61 
     62 #define LDMATRIX_0_12_13(BASE)			\
     63 	ld	[BASE + ( 0 * 0x4)], M0;	\
     64 	ldd	[BASE + (12 * 0x4)], M12
     65 
     66 #define LDMATRIX_0_1_2_12_13_14(BASE)		\
     67 	ldd	[BASE + ( 0 * 0x4)], M0;	\
     68 	ld	[BASE + ( 2 * 0x4)], M2;	\
     69 	ldd	[BASE + (12 * 0x4)], M12;	\
     70 	ld	[BASE + (14 * 0x4)], M14
     71 
     72 #define LDMATRIX_0_12_13_14(BASE)		\
     73 	ld	[BASE + ( 0 * 0x4)], M0;	\
     74 	ldd	[BASE + (12 * 0x4)], M12;	\
     75 	ld	[BASE + (14 * 0x4)], M14
     76 
     77 #define LDMATRIX_0_14(BASE)			\
     78 	ld	[BASE + ( 0 * 0x4)], M0;	\
     79 	ld	[BASE + (14 * 0x4)], M14
     80 
     81 #define LDMATRIX_0_1_2_3_4_5_6_7_12_13_14_15(BASE) \
     82 	ldd	[BASE + ( 0 * 0x4)], M0;	\
     83 	ldd	[BASE + ( 2 * 0x4)], M2;	\
     84 	ldd	[BASE + ( 4 * 0x4)], M4;	\
     85 	ldd	[BASE + ( 6 * 0x4)], M6;	\
     86 	ldd	[BASE + (12 * 0x4)], M12;	\
     87 	ldd	[BASE + (14 * 0x4)], M14
     88 
     89 #define LDMATRIX_0_5_12_13(BASE) 		\
     90 	ld	[BASE + ( 0 * 0x4)], M0;	\
     91 	ld	[BASE + ( 5 * 0x4)], M5;	\
     92 	ldd	[BASE + (12 * 0x4)], M12
     93 
     94 #define LDMATRIX_0_1_2_3_4_5_6_12_13_14(BASE)	\
     95 	ldd	[BASE + ( 0 * 0x4)], M0;	\
     96 	ldd	[BASE + ( 2 * 0x4)], M2;	\
     97 	ldd	[BASE + ( 4 * 0x4)], M4;	\
     98 	ld	[BASE + ( 6 * 0x4)], M6;	\
     99 	ldd	[BASE + (12 * 0x4)], M12;	\
    100 	ld	[BASE + (14 * 0x4)], M14
    101 
    102 #define LDMATRIX_0_5_12_13_14(BASE)		\
    103 	ld	[BASE + ( 0 * 0x4)], M0;	\
    104 	ld	[BASE + ( 5 * 0x4)], M5;	\
    105 	ldd	[BASE + (12 * 0x4)], M12;	\
    106 	ld	[BASE + (14 * 0x4)], M14
    107 
    108 #define LDMATRIX_0_5_14(BASE)			\
    109 	ld	[BASE + ( 0 * 0x4)], M0;	\
    110 	ld	[BASE + ( 5 * 0x4)], M5;	\
    111 	ld	[BASE + (14 * 0x4)], M14
    112 
    113 #define LDMATRIX_0_1_2_3_4_5_6_7_8_9_10_11_12_13_14_15(BASE) \
    114 	ldd	[BASE + ( 0 * 0x4)], M0;	\
    115 	ldd	[BASE + ( 2 * 0x4)], M2;	\
    116 	ldd	[BASE + ( 4 * 0x4)], M4;	\
    117 	ldd	[BASE + ( 6 * 0x4)], M6;	\
    118 	ldd	[BASE + ( 8 * 0x4)], M8;	\
    119 	ldd	[BASE + (10 * 0x4)], M10;	\
    120 	ldd	[BASE + (12 * 0x4)], M12;	\
    121 	ldd	[BASE + (14 * 0x4)], M14
    122 
    123 #define LDMATRIX_0_1_4_5_12_13(BASE) 		\
    124 	ldd	[BASE + ( 0 * 0x4)], M0;	\
    125 	ldd	[BASE + ( 4 * 0x4)], M4;	\
    126 	ldd	[BASE + (12 * 0x4)], M12
    127 
    128 #define LDMATRIX_0_5_12_13(BASE) 		\
    129 	ld	[BASE + ( 0 * 0x4)], M0;	\
    130 	ld	[BASE + ( 5 * 0x4)], M5;	\
    131 	ldd	[BASE + (12 * 0x4)], M12
    132 
    133 #define LDMATRIX_0_1_2_4_5_6_8_9_10(BASE) \
    134 	ldd	[BASE + ( 0 * 0x4)], M0;	\
    135 	ld	[BASE + ( 2 * 0x4)], M2;	\
    136 	ldd	[BASE + ( 4 * 0x4)], M4;	\
    137 	ld	[BASE + ( 6 * 0x4)], M6;	\
    138 	ldd	[BASE + ( 8 * 0x4)], M8;	\
    139 	ld	[BASE + (10 * 0x4)], M10
    140 
    141 #define LDMATRIX_0_1_2_4_5_6_8_9_10_12_13_14(BASE) \
    142 	ldd	[BASE + ( 0 * 0x4)], M0;	\
    143 	ld	[BASE + ( 2 * 0x4)], M2;	\
    144 	ldd	[BASE + ( 4 * 0x4)], M4;	\
    145 	ld	[BASE + ( 6 * 0x4)], M6;	\
    146 	ldd	[BASE + ( 8 * 0x4)], M8;	\
    147 	ld	[BASE + (10 * 0x4)], M10;	\
    148 	ldd	[BASE + (12 * 0x4)], M12;	\
    149 	ld	[BASE + (14 * 0x4)], M14
    150 
    151 #define LDMATRIX_0_5_10(BASE) 			\
    152 	ld	[BASE + ( 0 * 0x4)], M0;	\
    153 	ld	[BASE + ( 5 * 0x4)], M5;	\
    154 	ld	[BASE + (10 * 0x4)], M10;
    155 
    156 #define LDMATRIX_0_5_10_12_13_14(BASE) 		\
    157 	ld	[BASE + ( 0 * 0x4)], M0;	\
    158 	ld	[BASE + ( 5 * 0x4)], M5;	\
    159 	ld	[BASE + (10 * 0x4)], M10;	\
    160 	ldd	[BASE + (12 * 0x4)], M12;	\
    161 	ld	[BASE + (14 * 0x4)], M14
    162 
    163 #define LDMATRIX_0_5_8_9_10_14(BASE) 		\
    164 	ld	[BASE + ( 0 * 0x4)], M0;	\
    165 	ld	[BASE + ( 5 * 0x4)], M5;	\
    166 	ldd	[BASE + ( 8 * 0x4)], M8;	\
    167 	ld	[BASE + (10 * 0x4)], M10;	\
    168 	ld	[BASE + (14 * 0x4)], M14
    169 
    170 #endif /* !(_SPARC_MATRIX_H) */
    171