Commit 87d2857b authored by Matthew Wilcox's avatar Matthew Wilcox Committed by Linus Torvalds

[PATCH] parisc: arch/parisc/kernel/perf_asm.S

Indentation and comment cleanup
Committed-by: default avatarGrant Grundler <grundler@parisc-linux.org>
parent 0a0582d8
/* low-level asm for "intrigue" (PA8500-8700 CPU perf counters) /* low-level asm for "intrigue" (PA8500-8700 CPU perf counters)
* *
* Copyright (C) 2001 Randolph Chung <tausq at parisc-linux.org> * Copyright (C) 2001 Randolph Chung <tausq at parisc-linux.org>
* * Copyright (C) 2001 Hewlett-Packard (Grant Grundler)
*
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
...@@ -48,7 +49,7 @@ perf_intrigue_enable_perf_counters: ...@@ -48,7 +49,7 @@ perf_intrigue_enable_perf_counters:
.proc .proc
.callinfo frame=0,NO_CALLS .callinfo frame=0,NO_CALLS
.entry .entry
ldi 0x20,%r25 ; load up perfmon bit ldi 0x20,%r25 ; load up perfmon bit
mfctl ccr,%r26 ; get coprocessor register mfctl ccr,%r26 ; get coprocessor register
or %r25,%r26,%r26 ; set bit or %r25,%r26,%r26 ; set bit
...@@ -87,35 +88,35 @@ perf_intrigue_disable_perf_counters: ...@@ -87,35 +88,35 @@ perf_intrigue_disable_perf_counters:
.exit .exit
.procend .procend
;************************************************************************ ;***********************************************************************
;* * ;*
;* Name: perf_rdr_shift_in_W * ;* Name: perf_rdr_shift_in_W
;* * ;*
;* Description: * ;* Description:
;* This routine shifts data in from the RDR in arg0 and returns * ;* This routine shifts data in from the RDR in arg0 and returns
;* the result in ret0. If the RDR is <= 64 bits in length, it * ;* the result in ret0. If the RDR is <= 64 bits in length, it
;* is shifted shifted backup immediately. This is to compensate * ;* is shifted shifted backup immediately. This is to compensate
;* for RDR10 which has bits that preclude PDC stack operations * ;* for RDR10 which has bits that preclude PDC stack operations
;* when they are in the wrong state. * ;* when they are in the wrong state.
;* * ;*
;* Arguments: * ;* Arguments:
;* arg0 : rdr to be read * ;* arg0 : rdr to be read
;* arg1 : bit length of rdr * ;* arg1 : bit length of rdr
;* * ;*
;* Returns: * ;* Returns:
;* ret0 = next 64 bits of rdr data from staging register * ;* ret0 = next 64 bits of rdr data from staging register
;* * ;*
;* Register usage: * ;* Register usage:
;* arg0 : rdr to be read * ;* arg0 : rdr to be read
;* arg1 : bit length of rdr * ;* arg1 : bit length of rdr
;* %r24 - original DR2 value * ;* %r24 - original DR2 value
;* %r1 - scratch * ;* %r1 - scratch
;* %r29 - scratch * ;* %r29 - scratch
;* * ;*
;* Returns: * ;* Returns:
;* ret0 = RDR data (right justified) * ;* ret0 = RDR data (right justified)
;* * ;*
;************************************************************************ ;***********************************************************************
.export perf_rdr_shift_in_W,code .export perf_rdr_shift_in_W,code
perf_rdr_shift_in_W: perf_rdr_shift_in_W:
...@@ -138,7 +139,7 @@ perf_rdr_shift_in_W: ...@@ -138,7 +139,7 @@ perf_rdr_shift_in_W:
nop nop
nop nop
nop nop
nop nop
; ;
; Cacheline start (32-byte cacheline) ; Cacheline start (32-byte cacheline)
...@@ -146,11 +147,11 @@ perf_rdr_shift_in_W: ...@@ -146,11 +147,11 @@ perf_rdr_shift_in_W:
nop nop
nop nop
nop nop
extrd,u arg1,63,6,%r1 ; setup shift amount based on bits to move extrd,u arg1,63,6,%r1 ; setup shift amount by bits to move
mtsar %r1 mtsar %r1
shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number
blr %r1,%r0 ; branch to 8-instruction sequence blr %r1,%r0 ; branch to 8-instruction sequence
nop nop
; ;
...@@ -160,19 +161,19 @@ perf_rdr_shift_in_W: ...@@ -160,19 +161,19 @@ perf_rdr_shift_in_W:
; ;
; RDR 0 sequence ; RDR 0 sequence
; ;
SFDIAG (0) SFDIAG (0)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) ; mtdiag %dr1, %r1 MTDIAG_1 (1) ; mtdiag %dr1, %r1
STDIAG (0) STDIAG (0)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 1 sequence ; RDR 1 sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (1) SFDIAG (1)
ssm 0,0 ssm 0,0
...@@ -180,11 +181,11 @@ perf_rdr_shift_in_W: ...@@ -180,11 +181,11 @@ perf_rdr_shift_in_W:
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
nop nop
; ;
; RDR 2 read sequence ; RDR 2 read sequence
; ;
SFDIAG (2) SFDIAG (2)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
...@@ -192,7 +193,7 @@ perf_rdr_shift_in_W: ...@@ -192,7 +193,7 @@ perf_rdr_shift_in_W:
STDIAG (2) STDIAG (2)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 3 read sequence ; RDR 3 read sequence
; ;
...@@ -208,39 +209,39 @@ perf_rdr_shift_in_W: ...@@ -208,39 +209,39 @@ perf_rdr_shift_in_W:
; ;
; RDR 4 read sequence ; RDR 4 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (4) SFDIAG (4)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 5 read sequence ; RDR 5 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (5) SFDIAG (5)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 6 read sequence ; RDR 6 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (6) SFDIAG (6)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 7 read sequence ; RDR 7 read sequence
; ;
...@@ -281,26 +282,26 @@ perf_rdr_shift_in_W: ...@@ -281,26 +282,26 @@ perf_rdr_shift_in_W:
; RDR 10 read sequence ; RDR 10 read sequence
; ;
SFDIAG (10) SFDIAG (10)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (10) STDIAG (10)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 11 read sequence ; RDR 11 read sequence
; ;
SFDIAG (11) SFDIAG (11)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (11) STDIAG (11)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 12 read sequence ; RDR 12 read sequence
; ;
...@@ -317,77 +318,77 @@ perf_rdr_shift_in_W: ...@@ -317,77 +318,77 @@ perf_rdr_shift_in_W:
; RDR 13 read sequence ; RDR 13 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (13) SFDIAG (13)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 14 read sequence ; RDR 14 read sequence
; ;
SFDIAG (14) SFDIAG (14)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (14) STDIAG (14)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 15 read sequence ; RDR 15 read sequence
; ;
sync ; RDR 15 read sequence sync
ssm 0,0 ssm 0,0
SFDIAG (15) SFDIAG (15)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
nop nop
; ;
; RDR 16 read sequence ; RDR 16 read sequence
; ;
sync ; RDR 16 read sequence sync
ssm 0,0 ssm 0,0
SFDIAG (16) SFDIAG (16)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 17 read sequence ; RDR 17 read sequence
; ;
SFDIAG (17) SFDIAG (17)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (17) STDIAG (17)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 18 read sequence ; RDR 18 read sequence
; ;
SFDIAG (18) SFDIAG (18)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (18) STDIAG (18)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 19 read sequence ; RDR 19 read sequence
; ;
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
nop nop
nop nop
...@@ -401,144 +402,144 @@ perf_rdr_shift_in_W: ...@@ -401,144 +402,144 @@ perf_rdr_shift_in_W:
; RDR 20 read sequence ; RDR 20 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (20) SFDIAG (20)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 21 read sequence ; RDR 21 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (21) SFDIAG (21)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 22 read sequence ; RDR 22 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (22) SFDIAG (22)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 23 read sequence ; RDR 23 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (23) SFDIAG (23)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 24 read sequence ; RDR 24 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (24) SFDIAG (24)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 25 read sequence ; RDR 25 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (25) SFDIAG (25)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 26 read sequence ; RDR 26 read sequence
; ;
SFDIAG (26) SFDIAG (26)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (26) STDIAG (26)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 27 read sequence ; RDR 27 read sequence
; ;
SFDIAG (27) SFDIAG (27)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (27) STDIAG (27)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 28 read sequence ; RDR 28 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (28) SFDIAG (28)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 29 read sequence ; RDR 29 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (29) SFDIAG (29)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
ssm 0,0 ssm 0,0
nop nop
; ;
; RDR 30 read sequence ; RDR 30 read sequence
; ;
SFDIAG (30) SFDIAG (30)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (30) STDIAG (30)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_W_leave b,n perf_rdr_shift_in_W_leave
; ;
; RDR 31 read sequence ; RDR 31 read sequence
; ;
sync sync
ssm 0,0 ssm 0,0
SFDIAG (31) SFDIAG (31)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
nop nop
ssm 0,0 ssm 0,0
nop nop
; ;
...@@ -552,28 +553,28 @@ perf_rdr_shift_in_W_leave: ...@@ -552,28 +553,28 @@ perf_rdr_shift_in_W_leave:
.procend .procend
;************************************************************************ ;***********************************************************************
;* * ;*
;* Name: perf_rdr_shift_out_W * ;* Name: perf_rdr_shift_out_W
;* * ;*
;* Description: * ;* Description:
;* This routine moves data to the RDR's. The double-word that * ;* This routine moves data to the RDR's. The double-word that
;* arg1 points to is loaded and moved into the staging register. * ;* arg1 points to is loaded and moved into the staging register.
;* Then the STDIAG instruction for the RDR # in arg0 is called * ;* Then the STDIAG instruction for the RDR # in arg0 is called
;* to move the data to the RDR. * ;* to move the data to the RDR.
;* * ;*
;* Arguments: * ;* Arguments:
;* arg0 = rdr number * ;* arg0 = rdr number
;* arg1 = 64-bit value to write * ;* arg1 = 64-bit value to write
;* %r24 - DR2 | DR2_SLOW_RET * ;* %r24 - DR2 | DR2_SLOW_RET
;* %r23 - original DR2 value * ;* %r23 - original DR2 value
;* * ;*
;* Returns: * ;* Returns:
;* None * ;* None
;* * ;*
;* Register usage: * ;* Register usage:
;* * ;*
;************************************************************************ ;***********************************************************************
.export perf_rdr_shift_out_W,code .export perf_rdr_shift_out_W,code
perf_rdr_shift_out_W: perf_rdr_shift_out_W:
...@@ -587,24 +588,23 @@ perf_rdr_shift_out_W: ...@@ -587,24 +588,23 @@ perf_rdr_shift_out_W:
depdi,z 1,DR2_SLOW_RET,1,%r24 depdi,z 1,DR2_SLOW_RET,1,%r24
MFDIAG_2 (23) MFDIAG_2 (23)
or %r24,%r23,%r24 or %r24,%r23,%r24
MTDIAG_2 (24) ; set DR2_SLOW_RET MTDIAG_2 (24) ; set DR2_SLOW_RET
MTDIAG_1 (25) ; data to the staging register
MTDIAG_1 (25) ; data to the staging register
shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number
blr %r1,%r0 ; branch to 8-instruction sequence blr %r1,%r0 ; branch to 8-instruction sequence
nop nop
; ;
; RDR 0 write sequence ; RDR 0 write sequence
; ;
sync ; RDR 0 write sequence sync ; RDR 0 write sequence
ssm 0,0 ssm 0,0
STDIAG (0) STDIAG (0)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_W_leave b,n perf_rdr_shift_out_W_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
; ;
...@@ -718,7 +718,7 @@ perf_rdr_shift_out_W: ...@@ -718,7 +718,7 @@ perf_rdr_shift_out_W:
; ;
; RDR 10 write sequence ; RDR 10 write sequence
; ;
sync sync
ssm 0,0 ssm 0,0
STDIAG (10) STDIAG (10)
STDIAG (26) STDIAG (26)
...@@ -862,7 +862,7 @@ perf_rdr_shift_out_W: ...@@ -862,7 +862,7 @@ perf_rdr_shift_out_W:
; ;
; RDR 22 write sequence ; RDR 22 write sequence
; ;
sync sync
ssm 0,0 ssm 0,0
STDIAG (22) STDIAG (22)
ssm 0,0 ssm 0,0
...@@ -910,7 +910,7 @@ perf_rdr_shift_out_W: ...@@ -910,7 +910,7 @@ perf_rdr_shift_out_W:
; ;
; RDR 26 write sequence ; RDR 26 write sequence
; ;
sync sync
ssm 0,0 ssm 0,0
STDIAG (10) STDIAG (10)
STDIAG (26) STDIAG (26)
...@@ -958,7 +958,7 @@ perf_rdr_shift_out_W: ...@@ -958,7 +958,7 @@ perf_rdr_shift_out_W:
; ;
; RDR 30 write sequence ; RDR 30 write sequence
; ;
sync sync
ssm 0,0 ssm 0,0
STDIAG (30) STDIAG (30)
ssm 0,0 ssm 0,0
...@@ -970,7 +970,7 @@ perf_rdr_shift_out_W: ...@@ -970,7 +970,7 @@ perf_rdr_shift_out_W:
; ;
; RDR 31 write sequence ; RDR 31 write sequence
; ;
sync sync
ssm 0,0 ssm 0,0
STDIAG (31) STDIAG (31)
ssm 0,0 ssm 0,0
...@@ -986,34 +986,32 @@ perf_rdr_shift_out_W_leave: ...@@ -986,34 +986,32 @@ perf_rdr_shift_out_W_leave:
.procend .procend
;**************************** CHRIS *********************************** ;***********************************************************************
;*
;************************************************************************ ;* Name: rdr_shift_in_U
;* * ;*
;* Name: rdr_shift_in_U * ;* Description:
;* * ;* This routine shifts data in from the RDR in arg0 and returns
;* Description: * ;* the result in ret0. If the RDR is <= 64 bits in length, it
;* This routine shifts data in from the RDR in arg0 and returns * ;* is shifted shifted backup immediately. This is to compensate
;* the result in ret0. If the RDR is <= 64 bits in length, it * ;* for RDR10 which has bits that preclude PDC stack operations
;* is shifted shifted backup immediately. This is to compensate * ;* when they are in the wrong state.
;* for RDR10 which has bits that preclude PDC stack operations * ;*
;* when they are in the wrong state. * ;* Arguments:
;* * ;* arg0 : rdr to be read
;* Arguments: * ;* arg1 : bit length of rdr
;* arg0 : rdr to be read * ;*
;* arg1 : bit length of rdr * ;* Returns:
;* * ;* ret0 = next 64 bits of rdr data from staging register
;* Returns: * ;*
;* ret0 = next 64 bits of rdr data from staging register * ;* Register usage:
;* * ;* arg0 : rdr to be read
;* Register usage: * ;* arg1 : bit length of rdr
;* arg0 : rdr to be read * ;* %r24 - original DR2 value
;* arg1 : bit length of rdr * ;* %r23 - DR2 | DR2_SLOW_RET
;* %r24 - original DR2 value * ;* %r1 - scratch
;* %r23 - DR2 | DR2_SLOW_RET * ;*
;* %r1 - scratch * ;***********************************************************************
;* *
;************************************************************************
.export perf_rdr_shift_in_U,code .export perf_rdr_shift_in_U,code
perf_rdr_shift_in_U: perf_rdr_shift_in_U:
...@@ -1053,75 +1051,75 @@ perf_rdr_shift_in_U: ...@@ -1053,75 +1051,75 @@ perf_rdr_shift_in_U:
; Start of next 32-byte cacheline ; Start of next 32-byte cacheline
; ;
SFDIAG (0) ; RDR 0 read sequence SFDIAG (0) ; RDR 0 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (0) STDIAG (0)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (1) ; RDR 1 read sequence SFDIAG (1) ; RDR 1 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (1) STDIAG (1)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
sync ; RDR 2 read sequence sync ; RDR 2 read sequence
ssm 0,0 ssm 0,0
SFDIAG (4) SFDIAG (4)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 3 read sequence sync ; RDR 3 read sequence
ssm 0,0 ssm 0,0
SFDIAG (3) SFDIAG (3)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 4 read sequence sync ; RDR 4 read sequence
ssm 0,0 ssm 0,0
SFDIAG (4) SFDIAG (4)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 5 read sequence sync ; RDR 5 read sequence
ssm 0,0 ssm 0,0
SFDIAG (5) SFDIAG (5)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 6 read sequence sync ; RDR 6 read sequence
ssm 0,0 ssm 0,0
SFDIAG (6) SFDIAG (6)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 7 read sequence sync ; RDR 7 read sequence
ssm 0,0 ssm 0,0
SFDIAG (7) SFDIAG (7)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
...@@ -1134,95 +1132,95 @@ perf_rdr_shift_in_U: ...@@ -1134,95 +1132,95 @@ perf_rdr_shift_in_U:
nop nop
SFDIAG (9) ; RDR 9 read sequence SFDIAG (9) ; RDR 9 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (9) STDIAG (9)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (10) ; RDR 10 read sequence SFDIAG (10) ; RDR 10 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (10) STDIAG (10)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (11) ; RDR 11 read sequence SFDIAG (11) ; RDR 11 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (11) STDIAG (11)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (12) ; RDR 12 read sequence SFDIAG (12) ; RDR 12 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (12) STDIAG (12)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (13) ; RDR 13 read sequence SFDIAG (13) ; RDR 13 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (13) STDIAG (13)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (14) ; RDR 14 read sequence SFDIAG (14) ; RDR 14 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (14) STDIAG (14)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (15) ; RDR 15 read sequence SFDIAG (15) ; RDR 15 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (15) STDIAG (15)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
sync ; RDR 16 read sequence sync ; RDR 16 read sequence
ssm 0,0 ssm 0,0
SFDIAG (16) SFDIAG (16)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
SFDIAG (17) ; RDR 17 read sequence SFDIAG (17) ; RDR 17 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (17) STDIAG (17)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (18) ; RDR 18 read sequence SFDIAG (18) ; RDR 18 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (18) STDIAG (18)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
nop nop
nop nop
...@@ -1233,86 +1231,86 @@ perf_rdr_shift_in_U: ...@@ -1233,86 +1231,86 @@ perf_rdr_shift_in_U:
nop nop
sync ; RDR 20 read sequence sync ; RDR 20 read sequence
ssm 0,0 ssm 0,0
SFDIAG (20) SFDIAG (20)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 21 read sequence sync ; RDR 21 read sequence
ssm 0,0 ssm 0,0
SFDIAG (21) SFDIAG (21)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 22 read sequence sync ; RDR 22 read sequence
ssm 0,0 ssm 0,0
SFDIAG (22) SFDIAG (22)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 23 read sequence sync ; RDR 23 read sequence
ssm 0,0 ssm 0,0
SFDIAG (23) SFDIAG (23)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 24 read sequence sync ; RDR 24 read sequence
ssm 0,0 ssm 0,0
SFDIAG (24) SFDIAG (24)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 25 read sequence sync ; RDR 25 read sequence
ssm 0,0 ssm 0,0
SFDIAG (25) SFDIAG (25)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
SFDIAG (26) ; RDR 26 read sequence SFDIAG (26) ; RDR 26 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (26) STDIAG (26)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (27) ; RDR 27 read sequence SFDIAG (27) ; RDR 27 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (27) STDIAG (27)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
sync ; RDR 28 read sequence sync ; RDR 28 read sequence
ssm 0,0 ssm 0,0
SFDIAG (28) SFDIAG (28)
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
ssm 0,0 ssm 0,0
nop nop
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
nop nop
nop nop
...@@ -1321,23 +1319,23 @@ perf_rdr_shift_in_U: ...@@ -1321,23 +1319,23 @@ perf_rdr_shift_in_U:
nop nop
nop nop
nop nop
SFDIAG (30) ; RDR 30 read sequence SFDIAG (30) ; RDR 30 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (30) STDIAG (30)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
SFDIAG (31) ; RDR 31 read sequence SFDIAG (31) ; RDR 31 read sequence
ssm 0,0 ssm 0,0
MFDIAG_1 (28) MFDIAG_1 (28)
shrpd ret0,%r0,%sar,%r1 shrpd ret0,%r0,%sar,%r1
MTDIAG_1 (1) MTDIAG_1 (1)
STDIAG (31) STDIAG (31)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_in_U_leave b,n perf_rdr_shift_in_U_leave
nop nop
...@@ -1347,30 +1345,30 @@ perf_rdr_shift_in_U_leave: ...@@ -1347,30 +1345,30 @@ perf_rdr_shift_in_U_leave:
MTDIAG_2 (24) ; restore DR2 MTDIAG_2 (24) ; restore DR2
.procend .procend
;************************************************************************ ;***********************************************************************
;* * ;*
;* Name: rdr_shift_out_U * ;* Name: rdr_shift_out_U
;* * ;*
;* Description: * ;* Description:
;* This routine moves data to the RDR's. The double-word that * ;* This routine moves data to the RDR's. The double-word that
;* arg1 points to is loaded and moved into the staging register. * ;* arg1 points to is loaded and moved into the staging register.
;* Then the STDIAG instruction for the RDR # in arg0 is called * ;* Then the STDIAG instruction for the RDR # in arg0 is called
;* to move the data to the RDR. * ;* to move the data to the RDR.
;* * ;*
;* Arguments: * ;* Arguments:
;* arg0 = rdr target * ;* arg0 = rdr target
;* arg1 = buffer pointer * ;* arg1 = buffer pointer
;* * ;*
;* Returns: * ;* Returns:
;* None * ;* None
;* * ;*
;* Register usage: * ;* Register usage:
;* arg0 = rdr target * ;* arg0 = rdr target
;* arg1 = buffer pointer * ;* arg1 = buffer pointer
;* %r24 - DR2 | DR2_SLOW_RET * ;* %r24 - DR2 | DR2_SLOW_RET
;* %r23 - original DR2 value * ;* %r23 - original DR2 value
;* * ;*
;************************************************************************ ;***********************************************************************
.export perf_rdr_shift_out_U,code .export perf_rdr_shift_out_U,code
perf_rdr_shift_out_U: perf_rdr_shift_out_U:
...@@ -1386,11 +1384,11 @@ perf_rdr_shift_out_U: ...@@ -1386,11 +1384,11 @@ perf_rdr_shift_out_U:
depdi,z 1,DR2_SLOW_RET,1,%r24 depdi,z 1,DR2_SLOW_RET,1,%r24
MFDIAG_2 (23) MFDIAG_2 (23)
or %r24,%r23,%r24 or %r24,%r23,%r24
MTDIAG_2 (24) ; set DR2_SLOW_RET MTDIAG_2 (24) ; set DR2_SLOW_RET
MTDIAG_1 (25) ; data to the staging register MTDIAG_1 (25) ; data to the staging register
shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number
blr %r1,%r0 ; branch to 8-instruction sequence blr %r1,%r0 ; branch to 8-instruction sequence
nop nop
; ;
...@@ -1398,291 +1396,291 @@ perf_rdr_shift_out_U: ...@@ -1398,291 +1396,291 @@ perf_rdr_shift_out_U:
; ;
sync ; RDR 0 write sequence sync ; RDR 0 write sequence
ssm 0,0 ssm 0,0
STDIAG (0) STDIAG (0)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 1 write sequence sync ; RDR 1 write sequence
ssm 0,0 ssm 0,0
STDIAG (1) STDIAG (1)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 2 write sequence sync ; RDR 2 write sequence
ssm 0,0 ssm 0,0
STDIAG (2) STDIAG (2)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 3 write sequence sync ; RDR 3 write sequence
ssm 0,0 ssm 0,0
STDIAG (3) STDIAG (3)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 4 write sequence sync ; RDR 4 write sequence
ssm 0,0 ssm 0,0
STDIAG (4) STDIAG (4)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 5 write sequence sync ; RDR 5 write sequence
ssm 0,0 ssm 0,0
STDIAG (5) STDIAG (5)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 6 write sequence sync ; RDR 6 write sequence
ssm 0,0 ssm 0,0
STDIAG (6) STDIAG (6)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 7 write sequence sync ; RDR 7 write sequence
ssm 0,0 ssm 0,0
STDIAG (7) STDIAG (7)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 8 write sequence sync ; RDR 8 write sequence
ssm 0,0 ssm 0,0
STDIAG (8) STDIAG (8)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 9 write sequence sync ; RDR 9 write sequence
ssm 0,0 ssm 0,0
STDIAG (9) STDIAG (9)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 10 write sequence sync ; RDR 10 write sequence
ssm 0,0 ssm 0,0
STDIAG (10) STDIAG (10)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 11 write sequence sync ; RDR 11 write sequence
ssm 0,0 ssm 0,0
STDIAG (11) STDIAG (11)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 12 write sequence sync ; RDR 12 write sequence
ssm 0,0 ssm 0,0
STDIAG (12) STDIAG (12)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 13 write sequence sync ; RDR 13 write sequence
ssm 0,0 ssm 0,0
STDIAG (13) STDIAG (13)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 14 write sequence sync ; RDR 14 write sequence
ssm 0,0 ssm 0,0
STDIAG (14) STDIAG (14)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 15 write sequence sync ; RDR 15 write sequence
ssm 0,0 ssm 0,0
STDIAG (15) STDIAG (15)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 16 write sequence sync ; RDR 16 write sequence
ssm 0,0 ssm 0,0
STDIAG (16) STDIAG (16)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 17 write sequence sync ; RDR 17 write sequence
ssm 0,0 ssm 0,0
STDIAG (17) STDIAG (17)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 18 write sequence sync ; RDR 18 write sequence
ssm 0,0 ssm 0,0
STDIAG (18) STDIAG (18)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 19 write sequence sync ; RDR 19 write sequence
ssm 0,0 ssm 0,0
STDIAG (19) STDIAG (19)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 20 write sequence sync ; RDR 20 write sequence
ssm 0,0 ssm 0,0
STDIAG (20) STDIAG (20)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 21 write sequence sync ; RDR 21 write sequence
ssm 0,0 ssm 0,0
STDIAG (21) STDIAG (21)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 22 write sequence sync ; RDR 22 write sequence
ssm 0,0 ssm 0,0
STDIAG (22) STDIAG (22)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 23 write sequence sync ; RDR 23 write sequence
ssm 0,0 ssm 0,0
STDIAG (23) STDIAG (23)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 24 write sequence sync ; RDR 24 write sequence
ssm 0,0 ssm 0,0
STDIAG (24) STDIAG (24)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 25 write sequence sync ; RDR 25 write sequence
ssm 0,0 ssm 0,0
STDIAG (25) STDIAG (25)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 26 write sequence sync ; RDR 26 write sequence
ssm 0,0 ssm 0,0
STDIAG (26) STDIAG (26)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 27 write sequence sync ; RDR 27 write sequence
ssm 0,0 ssm 0,0
STDIAG (27) STDIAG (27)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 28 write sequence sync ; RDR 28 write sequence
ssm 0,0 ssm 0,0
STDIAG (28) STDIAG (28)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 29 write sequence sync ; RDR 29 write sequence
ssm 0,0 ssm 0,0
STDIAG (29) STDIAG (29)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 30 write sequence sync ; RDR 30 write sequence
ssm 0,0 ssm 0,0
STDIAG (30) STDIAG (30)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
sync ; RDR 31 write sequence sync ; RDR 31 write sequence
ssm 0,0 ssm 0,0
STDIAG (31) STDIAG (31)
ssm 0,0 ssm 0,0
b,n perf_rdr_shift_out_U_leave b,n perf_rdr_shift_out_U_leave
nop nop
ssm 0,0 ssm 0,0
nop nop
perf_rdr_shift_out_U_leave: perf_rdr_shift_out_U_leave:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment