perf_asm.S 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692
  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)