R0
R0(a,b,c,d,e, 0); R0(e,a,b,c,d, 1); R0(d,e,a,b,c, 2); R0(c,d,e,a,b, 3);
R0(b,c,d,e,a, 4); R0(a,b,c,d,e, 5); R0(e,a,b,c,d, 6); R0(d,e,a,b,c, 7);
R0(c,d,e,a,b, 8); R0(b,c,d,e,a, 9); R0(a,b,c,d,e,10); R0(e,a,b,c,d,11);
R0(d,e,a,b,c,12); R0(c,d,e,a,b,13); R0(b,c,d,e,a,14); R0(a,b,c,d,e,15);
R0(B, C, D, A, X(11), 19, 0);
R0(A, B, C, D, X(12), 3, 0);
R0(D, A, B, C, X(13), 7, 0);
R0(C, D, A, B, X(14), 11, 0);
R0(B, C, D, A, X(15), 19, 0);
R0(A, B, C, D, X(0), 3, 0);
R0(D, A, B, C, X(1), 7, 0);
R0(C, D, A, B, X(2), 11, 0);
R0(B, C, D, A, X(3), 19, 0);
R0(A, B, C, D, X(4), 3, 0);
R0(D, A, B, C, X(5), 7, 0);
R0(C, D, A, B, X(6), 11, 0);
R0(B, C, D, A, X(7), 19, 0);
R0(A, B, C, D, X(8), 3, 0);
R0(D, A, B, C, X(9), 7, 0);
R0(C, D, A, B, X(10), 11, 0);
R0(B, C, D, A, X(11), 22, 0x895cd7beL);
R0(A, B, C, D, X(12), 7, 0x6b901122L);
R0(D, A, B, C, X(13), 12, 0xfd987193L);
R0(C, D, A, B, X(14), 17, 0xa679438eL);
R0(B, C, D, A, X(15), 22, 0x49b40821L);
R0(A, B, C, D, X(0), 7, 0xd76aa478L);
R0(D, A, B, C, X(1), 12, 0xe8c7b756L);
R0(C, D, A, B, X(2), 17, 0x242070dbL);
R0(B, C, D, A, X(3), 22, 0xc1bdceeeL);
R0(A, B, C, D, X(4), 7, 0xf57c0fafL);
R0(D, A, B, C, X(5), 12, 0x4787c62aL);
R0(C, D, A, B, X(6), 17, 0xa8304613L);
R0(B, C, D, A, X(7), 22, 0xfd469501L);
R0(A, B, C, D, X(8), 7, 0x698098d8L);
R0(D, A, B, C, X(9), 12, 0x8b44f7afL);
R0(C, D, A, B, X(10), 17, 0xffff5bb1L);
_R64F0(cp15_cntpct_get, CP15_CNTPCT(%Q0, %R0))
_R64F0(cp15_cntvct_get, CP15_CNTVCT(%Q0, %R0))
_R64F0(cp15_cntp_cval_get, CP15_CNTP_CVAL(%Q0, %R0))
_W64F1(cp15_cntp_cval_set, CP15_CNTP_CVAL(%Q0, %R0))
_R64F0(cp15_cntv_cval_get, CP15_CNTV_CVAL(%Q0, %R0))
_W64F1(cp15_cntv_cval_set, CP15_CNTV_CVAL(%Q0, %R0))
_R64F0(cp15_cntvoff_get, CP15_CNTVOFF(%Q0, %R0))
_W64F1(cp15_cntvoff_set, CP15_CNTVOFF(%Q0, %R0))
_R64F0(cp15_cnthp_cval_get, CP15_CNTHP_CVAL(%Q0, %R0))
_W64F1(cp15_cnthp_cval_set, CP15_CNTHP_CVAL(%Q0, %R0))
#define REG_PS R0
#define REG_R0 R0