perf_asm.S 26 KB

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