perf_asm.S 26 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693
  1. /* low-level asm for "intrigue" (PA8500-8700 CPU perf counters)
  2. *
  3. * Copyright (C) 2001 Randolph Chung <tausq at parisc-linux.org>
  4. * Copyright (C) 2001 Hewlett-Packard (Grant Grundler)
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, write to the Free Software
  18. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  19. */
  20. #include <asm/assembly.h>
  21. #include <linux/init.h>
  22. #include <linux/linkage.h>
  23. #ifdef CONFIG_64BIT
  24. .level 2.0w
  25. #endif /* CONFIG_64BIT */
  26. #define MTDIAG_1(gr) .word 0x14201840 + gr*0x10000
  27. #define MTDIAG_2(gr) .word 0x14401840 + gr*0x10000
  28. #define MFDIAG_1(gr) .word 0x142008A0 + gr
  29. #define MFDIAG_2(gr) .word 0x144008A0 + gr
  30. #define STDIAG(dr) .word 0x14000AA0 + dr*0x200000
  31. #define SFDIAG(dr) .word 0x14000BA0 + dr*0x200000
  32. #define DR2_SLOW_RET 53
  33. ;
  34. ; Enable the performance counters
  35. ;
  36. ; The coprocessor only needs to be enabled when
  37. ; starting/stopping the coprocessor with the pmenb/pmdis.
  38. ;
  39. .text
  40. ENTRY(perf_intrigue_enable_perf_counters)
  41. .proc
  42. .callinfo frame=0,NO_CALLS
  43. .entry
  44. ldi 0x20,%r25 ; load up perfmon bit
  45. mfctl ccr,%r26 ; get coprocessor register
  46. or %r25,%r26,%r26 ; set bit
  47. mtctl %r26,ccr ; turn on performance coprocessor
  48. pmenb ; enable performance monitor
  49. ssm 0,0 ; dummy op to ensure completion
  50. sync ; follow ERS
  51. andcm %r26,%r25,%r26 ; clear bit now
  52. mtctl %r26,ccr ; turn off performance coprocessor
  53. nop ; NOPs as specified in ERS
  54. nop
  55. nop
  56. nop
  57. nop
  58. nop
  59. nop
  60. bve (%r2)
  61. nop
  62. .exit
  63. .procend
  64. ENDPROC(perf_intrigue_enable_perf_counters)
  65. ENTRY(perf_intrigue_disable_perf_counters)
  66. .proc
  67. .callinfo frame=0,NO_CALLS
  68. .entry
  69. ldi 0x20,%r25 ; load up perfmon bit
  70. mfctl ccr,%r26 ; get coprocessor register
  71. or %r25,%r26,%r26 ; set bit
  72. mtctl %r26,ccr ; turn on performance coprocessor
  73. pmdis ; disable performance monitor
  74. ssm 0,0 ; dummy op to ensure completion
  75. andcm %r26,%r25,%r26 ; clear bit now
  76. bve (%r2)
  77. mtctl %r26,ccr ; turn off performance coprocessor
  78. .exit
  79. .procend
  80. ENDPROC(perf_intrigue_disable_perf_counters)
  81. ;***********************************************************************
  82. ;*
  83. ;* Name: perf_rdr_shift_in_W
  84. ;*
  85. ;* Description:
  86. ;* This routine shifts data in from the RDR in arg0 and returns
  87. ;* the result in ret0. If the RDR is <= 64 bits in length, it
  88. ;* is shifted shifted backup immediately. This is to compensate
  89. ;* for RDR10 which has bits that preclude PDC stack operations
  90. ;* when they are in the wrong state.
  91. ;*
  92. ;* Arguments:
  93. ;* arg0 : rdr to be read
  94. ;* arg1 : bit length of rdr
  95. ;*
  96. ;* Returns:
  97. ;* ret0 = next 64 bits of rdr data from staging register
  98. ;*
  99. ;* Register usage:
  100. ;* arg0 : rdr to be read
  101. ;* arg1 : bit length of rdr
  102. ;* %r24 - original DR2 value
  103. ;* %r1 - scratch
  104. ;* %r29 - scratch
  105. ;*
  106. ;* Returns:
  107. ;* ret0 = RDR data (right justified)
  108. ;*
  109. ;***********************************************************************
  110. ENTRY(perf_rdr_shift_in_W)
  111. .proc
  112. .callinfo frame=0,NO_CALLS
  113. .entry
  114. ;
  115. ; read(shift in) the RDR.
  116. ;
  117. ; NOTE: The PCX-W ERS states that DR2_SLOW_RET must be set before any
  118. ; shifting is done, from or to, remote diagnose registers.
  119. ;
  120. depdi,z 1,DR2_SLOW_RET,1,%r29
  121. MFDIAG_2 (24)
  122. or %r24,%r29,%r29
  123. MTDIAG_2 (29) ; set DR2_SLOW_RET
  124. nop
  125. nop
  126. nop
  127. nop
  128. ;
  129. ; Cacheline start (32-byte cacheline)
  130. ;
  131. nop
  132. nop
  133. nop
  134. extrd,u arg1,63,6,%r1 ; setup shift amount by bits to move
  135. mtsar %r1
  136. shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number
  137. blr %r1,%r0 ; branch to 8-instruction sequence
  138. nop
  139. ;
  140. ; Cacheline start (32-byte cacheline)
  141. ;
  142. ;
  143. ; RDR 0 sequence
  144. ;
  145. SFDIAG (0)
  146. ssm 0,0
  147. MFDIAG_1 (28)
  148. shrpd ret0,%r0,%sar,%r1
  149. MTDIAG_1 (1) ; mtdiag %dr1, %r1
  150. STDIAG (0)
  151. ssm 0,0
  152. b,n perf_rdr_shift_in_W_leave
  153. ;
  154. ; RDR 1 sequence
  155. ;
  156. sync
  157. ssm 0,0
  158. SFDIAG (1)
  159. ssm 0,0
  160. MFDIAG_1 (28)
  161. ssm 0,0
  162. b,n perf_rdr_shift_in_W_leave
  163. nop
  164. ;
  165. ; RDR 2 read sequence
  166. ;
  167. SFDIAG (2)
  168. ssm 0,0
  169. MFDIAG_1 (28)
  170. shrpd ret0,%r0,%sar,%r1
  171. MTDIAG_1 (1)
  172. STDIAG (2)
  173. ssm 0,0
  174. b,n perf_rdr_shift_in_W_leave
  175. ;
  176. ; RDR 3 read sequence
  177. ;
  178. b,n perf_rdr_shift_in_W_leave
  179. nop
  180. nop
  181. nop
  182. nop
  183. nop
  184. nop
  185. nop
  186. ;
  187. ; RDR 4 read sequence
  188. ;
  189. sync
  190. ssm 0,0
  191. SFDIAG (4)
  192. ssm 0,0
  193. MFDIAG_1 (28)
  194. b,n perf_rdr_shift_in_W_leave
  195. ssm 0,0
  196. nop
  197. ;
  198. ; RDR 5 read sequence
  199. ;
  200. sync
  201. ssm 0,0
  202. SFDIAG (5)
  203. ssm 0,0
  204. MFDIAG_1 (28)
  205. b,n perf_rdr_shift_in_W_leave
  206. ssm 0,0
  207. nop
  208. ;
  209. ; RDR 6 read sequence
  210. ;
  211. sync
  212. ssm 0,0
  213. SFDIAG (6)
  214. ssm 0,0
  215. MFDIAG_1 (28)
  216. b,n perf_rdr_shift_in_W_leave
  217. ssm 0,0
  218. nop
  219. ;
  220. ; RDR 7 read sequence
  221. ;
  222. b,n perf_rdr_shift_in_W_leave
  223. nop
  224. nop
  225. nop
  226. nop
  227. nop
  228. nop
  229. nop
  230. ;
  231. ; RDR 8 read sequence
  232. ;
  233. b,n perf_rdr_shift_in_W_leave
  234. nop
  235. nop
  236. nop
  237. nop
  238. nop
  239. nop
  240. nop
  241. ;
  242. ; RDR 9 read sequence
  243. ;
  244. b,n perf_rdr_shift_in_W_leave
  245. nop
  246. nop
  247. nop
  248. nop
  249. nop
  250. nop
  251. nop
  252. ;
  253. ; RDR 10 read sequence
  254. ;
  255. SFDIAG (10)
  256. ssm 0,0
  257. MFDIAG_1 (28)
  258. shrpd ret0,%r0,%sar,%r1
  259. MTDIAG_1 (1)
  260. STDIAG (10)
  261. ssm 0,0
  262. b,n perf_rdr_shift_in_W_leave
  263. ;
  264. ; RDR 11 read sequence
  265. ;
  266. SFDIAG (11)
  267. ssm 0,0
  268. MFDIAG_1 (28)
  269. shrpd ret0,%r0,%sar,%r1
  270. MTDIAG_1 (1)
  271. STDIAG (11)
  272. ssm 0,0
  273. b,n perf_rdr_shift_in_W_leave
  274. ;
  275. ; RDR 12 read sequence
  276. ;
  277. b,n perf_rdr_shift_in_W_leave
  278. nop
  279. nop
  280. nop
  281. nop
  282. nop
  283. nop
  284. nop
  285. ;
  286. ; RDR 13 read sequence
  287. ;
  288. sync
  289. ssm 0,0
  290. SFDIAG (13)
  291. ssm 0,0
  292. MFDIAG_1 (28)
  293. b,n perf_rdr_shift_in_W_leave
  294. ssm 0,0
  295. nop
  296. ;
  297. ; RDR 14 read sequence
  298. ;
  299. SFDIAG (14)
  300. ssm 0,0
  301. MFDIAG_1 (28)
  302. shrpd ret0,%r0,%sar,%r1
  303. MTDIAG_1 (1)
  304. STDIAG (14)
  305. ssm 0,0
  306. b,n perf_rdr_shift_in_W_leave
  307. ;
  308. ; RDR 15 read sequence
  309. ;
  310. sync
  311. ssm 0,0
  312. SFDIAG (15)
  313. ssm 0,0
  314. MFDIAG_1 (28)
  315. ssm 0,0
  316. b,n perf_rdr_shift_in_W_leave
  317. nop
  318. ;
  319. ; RDR 16 read sequence
  320. ;
  321. sync
  322. ssm 0,0
  323. SFDIAG (16)
  324. ssm 0,0
  325. MFDIAG_1 (28)
  326. b,n perf_rdr_shift_in_W_leave
  327. ssm 0,0
  328. nop
  329. ;
  330. ; RDR 17 read sequence
  331. ;
  332. SFDIAG (17)
  333. ssm 0,0
  334. MFDIAG_1 (28)
  335. shrpd ret0,%r0,%sar,%r1
  336. MTDIAG_1 (1)
  337. STDIAG (17)
  338. ssm 0,0
  339. b,n perf_rdr_shift_in_W_leave
  340. ;
  341. ; RDR 18 read sequence
  342. ;
  343. SFDIAG (18)
  344. ssm 0,0
  345. MFDIAG_1 (28)
  346. shrpd ret0,%r0,%sar,%r1
  347. MTDIAG_1 (1)
  348. STDIAG (18)
  349. ssm 0,0
  350. b,n perf_rdr_shift_in_W_leave
  351. ;
  352. ; RDR 19 read sequence
  353. ;
  354. b,n perf_rdr_shift_in_W_leave
  355. nop
  356. nop
  357. nop
  358. nop
  359. nop
  360. nop
  361. nop
  362. ;
  363. ; RDR 20 read sequence
  364. ;
  365. sync
  366. ssm 0,0
  367. SFDIAG (20)
  368. ssm 0,0
  369. MFDIAG_1 (28)
  370. b,n perf_rdr_shift_in_W_leave
  371. ssm 0,0
  372. nop
  373. ;
  374. ; RDR 21 read sequence
  375. ;
  376. sync
  377. ssm 0,0
  378. SFDIAG (21)
  379. ssm 0,0
  380. MFDIAG_1 (28)
  381. b,n perf_rdr_shift_in_W_leave
  382. ssm 0,0
  383. nop
  384. ;
  385. ; RDR 22 read sequence
  386. ;
  387. sync
  388. ssm 0,0
  389. SFDIAG (22)
  390. ssm 0,0
  391. MFDIAG_1 (28)
  392. b,n perf_rdr_shift_in_W_leave
  393. ssm 0,0
  394. nop
  395. ;
  396. ; RDR 23 read sequence
  397. ;
  398. sync
  399. ssm 0,0
  400. SFDIAG (23)
  401. ssm 0,0
  402. MFDIAG_1 (28)
  403. b,n perf_rdr_shift_in_W_leave
  404. ssm 0,0
  405. nop
  406. ;
  407. ; RDR 24 read sequence
  408. ;
  409. sync
  410. ssm 0,0
  411. SFDIAG (24)
  412. ssm 0,0
  413. MFDIAG_1 (28)
  414. b,n perf_rdr_shift_in_W_leave
  415. ssm 0,0
  416. nop
  417. ;
  418. ; RDR 25 read sequence
  419. ;
  420. sync
  421. ssm 0,0
  422. SFDIAG (25)
  423. ssm 0,0
  424. MFDIAG_1 (28)
  425. b,n perf_rdr_shift_in_W_leave
  426. ssm 0,0
  427. nop
  428. ;
  429. ; RDR 26 read sequence
  430. ;
  431. SFDIAG (26)
  432. ssm 0,0
  433. MFDIAG_1 (28)
  434. shrpd ret0,%r0,%sar,%r1
  435. MTDIAG_1 (1)
  436. STDIAG (26)
  437. ssm 0,0
  438. b,n perf_rdr_shift_in_W_leave
  439. ;
  440. ; RDR 27 read sequence
  441. ;
  442. SFDIAG (27)
  443. ssm 0,0
  444. MFDIAG_1 (28)
  445. shrpd ret0,%r0,%sar,%r1
  446. MTDIAG_1 (1)
  447. STDIAG (27)
  448. ssm 0,0
  449. b,n perf_rdr_shift_in_W_leave
  450. ;
  451. ; RDR 28 read sequence
  452. ;
  453. sync
  454. ssm 0,0
  455. SFDIAG (28)
  456. ssm 0,0
  457. MFDIAG_1 (28)
  458. b,n perf_rdr_shift_in_W_leave
  459. ssm 0,0
  460. nop
  461. ;
  462. ; RDR 29 read sequence
  463. ;
  464. sync
  465. ssm 0,0
  466. SFDIAG (29)
  467. ssm 0,0
  468. MFDIAG_1 (28)
  469. b,n perf_rdr_shift_in_W_leave
  470. ssm 0,0
  471. nop
  472. ;
  473. ; RDR 30 read sequence
  474. ;
  475. SFDIAG (30)
  476. ssm 0,0
  477. MFDIAG_1 (28)
  478. shrpd ret0,%r0,%sar,%r1
  479. MTDIAG_1 (1)
  480. STDIAG (30)
  481. ssm 0,0
  482. b,n perf_rdr_shift_in_W_leave
  483. ;
  484. ; RDR 31 read sequence
  485. ;
  486. sync
  487. ssm 0,0
  488. SFDIAG (31)
  489. ssm 0,0
  490. MFDIAG_1 (28)
  491. nop
  492. ssm 0,0
  493. nop
  494. ;
  495. ; Fallthrough
  496. ;
  497. perf_rdr_shift_in_W_leave:
  498. bve (%r2)
  499. .exit
  500. MTDIAG_2 (24) ; restore DR2
  501. .procend
  502. ENDPROC(perf_rdr_shift_in_W)
  503. ;***********************************************************************
  504. ;*
  505. ;* Name: perf_rdr_shift_out_W
  506. ;*
  507. ;* Description:
  508. ;* This routine moves data to the RDR's. The double-word that
  509. ;* arg1 points to is loaded and moved into the staging register.
  510. ;* Then the STDIAG instruction for the RDR # in arg0 is called
  511. ;* to move the data to the RDR.
  512. ;*
  513. ;* Arguments:
  514. ;* arg0 = rdr number
  515. ;* arg1 = 64-bit value to write
  516. ;* %r24 - DR2 | DR2_SLOW_RET
  517. ;* %r23 - original DR2 value
  518. ;*
  519. ;* Returns:
  520. ;* None
  521. ;*
  522. ;* Register usage:
  523. ;*
  524. ;***********************************************************************
  525. ENTRY(perf_rdr_shift_out_W)
  526. .proc
  527. .callinfo frame=0,NO_CALLS
  528. .entry
  529. ;
  530. ; NOTE: The PCX-W ERS states that DR2_SLOW_RET must be set before any
  531. ; shifting is done, from or to, the remote diagnose registers.
  532. ;
  533. depdi,z 1,DR2_SLOW_RET,1,%r24
  534. MFDIAG_2 (23)
  535. or %r24,%r23,%r24
  536. MTDIAG_2 (24) ; set DR2_SLOW_RET
  537. MTDIAG_1 (25) ; data to the staging register
  538. shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number
  539. blr %r1,%r0 ; branch to 8-instruction sequence
  540. nop
  541. ;
  542. ; RDR 0 write sequence
  543. ;
  544. sync ; RDR 0 write sequence
  545. ssm 0,0
  546. STDIAG (0)
  547. ssm 0,0
  548. b,n perf_rdr_shift_out_W_leave
  549. nop
  550. ssm 0,0
  551. nop
  552. ;
  553. ; RDR 1 write sequence
  554. ;
  555. sync
  556. ssm 0,0
  557. STDIAG (1)
  558. ssm 0,0
  559. b,n perf_rdr_shift_out_W_leave
  560. nop
  561. ssm 0,0
  562. nop
  563. ;
  564. ; RDR 2 write sequence
  565. ;
  566. sync
  567. ssm 0,0
  568. STDIAG (2)
  569. ssm 0,0
  570. b,n perf_rdr_shift_out_W_leave
  571. nop
  572. ssm 0,0
  573. nop
  574. ;
  575. ; RDR 3 write sequence
  576. ;
  577. sync
  578. ssm 0,0
  579. STDIAG (3)
  580. ssm 0,0
  581. b,n perf_rdr_shift_out_W_leave
  582. nop
  583. ssm 0,0
  584. nop
  585. ;
  586. ; RDR 4 write sequence
  587. ;
  588. sync
  589. ssm 0,0
  590. STDIAG (4)
  591. ssm 0,0
  592. b,n perf_rdr_shift_out_W_leave
  593. nop
  594. ssm 0,0
  595. nop
  596. ;
  597. ; RDR 5 write sequence
  598. ;
  599. sync
  600. ssm 0,0
  601. STDIAG (5)
  602. ssm 0,0
  603. b,n perf_rdr_shift_out_W_leave
  604. nop
  605. ssm 0,0
  606. nop
  607. ;
  608. ; RDR 6 write sequence
  609. ;
  610. sync
  611. ssm 0,0
  612. STDIAG (6)
  613. ssm 0,0
  614. b,n perf_rdr_shift_out_W_leave
  615. nop
  616. ssm 0,0
  617. nop
  618. ;
  619. ; RDR 7 write sequence
  620. ;
  621. sync
  622. ssm 0,0
  623. STDIAG (7)
  624. ssm 0,0
  625. b,n perf_rdr_shift_out_W_leave
  626. nop
  627. ssm 0,0
  628. nop
  629. ;
  630. ; RDR 8 write sequence
  631. ;
  632. sync
  633. ssm 0,0
  634. STDIAG (8)
  635. ssm 0,0
  636. b,n perf_rdr_shift_out_W_leave
  637. nop
  638. ssm 0,0
  639. nop
  640. ;
  641. ; RDR 9 write sequence
  642. ;
  643. sync
  644. ssm 0,0
  645. STDIAG (9)
  646. ssm 0,0
  647. b,n perf_rdr_shift_out_W_leave
  648. nop
  649. ssm 0,0
  650. nop
  651. ;
  652. ; RDR 10 write sequence
  653. ;
  654. sync
  655. ssm 0,0
  656. STDIAG (10)
  657. STDIAG (26)
  658. ssm 0,0
  659. b,n perf_rdr_shift_out_W_leave
  660. ssm 0,0
  661. nop
  662. ;
  663. ; RDR 11 write sequence
  664. ;
  665. sync
  666. ssm 0,0
  667. STDIAG (11)
  668. STDIAG (27)
  669. ssm 0,0
  670. b,n perf_rdr_shift_out_W_leave
  671. ssm 0,0
  672. nop
  673. ;
  674. ; RDR 12 write sequence
  675. ;
  676. sync
  677. ssm 0,0
  678. STDIAG (12)
  679. ssm 0,0
  680. b,n perf_rdr_shift_out_W_leave
  681. nop
  682. ssm 0,0
  683. nop
  684. ;
  685. ; RDR 13 write sequence
  686. ;
  687. sync
  688. ssm 0,0
  689. STDIAG (13)
  690. ssm 0,0
  691. b,n perf_rdr_shift_out_W_leave
  692. nop
  693. ssm 0,0
  694. nop
  695. ;
  696. ; RDR 14 write sequence
  697. ;
  698. sync
  699. ssm 0,0
  700. STDIAG (14)
  701. ssm 0,0
  702. b,n perf_rdr_shift_out_W_leave
  703. nop
  704. ssm 0,0
  705. nop
  706. ;
  707. ; RDR 15 write sequence
  708. ;
  709. sync
  710. ssm 0,0
  711. STDIAG (15)
  712. ssm 0,0
  713. b,n perf_rdr_shift_out_W_leave
  714. nop
  715. ssm 0,0
  716. nop
  717. ;
  718. ; RDR 16 write sequence
  719. ;
  720. sync
  721. ssm 0,0
  722. STDIAG (16)
  723. ssm 0,0
  724. b,n perf_rdr_shift_out_W_leave
  725. nop
  726. ssm 0,0
  727. nop
  728. ;
  729. ; RDR 17 write sequence
  730. ;
  731. sync
  732. ssm 0,0
  733. STDIAG (17)
  734. ssm 0,0
  735. b,n perf_rdr_shift_out_W_leave
  736. nop
  737. ssm 0,0
  738. nop
  739. ;
  740. ; RDR 18 write sequence
  741. ;
  742. sync
  743. ssm 0,0
  744. STDIAG (18)
  745. ssm 0,0
  746. b,n perf_rdr_shift_out_W_leave
  747. nop
  748. ssm 0,0
  749. nop
  750. ;
  751. ; RDR 19 write sequence
  752. ;
  753. sync
  754. ssm 0,0
  755. STDIAG (19)
  756. ssm 0,0
  757. b,n perf_rdr_shift_out_W_leave
  758. nop
  759. ssm 0,0
  760. nop
  761. ;
  762. ; RDR 20 write sequence
  763. ;
  764. sync
  765. ssm 0,0
  766. STDIAG (20)
  767. ssm 0,0
  768. b,n perf_rdr_shift_out_W_leave
  769. nop
  770. ssm 0,0
  771. nop
  772. ;
  773. ; RDR 21 write sequence
  774. ;
  775. sync
  776. ssm 0,0
  777. STDIAG (21)
  778. ssm 0,0
  779. b,n perf_rdr_shift_out_W_leave
  780. nop
  781. ssm 0,0
  782. nop
  783. ;
  784. ; RDR 22 write sequence
  785. ;
  786. sync
  787. ssm 0,0
  788. STDIAG (22)
  789. ssm 0,0
  790. b,n perf_rdr_shift_out_W_leave
  791. nop
  792. ssm 0,0
  793. nop
  794. ;
  795. ; RDR 23 write sequence
  796. ;
  797. sync
  798. ssm 0,0
  799. STDIAG (23)
  800. ssm 0,0
  801. b,n perf_rdr_shift_out_W_leave
  802. nop
  803. ssm 0,0
  804. nop
  805. ;
  806. ; RDR 24 write sequence
  807. ;
  808. sync
  809. ssm 0,0
  810. STDIAG (24)
  811. ssm 0,0
  812. b,n perf_rdr_shift_out_W_leave
  813. nop
  814. ssm 0,0
  815. nop
  816. ;
  817. ; RDR 25 write sequence
  818. ;
  819. sync
  820. ssm 0,0
  821. STDIAG (25)
  822. ssm 0,0
  823. b,n perf_rdr_shift_out_W_leave
  824. nop
  825. ssm 0,0
  826. nop
  827. ;
  828. ; RDR 26 write sequence
  829. ;
  830. sync
  831. ssm 0,0
  832. STDIAG (10)
  833. STDIAG (26)
  834. ssm 0,0
  835. b,n perf_rdr_shift_out_W_leave
  836. ssm 0,0
  837. nop
  838. ;
  839. ; RDR 27 write sequence
  840. ;
  841. sync
  842. ssm 0,0
  843. STDIAG (11)
  844. STDIAG (27)
  845. ssm 0,0
  846. b,n perf_rdr_shift_out_W_leave
  847. ssm 0,0
  848. nop
  849. ;
  850. ; RDR 28 write sequence
  851. ;
  852. sync
  853. ssm 0,0
  854. STDIAG (28)
  855. ssm 0,0
  856. b,n perf_rdr_shift_out_W_leave
  857. nop
  858. ssm 0,0
  859. nop
  860. ;
  861. ; RDR 29 write sequence
  862. ;
  863. sync
  864. ssm 0,0
  865. STDIAG (29)
  866. ssm 0,0
  867. b,n perf_rdr_shift_out_W_leave
  868. nop
  869. ssm 0,0
  870. nop
  871. ;
  872. ; RDR 30 write sequence
  873. ;
  874. sync
  875. ssm 0,0
  876. STDIAG (30)
  877. ssm 0,0
  878. b,n perf_rdr_shift_out_W_leave
  879. nop
  880. ssm 0,0
  881. nop
  882. ;
  883. ; RDR 31 write sequence
  884. ;
  885. sync
  886. ssm 0,0
  887. STDIAG (31)
  888. ssm 0,0
  889. b,n perf_rdr_shift_out_W_leave
  890. nop
  891. ssm 0,0
  892. nop
  893. perf_rdr_shift_out_W_leave:
  894. bve (%r2)
  895. .exit
  896. MTDIAG_2 (23) ; restore DR2
  897. .procend
  898. ENDPROC(perf_rdr_shift_out_W)
  899. ;***********************************************************************
  900. ;*
  901. ;* Name: rdr_shift_in_U
  902. ;*
  903. ;* Description:
  904. ;* This routine shifts data in from the RDR in arg0 and returns
  905. ;* the result in ret0. If the RDR is <= 64 bits in length, it
  906. ;* is shifted shifted backup immediately. This is to compensate
  907. ;* for RDR10 which has bits that preclude PDC stack operations
  908. ;* when they are in the wrong state.
  909. ;*
  910. ;* Arguments:
  911. ;* arg0 : rdr to be read
  912. ;* arg1 : bit length of rdr
  913. ;*
  914. ;* Returns:
  915. ;* ret0 = next 64 bits of rdr data from staging register
  916. ;*
  917. ;* Register usage:
  918. ;* arg0 : rdr to be read
  919. ;* arg1 : bit length of rdr
  920. ;* %r24 - original DR2 value
  921. ;* %r23 - DR2 | DR2_SLOW_RET
  922. ;* %r1 - scratch
  923. ;*
  924. ;***********************************************************************
  925. ENTRY(perf_rdr_shift_in_U)
  926. .proc
  927. .callinfo frame=0,NO_CALLS
  928. .entry
  929. ; read(shift in) the RDR.
  930. ;
  931. ; NOTE: The PCX-U ERS states that DR2_SLOW_RET must be set before any
  932. ; shifting is done, from or to, remote diagnose registers.
  933. depdi,z 1,DR2_SLOW_RET,1,%r29
  934. MFDIAG_2 (24)
  935. or %r24,%r29,%r29
  936. MTDIAG_2 (29) ; set DR2_SLOW_RET
  937. nop
  938. nop
  939. nop
  940. nop
  941. ;
  942. ; Start of next 32-byte cacheline
  943. ;
  944. nop
  945. nop
  946. nop
  947. extrd,u arg1,63,6,%r1
  948. mtsar %r1
  949. shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number
  950. blr %r1,%r0 ; branch to 8-instruction sequence
  951. nop
  952. ;
  953. ; Start of next 32-byte cacheline
  954. ;
  955. SFDIAG (0) ; RDR 0 read sequence
  956. ssm 0,0
  957. MFDIAG_1 (28)
  958. shrpd ret0,%r0,%sar,%r1
  959. MTDIAG_1 (1)
  960. STDIAG (0)
  961. ssm 0,0
  962. b,n perf_rdr_shift_in_U_leave
  963. SFDIAG (1) ; RDR 1 read sequence
  964. ssm 0,0
  965. MFDIAG_1 (28)
  966. shrpd ret0,%r0,%sar,%r1
  967. MTDIAG_1 (1)
  968. STDIAG (1)
  969. ssm 0,0
  970. b,n perf_rdr_shift_in_U_leave
  971. sync ; RDR 2 read sequence
  972. ssm 0,0
  973. SFDIAG (4)
  974. ssm 0,0
  975. MFDIAG_1 (28)
  976. b,n perf_rdr_shift_in_U_leave
  977. ssm 0,0
  978. nop
  979. sync ; RDR 3 read sequence
  980. ssm 0,0
  981. SFDIAG (3)
  982. ssm 0,0
  983. MFDIAG_1 (28)
  984. b,n perf_rdr_shift_in_U_leave
  985. ssm 0,0
  986. nop
  987. sync ; RDR 4 read sequence
  988. ssm 0,0
  989. SFDIAG (4)
  990. ssm 0,0
  991. MFDIAG_1 (28)
  992. b,n perf_rdr_shift_in_U_leave
  993. ssm 0,0
  994. nop
  995. sync ; RDR 5 read sequence
  996. ssm 0,0
  997. SFDIAG (5)
  998. ssm 0,0
  999. MFDIAG_1 (28)
  1000. b,n perf_rdr_shift_in_U_leave
  1001. ssm 0,0
  1002. nop
  1003. sync ; RDR 6 read sequence
  1004. ssm 0,0
  1005. SFDIAG (6)
  1006. ssm 0,0
  1007. MFDIAG_1 (28)
  1008. b,n perf_rdr_shift_in_U_leave
  1009. ssm 0,0
  1010. nop
  1011. sync ; RDR 7 read sequence
  1012. ssm 0,0
  1013. SFDIAG (7)
  1014. ssm 0,0
  1015. MFDIAG_1 (28)
  1016. b,n perf_rdr_shift_in_U_leave
  1017. ssm 0,0
  1018. nop
  1019. b,n perf_rdr_shift_in_U_leave
  1020. nop
  1021. nop
  1022. nop
  1023. nop
  1024. nop
  1025. nop
  1026. nop
  1027. SFDIAG (9) ; RDR 9 read sequence
  1028. ssm 0,0
  1029. MFDIAG_1 (28)
  1030. shrpd ret0,%r0,%sar,%r1
  1031. MTDIAG_1 (1)
  1032. STDIAG (9)
  1033. ssm 0,0
  1034. b,n perf_rdr_shift_in_U_leave
  1035. SFDIAG (10) ; RDR 10 read sequence
  1036. ssm 0,0
  1037. MFDIAG_1 (28)
  1038. shrpd ret0,%r0,%sar,%r1
  1039. MTDIAG_1 (1)
  1040. STDIAG (10)
  1041. ssm 0,0
  1042. b,n perf_rdr_shift_in_U_leave
  1043. SFDIAG (11) ; RDR 11 read sequence
  1044. ssm 0,0
  1045. MFDIAG_1 (28)
  1046. shrpd ret0,%r0,%sar,%r1
  1047. MTDIAG_1 (1)
  1048. STDIAG (11)
  1049. ssm 0,0
  1050. b,n perf_rdr_shift_in_U_leave
  1051. SFDIAG (12) ; RDR 12 read sequence
  1052. ssm 0,0
  1053. MFDIAG_1 (28)
  1054. shrpd ret0,%r0,%sar,%r1
  1055. MTDIAG_1 (1)
  1056. STDIAG (12)
  1057. ssm 0,0
  1058. b,n perf_rdr_shift_in_U_leave
  1059. SFDIAG (13) ; RDR 13 read sequence
  1060. ssm 0,0
  1061. MFDIAG_1 (28)
  1062. shrpd ret0,%r0,%sar,%r1
  1063. MTDIAG_1 (1)
  1064. STDIAG (13)
  1065. ssm 0,0
  1066. b,n perf_rdr_shift_in_U_leave
  1067. SFDIAG (14) ; RDR 14 read sequence
  1068. ssm 0,0
  1069. MFDIAG_1 (28)
  1070. shrpd ret0,%r0,%sar,%r1
  1071. MTDIAG_1 (1)
  1072. STDIAG (14)
  1073. ssm 0,0
  1074. b,n perf_rdr_shift_in_U_leave
  1075. SFDIAG (15) ; RDR 15 read sequence
  1076. ssm 0,0
  1077. MFDIAG_1 (28)
  1078. shrpd ret0,%r0,%sar,%r1
  1079. MTDIAG_1 (1)
  1080. STDIAG (15)
  1081. ssm 0,0
  1082. b,n perf_rdr_shift_in_U_leave
  1083. sync ; RDR 16 read sequence
  1084. ssm 0,0
  1085. SFDIAG (16)
  1086. ssm 0,0
  1087. MFDIAG_1 (28)
  1088. b,n perf_rdr_shift_in_U_leave
  1089. ssm 0,0
  1090. nop
  1091. SFDIAG (17) ; RDR 17 read sequence
  1092. ssm 0,0
  1093. MFDIAG_1 (28)
  1094. shrpd ret0,%r0,%sar,%r1
  1095. MTDIAG_1 (1)
  1096. STDIAG (17)
  1097. ssm 0,0
  1098. b,n perf_rdr_shift_in_U_leave
  1099. SFDIAG (18) ; RDR 18 read sequence
  1100. ssm 0,0
  1101. MFDIAG_1 (28)
  1102. shrpd ret0,%r0,%sar,%r1
  1103. MTDIAG_1 (1)
  1104. STDIAG (18)
  1105. ssm 0,0
  1106. b,n perf_rdr_shift_in_U_leave
  1107. b,n perf_rdr_shift_in_U_leave
  1108. nop
  1109. nop
  1110. nop
  1111. nop
  1112. nop
  1113. nop
  1114. nop
  1115. sync ; RDR 20 read sequence
  1116. ssm 0,0
  1117. SFDIAG (20)
  1118. ssm 0,0
  1119. MFDIAG_1 (28)
  1120. b,n perf_rdr_shift_in_U_leave
  1121. ssm 0,0
  1122. nop
  1123. sync ; RDR 21 read sequence
  1124. ssm 0,0
  1125. SFDIAG (21)
  1126. ssm 0,0
  1127. MFDIAG_1 (28)
  1128. b,n perf_rdr_shift_in_U_leave
  1129. ssm 0,0
  1130. nop
  1131. sync ; RDR 22 read sequence
  1132. ssm 0,0
  1133. SFDIAG (22)
  1134. ssm 0,0
  1135. MFDIAG_1 (28)
  1136. b,n perf_rdr_shift_in_U_leave
  1137. ssm 0,0
  1138. nop
  1139. sync ; RDR 23 read sequence
  1140. ssm 0,0
  1141. SFDIAG (23)
  1142. ssm 0,0
  1143. MFDIAG_1 (28)
  1144. b,n perf_rdr_shift_in_U_leave
  1145. ssm 0,0
  1146. nop
  1147. sync ; RDR 24 read sequence
  1148. ssm 0,0
  1149. SFDIAG (24)
  1150. ssm 0,0
  1151. MFDIAG_1 (28)
  1152. b,n perf_rdr_shift_in_U_leave
  1153. ssm 0,0
  1154. nop
  1155. sync ; RDR 25 read sequence
  1156. ssm 0,0
  1157. SFDIAG (25)
  1158. ssm 0,0
  1159. MFDIAG_1 (28)
  1160. b,n perf_rdr_shift_in_U_leave
  1161. ssm 0,0
  1162. nop
  1163. SFDIAG (26) ; RDR 26 read sequence
  1164. ssm 0,0
  1165. MFDIAG_1 (28)
  1166. shrpd ret0,%r0,%sar,%r1
  1167. MTDIAG_1 (1)
  1168. STDIAG (26)
  1169. ssm 0,0
  1170. b,n perf_rdr_shift_in_U_leave
  1171. SFDIAG (27) ; RDR 27 read sequence
  1172. ssm 0,0
  1173. MFDIAG_1 (28)
  1174. shrpd ret0,%r0,%sar,%r1
  1175. MTDIAG_1 (1)
  1176. STDIAG (27)
  1177. ssm 0,0
  1178. b,n perf_rdr_shift_in_U_leave
  1179. sync ; RDR 28 read sequence
  1180. ssm 0,0
  1181. SFDIAG (28)
  1182. ssm 0,0
  1183. MFDIAG_1 (28)
  1184. b,n perf_rdr_shift_in_U_leave
  1185. ssm 0,0
  1186. nop
  1187. b,n perf_rdr_shift_in_U_leave
  1188. nop
  1189. nop
  1190. nop
  1191. nop
  1192. nop
  1193. nop
  1194. nop
  1195. SFDIAG (30) ; RDR 30 read sequence
  1196. ssm 0,0
  1197. MFDIAG_1 (28)
  1198. shrpd ret0,%r0,%sar,%r1
  1199. MTDIAG_1 (1)
  1200. STDIAG (30)
  1201. ssm 0,0
  1202. b,n perf_rdr_shift_in_U_leave
  1203. SFDIAG (31) ; RDR 31 read sequence
  1204. ssm 0,0
  1205. MFDIAG_1 (28)
  1206. shrpd ret0,%r0,%sar,%r1
  1207. MTDIAG_1 (1)
  1208. STDIAG (31)
  1209. ssm 0,0
  1210. b,n perf_rdr_shift_in_U_leave
  1211. nop
  1212. perf_rdr_shift_in_U_leave:
  1213. bve (%r2)
  1214. .exit
  1215. MTDIAG_2 (24) ; restore DR2
  1216. .procend
  1217. ENDPROC(perf_rdr_shift_in_U)
  1218. ;***********************************************************************
  1219. ;*
  1220. ;* Name: rdr_shift_out_U
  1221. ;*
  1222. ;* Description:
  1223. ;* This routine moves data to the RDR's. The double-word that
  1224. ;* arg1 points to is loaded and moved into the staging register.
  1225. ;* Then the STDIAG instruction for the RDR # in arg0 is called
  1226. ;* to move the data to the RDR.
  1227. ;*
  1228. ;* Arguments:
  1229. ;* arg0 = rdr target
  1230. ;* arg1 = buffer pointer
  1231. ;*
  1232. ;* Returns:
  1233. ;* None
  1234. ;*
  1235. ;* Register usage:
  1236. ;* arg0 = rdr target
  1237. ;* arg1 = buffer pointer
  1238. ;* %r24 - DR2 | DR2_SLOW_RET
  1239. ;* %r23 - original DR2 value
  1240. ;*
  1241. ;***********************************************************************
  1242. ENTRY(perf_rdr_shift_out_U)
  1243. .proc
  1244. .callinfo frame=0,NO_CALLS
  1245. .entry
  1246. ;
  1247. ; NOTE: The PCX-U ERS states that DR2_SLOW_RET must be set before any
  1248. ; shifting is done, from or to, the remote diagnose registers.
  1249. ;
  1250. depdi,z 1,DR2_SLOW_RET,1,%r24
  1251. MFDIAG_2 (23)
  1252. or %r24,%r23,%r24
  1253. MTDIAG_2 (24) ; set DR2_SLOW_RET
  1254. MTDIAG_1 (25) ; data to the staging register
  1255. shladd arg0,2,%r0,%r1 ; %r1 = 4 * RDR number
  1256. blr %r1,%r0 ; branch to 8-instruction sequence
  1257. nop
  1258. ;
  1259. ; 32-byte cachline aligned
  1260. ;
  1261. sync ; RDR 0 write sequence
  1262. ssm 0,0
  1263. STDIAG (0)
  1264. ssm 0,0
  1265. b,n perf_rdr_shift_out_U_leave
  1266. nop
  1267. ssm 0,0
  1268. nop
  1269. sync ; RDR 1 write sequence
  1270. ssm 0,0
  1271. STDIAG (1)
  1272. ssm 0,0
  1273. b,n perf_rdr_shift_out_U_leave
  1274. nop
  1275. ssm 0,0
  1276. nop
  1277. sync ; RDR 2 write sequence
  1278. ssm 0,0
  1279. STDIAG (2)
  1280. ssm 0,0
  1281. b,n perf_rdr_shift_out_U_leave
  1282. nop
  1283. ssm 0,0
  1284. nop
  1285. sync ; RDR 3 write sequence
  1286. ssm 0,0
  1287. STDIAG (3)
  1288. ssm 0,0
  1289. b,n perf_rdr_shift_out_U_leave
  1290. nop
  1291. ssm 0,0
  1292. nop
  1293. sync ; RDR 4 write sequence
  1294. ssm 0,0
  1295. STDIAG (4)
  1296. ssm 0,0
  1297. b,n perf_rdr_shift_out_U_leave
  1298. nop
  1299. ssm 0,0
  1300. nop
  1301. sync ; RDR 5 write sequence
  1302. ssm 0,0
  1303. STDIAG (5)
  1304. ssm 0,0
  1305. b,n perf_rdr_shift_out_U_leave
  1306. nop
  1307. ssm 0,0
  1308. nop
  1309. sync ; RDR 6 write sequence
  1310. ssm 0,0
  1311. STDIAG (6)
  1312. ssm 0,0
  1313. b,n perf_rdr_shift_out_U_leave
  1314. nop
  1315. ssm 0,0
  1316. nop
  1317. sync ; RDR 7 write sequence
  1318. ssm 0,0
  1319. STDIAG (7)
  1320. ssm 0,0
  1321. b,n perf_rdr_shift_out_U_leave
  1322. nop
  1323. ssm 0,0
  1324. nop
  1325. sync ; RDR 8 write sequence
  1326. ssm 0,0
  1327. STDIAG (8)
  1328. ssm 0,0
  1329. b,n perf_rdr_shift_out_U_leave
  1330. nop
  1331. ssm 0,0
  1332. nop
  1333. sync ; RDR 9 write sequence
  1334. ssm 0,0
  1335. STDIAG (9)
  1336. ssm 0,0
  1337. b,n perf_rdr_shift_out_U_leave
  1338. nop
  1339. ssm 0,0
  1340. nop
  1341. sync ; RDR 10 write sequence
  1342. ssm 0,0
  1343. STDIAG (10)
  1344. ssm 0,0
  1345. b,n perf_rdr_shift_out_U_leave
  1346. nop
  1347. ssm 0,0
  1348. nop
  1349. sync ; RDR 11 write sequence
  1350. ssm 0,0
  1351. STDIAG (11)
  1352. ssm 0,0
  1353. b,n perf_rdr_shift_out_U_leave
  1354. nop
  1355. ssm 0,0
  1356. nop
  1357. sync ; RDR 12 write sequence
  1358. ssm 0,0
  1359. STDIAG (12)
  1360. ssm 0,0
  1361. b,n perf_rdr_shift_out_U_leave
  1362. nop
  1363. ssm 0,0
  1364. nop
  1365. sync ; RDR 13 write sequence
  1366. ssm 0,0
  1367. STDIAG (13)
  1368. ssm 0,0
  1369. b,n perf_rdr_shift_out_U_leave
  1370. nop
  1371. ssm 0,0
  1372. nop
  1373. sync ; RDR 14 write sequence
  1374. ssm 0,0
  1375. STDIAG (14)
  1376. ssm 0,0
  1377. b,n perf_rdr_shift_out_U_leave
  1378. nop
  1379. ssm 0,0
  1380. nop
  1381. sync ; RDR 15 write sequence
  1382. ssm 0,0
  1383. STDIAG (15)
  1384. ssm 0,0
  1385. b,n perf_rdr_shift_out_U_leave
  1386. nop
  1387. ssm 0,0
  1388. nop
  1389. sync ; RDR 16 write sequence
  1390. ssm 0,0
  1391. STDIAG (16)
  1392. ssm 0,0
  1393. b,n perf_rdr_shift_out_U_leave
  1394. nop
  1395. ssm 0,0
  1396. nop
  1397. sync ; RDR 17 write sequence
  1398. ssm 0,0
  1399. STDIAG (17)
  1400. ssm 0,0
  1401. b,n perf_rdr_shift_out_U_leave
  1402. nop
  1403. ssm 0,0
  1404. nop
  1405. sync ; RDR 18 write sequence
  1406. ssm 0,0
  1407. STDIAG (18)
  1408. ssm 0,0
  1409. b,n perf_rdr_shift_out_U_leave
  1410. nop
  1411. ssm 0,0
  1412. nop
  1413. sync ; RDR 19 write sequence
  1414. ssm 0,0
  1415. STDIAG (19)
  1416. ssm 0,0
  1417. b,n perf_rdr_shift_out_U_leave
  1418. nop
  1419. ssm 0,0
  1420. nop
  1421. sync ; RDR 20 write sequence
  1422. ssm 0,0
  1423. STDIAG (20)
  1424. ssm 0,0
  1425. b,n perf_rdr_shift_out_U_leave
  1426. nop
  1427. ssm 0,0
  1428. nop
  1429. sync ; RDR 21 write sequence
  1430. ssm 0,0
  1431. STDIAG (21)
  1432. ssm 0,0
  1433. b,n perf_rdr_shift_out_U_leave
  1434. nop
  1435. ssm 0,0
  1436. nop
  1437. sync ; RDR 22 write sequence
  1438. ssm 0,0
  1439. STDIAG (22)
  1440. ssm 0,0
  1441. b,n perf_rdr_shift_out_U_leave
  1442. nop
  1443. ssm 0,0
  1444. nop
  1445. sync ; RDR 23 write sequence
  1446. ssm 0,0
  1447. STDIAG (23)
  1448. ssm 0,0
  1449. b,n perf_rdr_shift_out_U_leave
  1450. nop
  1451. ssm 0,0
  1452. nop
  1453. sync ; RDR 24 write sequence
  1454. ssm 0,0
  1455. STDIAG (24)
  1456. ssm 0,0
  1457. b,n perf_rdr_shift_out_U_leave
  1458. nop
  1459. ssm 0,0
  1460. nop
  1461. sync ; RDR 25 write sequence
  1462. ssm 0,0
  1463. STDIAG (25)
  1464. ssm 0,0
  1465. b,n perf_rdr_shift_out_U_leave
  1466. nop
  1467. ssm 0,0
  1468. nop
  1469. sync ; RDR 26 write sequence
  1470. ssm 0,0
  1471. STDIAG (26)
  1472. ssm 0,0
  1473. b,n perf_rdr_shift_out_U_leave
  1474. nop
  1475. ssm 0,0
  1476. nop
  1477. sync ; RDR 27 write sequence
  1478. ssm 0,0
  1479. STDIAG (27)
  1480. ssm 0,0
  1481. b,n perf_rdr_shift_out_U_leave
  1482. nop
  1483. ssm 0,0
  1484. nop
  1485. sync ; RDR 28 write sequence
  1486. ssm 0,0
  1487. STDIAG (28)
  1488. ssm 0,0
  1489. b,n perf_rdr_shift_out_U_leave
  1490. nop
  1491. ssm 0,0
  1492. nop
  1493. sync ; RDR 29 write sequence
  1494. ssm 0,0
  1495. STDIAG (29)
  1496. ssm 0,0
  1497. b,n perf_rdr_shift_out_U_leave
  1498. nop
  1499. ssm 0,0
  1500. nop
  1501. sync ; RDR 30 write sequence
  1502. ssm 0,0
  1503. STDIAG (30)
  1504. ssm 0,0
  1505. b,n perf_rdr_shift_out_U_leave
  1506. nop
  1507. ssm 0,0
  1508. nop
  1509. sync ; RDR 31 write sequence
  1510. ssm 0,0
  1511. STDIAG (31)
  1512. ssm 0,0
  1513. b,n perf_rdr_shift_out_U_leave
  1514. nop
  1515. ssm 0,0
  1516. nop
  1517. perf_rdr_shift_out_U_leave:
  1518. bve (%r2)
  1519. .exit
  1520. MTDIAG_2 (23) ; restore DR2
  1521. .procend
  1522. ENDPROC(perf_rdr_shift_out_U)