| 1 | /**************************************************************************** | 
|---|
| 2 |  | 
|---|
| 3 |                 THIS SOFTWARE IS NOT COPYRIGHTED | 
|---|
| 4 |  | 
|---|
| 5 |    HP offers the following for use in the public domain.  HP makes no | 
|---|
| 6 |    warranty with regard to the software or it's performance and the | 
|---|
| 7 |    user accepts the software "AS IS" with all faults. | 
|---|
| 8 |  | 
|---|
| 9 |    HP DISCLAIMS ANY WARRANTIES, EXPRESS OR IMPLIED, WITH REGARD | 
|---|
| 10 |    TO THIS SOFTWARE INCLUDING BUT NOT LIMITED TO THE WARRANTIES | 
|---|
| 11 |    OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 
|---|
| 12 |  | 
|---|
| 13 | ****************************************************************************/ | 
|---|
| 14 |         .space  $TEXT$ | 
|---|
| 15 |         .subspa $CODE$,access=0x2c | 
|---|
| 16 |  | 
|---|
| 17 | #if 1 | 
|---|
| 18 | #include        "diagnose.h" | 
|---|
| 19 | #endif | 
|---|
| 20 |  | 
|---|
| 21 | i13BREAK        .equ    0xa5a                   ; im13 field for specified functions | 
|---|
| 22 | i5REG           .equ    0x06                    ; Init registers | 
|---|
| 23 | i5BP            .equ    0x09                    ; GDB breakpoin | 
|---|
| 24 | i5PSW           .equ    0x0b                    ; Get PSW | 
|---|
| 25 | i5INLINE        .equ    0x0e                    ; Get INLINE | 
|---|
| 26 | R_gr0           .equ     0 | 
|---|
| 27 | R_gr1           .equ     4 | 
|---|
| 28 | R_gr2           .equ     8 | 
|---|
| 29 | R_gr3           .equ    12 | 
|---|
| 30 | R_gr4           .equ    16 | 
|---|
| 31 | R_gr5           .equ    20 | 
|---|
| 32 | R_gr6           .equ    24 | 
|---|
| 33 | R_gr7           .equ    28 | 
|---|
| 34 | R_gr8           .equ    32 | 
|---|
| 35 | R_gr9           .equ    36 | 
|---|
| 36 | R_gr10          .equ    40 | 
|---|
| 37 | R_gr11          .equ    44 | 
|---|
| 38 | R_gr12          .equ    48 | 
|---|
| 39 | R_gr13          .equ    52 | 
|---|
| 40 | R_gr14          .equ    56 | 
|---|
| 41 | R_gr15          .equ    60 | 
|---|
| 42 | R_gr16          .equ    64 | 
|---|
| 43 | R_gr17          .equ    68 | 
|---|
| 44 | R_gr18          .equ    72 | 
|---|
| 45 | R_gr19          .equ    76 | 
|---|
| 46 | R_gr20          .equ    80 | 
|---|
| 47 | R_gr21          .equ    84 | 
|---|
| 48 | R_gr22          .equ    88 | 
|---|
| 49 | R_gr23          .equ    92 | 
|---|
| 50 | R_gr24          .equ    96 | 
|---|
| 51 | R_gr25          .equ    100 | 
|---|
| 52 | R_gr26          .equ    104 | 
|---|
| 53 | R_gr27          .equ    108 | 
|---|
| 54 | R_gr28          .equ    112 | 
|---|
| 55 | R_gr29          .equ    116 | 
|---|
| 56 | R_gr30          .equ    120 | 
|---|
| 57 | R_gr31          .equ    124 | 
|---|
| 58 |  | 
|---|
| 59 | R_sr0           .equ    128 | 
|---|
| 60 | R_sr1           .equ    132 | 
|---|
| 61 | R_sr2           .equ    136 | 
|---|
| 62 | R_sr3           .equ    140 | 
|---|
| 63 | R_sr4           .equ    144 | 
|---|
| 64 | R_sr5           .equ    148 | 
|---|
| 65 | R_sr6           .equ    152 | 
|---|
| 66 | R_sr7           .equ    156 | 
|---|
| 67 |  | 
|---|
| 68 | R_cr0           .equ    160 | 
|---|
| 69 | R_cr1           .equ    164 | 
|---|
| 70 | R_cr2           .equ    168 | 
|---|
| 71 | R_cr3           .equ    172 | 
|---|
| 72 | R_cr4           .equ    176 | 
|---|
| 73 | R_cr5           .equ    180 | 
|---|
| 74 | R_cr6           .equ    184 | 
|---|
| 75 | R_cr7           .equ    188 | 
|---|
| 76 | R_cr8           .equ    192 | 
|---|
| 77 | R_cr9           .equ    196 | 
|---|
| 78 | R_cr10          .equ    200 | 
|---|
| 79 | R_cr11          .equ    204 | 
|---|
| 80 | R_cr12          .equ    208 | 
|---|
| 81 | R_cr13          .equ    212 | 
|---|
| 82 | R_cr14          .equ    216 | 
|---|
| 83 | R_cr15          .equ    220 | 
|---|
| 84 | R_cr16          .equ    224 | 
|---|
| 85 | R_cr17H         .equ    228 | 
|---|
| 86 | R_cr18H         .equ    232 | 
|---|
| 87 | R_cr19          .equ    236 | 
|---|
| 88 | R_cr20          .equ    240 | 
|---|
| 89 | R_cr21          .equ    244 | 
|---|
| 90 | R_cr22          .equ    248 | 
|---|
| 91 | R_cr23          .equ    252 | 
|---|
| 92 | R_cr24          .equ    256 | 
|---|
| 93 | R_cr25          .equ    260 | 
|---|
| 94 | R_cr26          .equ    264 | 
|---|
| 95 | R_cr27          .equ    268 | 
|---|
| 96 | R_cr28          .equ    272 | 
|---|
| 97 | R_cr29          .equ    276 | 
|---|
| 98 | R_cr30          .equ    280 | 
|---|
| 99 | R_cr31          .equ    284 | 
|---|
| 100 |  | 
|---|
| 101 | R_cr17T         .equ    288 | 
|---|
| 102 | R_cr18T         .equ    292 | 
|---|
| 103 |  | 
|---|
| 104 | R_cpu0          .equ    296 | 
|---|
| 105 |  | 
|---|
| 106 | R_SIZE          .equ    300 | 
|---|
| 107 |  | 
|---|
| 108 | min_stack       .equ     64 | 
|---|
| 109 |  | 
|---|
| 110 |         .import handle_exception | 
|---|
| 111 |         .import $global$, data | 
|---|
| 112 |         .IMPORT putnum, code | 
|---|
| 113 |         .IMPORT led_putnum, code | 
|---|
| 114 |         .IMPORT delay, code | 
|---|
| 115 |  | 
|---|
| 116 |         .export FICE | 
|---|
| 117 |         .export DEBUG_GO | 
|---|
| 118 |         .export DEBUG_SS | 
|---|
| 119 |         .export STUB_RESTORE | 
|---|
| 120 |  | 
|---|
| 121 |         .export save_regs | 
|---|
| 122 |         .export RegBlk | 
|---|
| 123 |         .export Exception_index | 
|---|
| 124 |  | 
|---|
| 125 | ;------------------------------------------------------------------------------- | 
|---|
| 126 |         .EXPORT breakpoint,ENTRY,ARGW0=GR,RTNVAL=GR | 
|---|
| 127 | breakpoint | 
|---|
| 128 |         .PROC | 
|---|
| 129 |         .CALLINFO CALLER,FRAME=128,SAVE_RP | 
|---|
| 130 |         .ENTRY | 
|---|
| 131 |  | 
|---|
| 132 |         stw     %r2,-20(0,%r30)                 ; stash the return pointer | 
|---|
| 133 |         ldo     128(%r30),%r30                  ; push up the stack pointer | 
|---|
| 134 |  | 
|---|
| 135 | ;;; debug | 
|---|
| 136 |         ldi     6, %r26 | 
|---|
| 137 |         bl,n    led_putnum,%r2 | 
|---|
| 138 |         nop | 
|---|
| 139 |         ldil    L'900000,%r26 | 
|---|
| 140 |         ldo     R'900000(%r26),%r26 | 
|---|
| 141 |         bl,n    delay,%r2 | 
|---|
| 142 |         nop | 
|---|
| 143 | ;;;  | 
|---|
| 144 |         break   i5INLINE,i13BREAK | 
|---|
| 145 | ;;; more debug | 
|---|
| 146 |         ldi     7, %r26 | 
|---|
| 147 |         bl,n    led_putnum,%r2 | 
|---|
| 148 |         nop | 
|---|
| 149 |         ldil    L'900000,%r26 | 
|---|
| 150 |         ldo     R'900000(%r26),%r26 | 
|---|
| 151 |         bl,n    delay,%r2 | 
|---|
| 152 |         nop | 
|---|
| 153 | ;;;  | 
|---|
| 154 |          | 
|---|
| 155 | FICE    fice    0(0,%r26)                       ; Flush the i cache entry | 
|---|
| 156 |         sync | 
|---|
| 157 |  | 
|---|
| 158 |         ldw     -148(0,%r30),%r2                ; retrieve the return pointer | 
|---|
| 159 |         ldo     -128(%r30),%r30                 ; reset the stack pointer | 
|---|
| 160 |         bv,n    0(%r2)                          ; return to caller | 
|---|
| 161 |         nop | 
|---|
| 162 |  | 
|---|
| 163 |         .EXIT | 
|---|
| 164 |         .PROCEND | 
|---|
| 165 |  | 
|---|
| 166 | ;------------------------------------------------------------------------------- | 
|---|
| 167 | DEBUG_GO | 
|---|
| 168 |         or,tr   %r0,%r0,%r10    ; if go, do not set R-bit to 1 | 
|---|
| 169 |  | 
|---|
| 170 | DEBUG_SS | 
|---|
| 171 |         ldi     1,%r10          ; else set R-bit to 1 | 
|---|
| 172 |  | 
|---|
| 173 | DEBUG_EXEC | 
|---|
| 174 |  | 
|---|
| 175 |         bl      DGO_0,%r8                       ; r8 points to register block | 
|---|
| 176 |         addil   L%RegBlk-DGO_0,%r8 | 
|---|
| 177 | DGO_0 | 
|---|
| 178 |         ldo     R%RegBlk-DGO_0(%r1),%r8 | 
|---|
| 179 |  | 
|---|
| 180 | ; load space registers | 
|---|
| 181 |  | 
|---|
| 182 |         ldw     R_sr0(%r8),%r1 | 
|---|
| 183 |         mtsp    %r1,%sr0 | 
|---|
| 184 |         ldw     R_sr1(%r8),%r1 | 
|---|
| 185 |         mtsp    %r1,%sr1 | 
|---|
| 186 |         ldw     R_sr2(%r8),%r1 | 
|---|
| 187 |         mtsp    %r1,%sr2 | 
|---|
| 188 |         ldw     R_sr3(%r8),%r1 | 
|---|
| 189 |         mtsp    %r1,%sr3 | 
|---|
| 190 |         ldw     R_sr4(%r8),%r1 | 
|---|
| 191 |         mtsp    %r1,%sr4 | 
|---|
| 192 |         ldw     R_sr5(%r8),%r1 | 
|---|
| 193 |         mtsp    %r1,%sr5 | 
|---|
| 194 |         ldw     R_sr6(%r8),%r1 | 
|---|
| 195 |         mtsp    %r1,%sr6 | 
|---|
| 196 |         ldw     R_sr7(%r8),%r1 | 
|---|
| 197 |         mtsp    %r1,%sr7 | 
|---|
| 198 |  | 
|---|
| 199 | ; clear Q-bit for rfi | 
|---|
| 200 |  | 
|---|
| 201 |         rsm     0x08,%r0 | 
|---|
| 202 |  | 
|---|
| 203 | ; load control registers | 
|---|
| 204 |  | 
|---|
| 205 |         ldw     R_cr0(%r8),%r1 | 
|---|
| 206 |         or,=    %r10,%r0,%r0            ; if single step | 
|---|
| 207 |         copy    %r0,%r1                 ;   set %cr0 to 0 | 
|---|
| 208 |         mtctl   %r1,%cr0 | 
|---|
| 209 |         ldw     R_cr8(%r8),%r1 | 
|---|
| 210 |         mtctl   %r1,%cr8 | 
|---|
| 211 |         ldw     R_cr9(%r8),%r1 | 
|---|
| 212 |         mtctl   %r1,%cr9 | 
|---|
| 213 |         ldw     R_cr10(%r8),%r1 | 
|---|
| 214 |         mtctl   %r1,%cr10 | 
|---|
| 215 |         ldw     R_cr11(%r8),%r1 | 
|---|
| 216 |         mtctl   %r1,%cr11 | 
|---|
| 217 |         ldw     R_cr12(%r8),%r1 | 
|---|
| 218 |         mtctl   %r1,%cr12 | 
|---|
| 219 |         ldw     R_cr13(%r8),%r1 | 
|---|
| 220 |         mtctl   %r1,%cr13 | 
|---|
| 221 |         ldw     R_cr14(%r8),%r1 | 
|---|
| 222 |         mtctl   %r1,%cr14 | 
|---|
| 223 |         ldw     R_cr15(%r8),%r1 | 
|---|
| 224 |         mtctl   %r1,%cr15 | 
|---|
| 225 |         ldw     R_cr16(%r8),%r1 | 
|---|
| 226 |         mtctl   %r1,%cr16 | 
|---|
| 227 |         ldw     R_cr17H(%r8),%r1        ; load iiasq.head | 
|---|
| 228 |         mtctl   %r1,%cr17 | 
|---|
| 229 |         ldw     R_cr18H(%r8),%r1        ; load iiaoq.head | 
|---|
| 230 |         mtctl   %r1,%cr18 | 
|---|
| 231 |         ldw     R_cr17T(%r8),%r1        ; load iiasq.tail | 
|---|
| 232 |         mtctl   %r1,%cr17 | 
|---|
| 233 |         ldw     R_cr18T(%r8),%r1        ; load iiaoq.tail | 
|---|
| 234 |         mtctl   %r1,%cr18 | 
|---|
| 235 |         ldw     R_cr19(%r8),%r1 | 
|---|
| 236 |         mtctl   %r1,%cr19 | 
|---|
| 237 |         ldw     R_cr20(%r8),%r1 | 
|---|
| 238 |         mtctl   %r1,%cr20 | 
|---|
| 239 |         ldw     R_cr21(%r8),%r1 | 
|---|
| 240 |         mtctl   %r1,%cr21 | 
|---|
| 241 |         ldw     R_cr22(%r8),%r1 | 
|---|
| 242 |         dep     %r10,27,1,%r1           ; set R-bit if applicable | 
|---|
| 243 |         mtctl   %r1,%cr22 | 
|---|
| 244 |         ldw     R_cr23(%r8),%r1 | 
|---|
| 245 |         mtctl   %r1,%cr23 | 
|---|
| 246 |         ldw     R_cr24(%r8),%r1 | 
|---|
| 247 |         mtctl   %r1,%cr24 | 
|---|
| 248 |         ldw     R_cr25(%r8),%r1 | 
|---|
| 249 |         mtctl   %r1,%cr25 | 
|---|
| 250 |         ldw     R_cr26(%r8),%r1 | 
|---|
| 251 |         mtctl   %r1,%cr26 | 
|---|
| 252 |         ldw     R_cr27(%r8),%r1 | 
|---|
| 253 |         mtctl   %r1,%cr27 | 
|---|
| 254 |         ldw     R_cr28(%r8),%r1 | 
|---|
| 255 |         mtctl   %r1,%cr28 | 
|---|
| 256 |         ldw     R_cr29(%r8),%r1 | 
|---|
| 257 |         mtctl   %r1,%cr29 | 
|---|
| 258 |         ldw     R_cr30(%r8),%r1 | 
|---|
| 259 |         mtctl   %r1,%cr30 | 
|---|
| 260 |         ldw     R_cr31(%r8),%r1 | 
|---|
| 261 |         mtctl   %r1,%cr31 | 
|---|
| 262 |  | 
|---|
| 263 | ; load diagnose registers | 
|---|
| 264 |  | 
|---|
| 265 |         ldw     R_cpu0(%r8),%r1 | 
|---|
| 266 |         ldil    L%CPU0_MASK,%r2 | 
|---|
| 267 |         ldo     R%CPU0_MASK(%r2),%r2 | 
|---|
| 268 |         xor     %r1,%r2,%r1             ; xor the read/clear bits | 
|---|
| 269 |         nop | 
|---|
| 270 |         mtcpu   %r1,0 | 
|---|
| 271 |         mtcpu   %r1,0 | 
|---|
| 272 |  | 
|---|
| 273 | ; load general registers | 
|---|
| 274 |  | 
|---|
| 275 |         ldw     R_gr1(%r8),%r1 | 
|---|
| 276 |         ldw     R_gr2(%r8),%r2 | 
|---|
| 277 |         ldw     R_gr3(%r8),%r3 | 
|---|
| 278 |         ldw     R_gr4(%r8),%r4 | 
|---|
| 279 |         ldw     R_gr5(%r8),%r5 | 
|---|
| 280 |         ldw     R_gr6(%r8),%r6 | 
|---|
| 281 |         ldw     R_gr7(%r8),%r7 | 
|---|
| 282 |         ldw     R_gr9(%r8),%r9 | 
|---|
| 283 |         ldw     R_gr10(%r8),%r10 | 
|---|
| 284 |         ldw     R_gr11(%r8),%r11 | 
|---|
| 285 |         ldw     R_gr12(%r8),%r12 | 
|---|
| 286 |         ldw     R_gr13(%r8),%r13 | 
|---|
| 287 |         ldw     R_gr14(%r8),%r14 | 
|---|
| 288 |         ldw     R_gr15(%r8),%r15 | 
|---|
| 289 |         ldw     R_gr16(%r8),%r16 | 
|---|
| 290 |         ldw     R_gr17(%r8),%r17 | 
|---|
| 291 |         ldw     R_gr18(%r8),%r18 | 
|---|
| 292 |         ldw     R_gr19(%r8),%r19 | 
|---|
| 293 |         ldw     R_gr20(%r8),%r20 | 
|---|
| 294 |         ldw     R_gr21(%r8),%r21 | 
|---|
| 295 |         ldw     R_gr22(%r8),%r22 | 
|---|
| 296 |         ldw     R_gr23(%r8),%r23 | 
|---|
| 297 |         ldw     R_gr24(%r8),%r24 | 
|---|
| 298 |         ldw     R_gr25(%r8),%r25 | 
|---|
| 299 |         ldw     R_gr26(%r8),%r26 | 
|---|
| 300 |         ldw     R_gr27(%r8),%r27 | 
|---|
| 301 |         ldw     R_gr28(%r8),%r28 | 
|---|
| 302 |         ldw     R_gr29(%r8),%r29 | 
|---|
| 303 |         ldw     R_gr30(%r8),%r30 | 
|---|
| 304 |         ldw     R_gr31(%r8),%r31 | 
|---|
| 305 |         ldw     R_gr8(%r8),%r8 | 
|---|
| 306 |  | 
|---|
| 307 | ; execute user program | 
|---|
| 308 |  | 
|---|
| 309 |         nop | 
|---|
| 310 |         rfi             ; switch to user code | 
|---|
| 311 |         nop | 
|---|
| 312 |  | 
|---|
| 313 | ;------------------------------------------------------------------------------- | 
|---|
| 314 |  | 
|---|
| 315 | STUB_RESTORE | 
|---|
| 316 |         copy    %r1,%r9 ; save exception index | 
|---|
| 317 |         bl      SR_00,%r8 | 
|---|
| 318 |         addil   L%Exception_index-SR_00,%r8 | 
|---|
| 319 | SR_00 | 
|---|
| 320 |         ldo     R%Exception_index-SR_00(%r1),%r8 | 
|---|
| 321 |         stw     %r9,(%r8) | 
|---|
| 322 |  | 
|---|
| 323 |         bl      save_regs,%r25 | 
|---|
| 324 |         nop | 
|---|
| 325 |          | 
|---|
| 326 | #ifdef  DEBUG_DEBUGGER1 | 
|---|
| 327 |         stwm    %r1,8(%sp) | 
|---|
| 328 |         bl      putc,%rp | 
|---|
| 329 |         ldi     CR,%arg0 | 
|---|
| 330 |         bl      putc,%rp | 
|---|
| 331 |         ldi     LF,%arg0 | 
|---|
| 332 |         bl      printit,%mrp | 
|---|
| 333 |         mfctl   %pcoq,%arg0 | 
|---|
| 334 |  | 
|---|
| 335 |         mfctl   %pcoq,%r1 | 
|---|
| 336 |         mtctl   %r1,%pcoq | 
|---|
| 337 |         mfctl   %pcoq,%arg0 | 
|---|
| 338 |         bl      printit,%mrp | 
|---|
| 339 |         mtctl   %arg0,%pcoq | 
|---|
| 340 |  | 
|---|
| 341 |         bl      printit,%mrp | 
|---|
| 342 |         ldw     -8(%sp),%arg0 | 
|---|
| 343 |  | 
|---|
| 344 |         ldwm    -8(%sp),%r1 | 
|---|
| 345 | #endif | 
|---|
| 346 |  | 
|---|
| 347 | #ifdef  DEBUG_DEBUGGER2 | 
|---|
| 348 |         stwm    %r1,8(%sp) | 
|---|
| 349 |         bl      putc,%rp | 
|---|
| 350 |         ldi     LF,%arg0 | 
|---|
| 351 |         ldwm    -8(%sp),%r1 | 
|---|
| 352 | #endif | 
|---|
| 353 |  | 
|---|
| 354 | #ifdef  DEBUG_DEBUGGER3 | 
|---|
| 355 |         bl      printit,%mrp | 
|---|
| 356 |         copy    iptr,%arg0 | 
|---|
| 357 |         bl      printit,%mrp | 
|---|
| 358 |         copy    rstack,%arg0 | 
|---|
| 359 |         bl      printit,%mrp | 
|---|
| 360 |         copy    gspace,%arg0 | 
|---|
| 361 |         bl      printit,%mrp | 
|---|
| 362 |         copy    dstack,%arg0 | 
|---|
| 363 |         bl      printit,%mrp | 
|---|
| 364 |         copy    nextptr,%arg0 | 
|---|
| 365 |         bl      printit,%mrp | 
|---|
| 366 |         copy    %dp,%arg0 | 
|---|
| 367 |         bl      printit,%mrp | 
|---|
| 368 |         copy    %sp,%arg0 | 
|---|
| 369 |         bl      printit,%mrp | 
|---|
| 370 |         mfctl   %rctr,%arg0 | 
|---|
| 371 |         bl      printit,%mrp | 
|---|
| 372 |         mfctl   %iva,%arg0 | 
|---|
| 373 |         bl      printit,%mrp | 
|---|
| 374 |         mfctl   %eiem,%arg0 | 
|---|
| 375 |         bl      printit,%mrp | 
|---|
| 376 |         mfctl   %ipsw,%arg0 | 
|---|
| 377 |         bl      printit,%mrp | 
|---|
| 378 |         copy    %r0,%arg0 | 
|---|
| 379 | #endif | 
|---|
| 380 |         bl      SR_1,%sp | 
|---|
| 381 |         addil   L%Stub_stack-SR_1,%sp | 
|---|
| 382 | SR_1 | 
|---|
| 383 |         ldo     R%Stub_stack-SR_1(%r1),%sp      ; set the stack pointer | 
|---|
| 384 |  | 
|---|
| 385 |         bl      SR_2,%arg0 | 
|---|
| 386 |         addil   L%RegBlk-SR_2,%arg0 | 
|---|
| 387 | SR_2 | 
|---|
| 388 |         ldo     R%RegBlk-SR_2(%r1),%arg0        ; set arg0 (save register area) | 
|---|
| 389 |  | 
|---|
| 390 |         bl      SR_3,%arg1 | 
|---|
| 391 |         addil   L%Exception_index-SR_3,%arg1    ; set arg1 address | 
|---|
| 392 | SR_3 | 
|---|
| 393 |         ldo     R%Exception_index-SR_3(%r1),%arg1       ; set arg1 address | 
|---|
| 394 |  | 
|---|
| 395 |         addi    min_stack,%sp,%sp               ; allocate min stack frame | 
|---|
| 396 |  | 
|---|
| 397 |         bl      handle_exception,%r2 | 
|---|
| 398 |         ldw     0(%arg1),%arg1                  ; load arg1 | 
|---|
| 399 |         addi    -min_stack,%sp,%sp              ; de allocate min stack frame | 
|---|
| 400 |  | 
|---|
| 401 |         b       DEBUG_EXEC                      ;  | 
|---|
| 402 |         copy    %r28,%r10        | 
|---|
| 403 | ;------------------------------------------------------------------------------- | 
|---|
| 404 |  | 
|---|
| 405 | save_regs       ; return address is in %r25 | 
|---|
| 406 |  | 
|---|
| 407 |         bl      SR_0,%r1                        ; r1 points to Register block | 
|---|
| 408 |         addil   L%RegBlk-SR_0,%r1 | 
|---|
| 409 | SR_0 | 
|---|
| 410 |         ldo     R%RegBlk-SR_0(%r1),%r1 | 
|---|
| 411 |  | 
|---|
| 412 | ; save general registers | 
|---|
| 413 |  | 
|---|
| 414 |         stw     %r0,R_gr0(%r1) | 
|---|
| 415 |         ; don't store %r1 yet | 
|---|
| 416 |         stw     %r2,R_gr2(%r1) | 
|---|
| 417 |         stw     %r3,R_gr3(%r1) | 
|---|
| 418 |         stw     %r4,R_gr4(%r1) | 
|---|
| 419 |         stw     %r5,R_gr5(%r1) | 
|---|
| 420 |         stw     %r6,R_gr6(%r1) | 
|---|
| 421 |         stw     %r7,R_gr7(%r1) | 
|---|
| 422 |         ; don't store %r8 yet | 
|---|
| 423 |         ; don't store %r9 yet | 
|---|
| 424 |         stw     %r10,R_gr10(%r1) | 
|---|
| 425 |         stw     %r11,R_gr11(%r1) | 
|---|
| 426 |         stw     %r12,R_gr12(%r1) | 
|---|
| 427 |         stw     %r13,R_gr13(%r1) | 
|---|
| 428 |         stw     %r14,R_gr14(%r1) | 
|---|
| 429 |         stw     %r15,R_gr15(%r1) | 
|---|
| 430 |         ; don't store %r16 yet | 
|---|
| 431 |         ; don't store %r17 yet | 
|---|
| 432 |         stw     %r18,R_gr18(%r1) | 
|---|
| 433 |         stw     %r19,R_gr19(%r1) | 
|---|
| 434 |         stw     %r20,R_gr20(%r1) | 
|---|
| 435 |         stw     %r21,R_gr21(%r1) | 
|---|
| 436 |         stw     %r22,R_gr22(%r1) | 
|---|
| 437 |         stw     %r23,R_gr23(%r1) | 
|---|
| 438 |         ; don't store %r24 yet | 
|---|
| 439 |         ; don't store %r25 yet | 
|---|
| 440 |         stw     %r26,R_gr26(%r1) | 
|---|
| 441 |         stw     %r27,R_gr27(%r1) | 
|---|
| 442 |         stw     %r28,R_gr28(%r1) | 
|---|
| 443 |         stw     %r29,R_gr29(%r1) | 
|---|
| 444 |         stw     %r30,R_gr30(%r1) | 
|---|
| 445 |         stw     %r31,R_gr31(%r1) | 
|---|
| 446 |  | 
|---|
| 447 | ; restore general registers from shadow registers and save them | 
|---|
| 448 |  | 
|---|
| 449 |         copy    %r1,%r10        ; hold Register block pointer | 
|---|
| 450 |         copy    %r25,%rp        ; hold return pointer | 
|---|
| 451 |         shdw_gr | 
|---|
| 452 |         shdw_gr | 
|---|
| 453 |         stw     %r1,R_gr1(%r10) | 
|---|
| 454 |         stw     %r8,R_gr8(%r10) | 
|---|
| 455 |         stw     %r9,R_gr9(%r10) | 
|---|
| 456 |         stw     %r16,R_gr16(%r10) | 
|---|
| 457 |         stw     %r17,R_gr17(%r10) | 
|---|
| 458 |         stw     %r24,R_gr24(%r10) | 
|---|
| 459 |         stw     %r25,R_gr25(%r10) | 
|---|
| 460 |  | 
|---|
| 461 | ; save control registers | 
|---|
| 462 |  | 
|---|
| 463 |         mfctl   %cr0,%r1 | 
|---|
| 464 |         stw     %r1,R_cr0(%r10) | 
|---|
| 465 |         stw     %r0,R_cr1(%r10) | 
|---|
| 466 |         stw     %r0,R_cr2(%r10) | 
|---|
| 467 |         stw     %r0,R_cr3(%r10) | 
|---|
| 468 |         stw     %r0,R_cr4(%r10) | 
|---|
| 469 |         stw     %r0,R_cr5(%r10) | 
|---|
| 470 |         stw     %r0,R_cr6(%r10) | 
|---|
| 471 |         stw     %r0,R_cr7(%r10) | 
|---|
| 472 |         mfctl   %cr8,%r1 | 
|---|
| 473 |         stw     %r1,R_cr8(%r10) | 
|---|
| 474 |         mfctl   %cr9,%r1 | 
|---|
| 475 |         stw     %r1,R_cr9(%r10) | 
|---|
| 476 |         mfctl   %cr10,%r1 | 
|---|
| 477 |         stw     %r1,R_cr10(%r10) | 
|---|
| 478 |         mfctl   %cr11,%r1 | 
|---|
| 479 |         stw     %r1,R_cr11(%r10) | 
|---|
| 480 |         mfctl   %cr12,%r1 | 
|---|
| 481 |         stw     %r1,R_cr12(%r10) | 
|---|
| 482 |         mfctl   %cr13,%r1 | 
|---|
| 483 |         stw     %r1,R_cr13(%r10) | 
|---|
| 484 |         mfctl   %cr14,%r1 | 
|---|
| 485 |         stw     %r1,R_cr14(%r10) | 
|---|
| 486 |         mfctl   %cr15,%r1 | 
|---|
| 487 |         stw     %r1,R_cr15(%r10) | 
|---|
| 488 |         mfctl   %cr16,%r1 | 
|---|
| 489 |         stw     %r1,R_cr16(%r10) | 
|---|
| 490 |         mfctl   %cr17,%r1 | 
|---|
| 491 |         stw     %r1,R_cr17H(%r10) | 
|---|
| 492 |         mtctl   %r1,%cr17 | 
|---|
| 493 |         mfctl   %cr17,%r1 | 
|---|
| 494 |         stw     %r1,R_cr17T(%r10) | 
|---|
| 495 |         mtctl   %r1,%cr17 | 
|---|
| 496 |         mfctl   %cr18,%r1 | 
|---|
| 497 |         stw     %r1,R_cr18H(%r10) | 
|---|
| 498 |         mtctl   %r1,%cr18 | 
|---|
| 499 |         mfctl   %cr18,%r1 | 
|---|
| 500 |         stw     %r1,R_cr18T(%r10) | 
|---|
| 501 |         mtctl   %r1,%cr18 | 
|---|
| 502 |         mfctl   %cr19,%r1 | 
|---|
| 503 |         stw     %r1,R_cr19(%r10) | 
|---|
| 504 |         mfctl   %cr20,%r1 | 
|---|
| 505 |         stw     %r1,R_cr20(%r10) | 
|---|
| 506 |         mfctl   %cr21,%r1 | 
|---|
| 507 |         stw     %r1,R_cr21(%r10) | 
|---|
| 508 |         mfctl   %cr22,%r1 | 
|---|
| 509 |         stw     %r1,R_cr22(%r10) | 
|---|
| 510 |         mfctl   %cr23,%r1 | 
|---|
| 511 |         stw     %r1,R_cr23(%r10) | 
|---|
| 512 |         mfctl   %cr24,%r1 | 
|---|
| 513 |         stw     %r1,R_cr24(%r10) | 
|---|
| 514 |         mfctl   %cr25,%r1 | 
|---|
| 515 |         stw     %r1,R_cr25(%r10) | 
|---|
| 516 |         mfctl   %cr26,%r1 | 
|---|
| 517 |         stw     %r1,R_cr26(%r10) | 
|---|
| 518 |         mfctl   %cr27,%r1 | 
|---|
| 519 |         stw     %r1,R_cr27(%r10) | 
|---|
| 520 |         mfctl   %cr28,%r1 | 
|---|
| 521 |         stw     %r1,R_cr28(%r10) | 
|---|
| 522 |         mfctl   %cr29,%r1 | 
|---|
| 523 |         stw     %r1,R_cr29(%r10) | 
|---|
| 524 |         mfctl   %cr30,%r1 | 
|---|
| 525 |         stw     %r1,R_cr30(%r10) | 
|---|
| 526 |         mfctl   %cr31,%r1 | 
|---|
| 527 |         stw     %r1,R_cr31(%r10) | 
|---|
| 528 |  | 
|---|
| 529 | ; save diagnose registers | 
|---|
| 530 |  | 
|---|
| 531 |         mfcpu_c 0,%r1 | 
|---|
| 532 |         mfcpu_c 0,%r1 | 
|---|
| 533 |         stw     %r1,R_cpu0(%r10) | 
|---|
| 534 |  | 
|---|
| 535 | ; save space registers | 
|---|
| 536 |  | 
|---|
| 537 |         mfsp    %sr0,%r1 | 
|---|
| 538 |         stw     %r1,R_sr0(%r10) | 
|---|
| 539 |         mfsp    %sr1,%r1 | 
|---|
| 540 |         stw     %r1,R_sr1(%r10) | 
|---|
| 541 |         mfsp    %sr2,%r1 | 
|---|
| 542 |         stw     %r1,R_sr2(%r10) | 
|---|
| 543 |         mfsp    %sr3,%r1 | 
|---|
| 544 |         stw     %r1,R_sr3(%r10) | 
|---|
| 545 |         mfsp    %sr4,%r1 | 
|---|
| 546 |         stw     %r1,R_sr4(%r10) | 
|---|
| 547 |         mfsp    %sr5,%r1 | 
|---|
| 548 |         stw     %r1,R_sr5(%r10) | 
|---|
| 549 |         mfsp    %sr6,%r1 | 
|---|
| 550 |         stw     %r1,R_sr6(%r10) | 
|---|
| 551 |         mfsp    %sr7,%r1 | 
|---|
| 552 |         bv      (%rp) | 
|---|
| 553 |         stw     %r1,R_sr7(%r10) | 
|---|
| 554 |  | 
|---|
| 555 | #ifdef  DEBUG_DEBUGGER | 
|---|
| 556 | ;------------------------------------------------------------------------------- | 
|---|
| 557 | printit | 
|---|
| 558 |         mtctl   %rp,%tr0 | 
|---|
| 559 |         mtctl   %r1,%tr1 | 
|---|
| 560 |         bl      putnum,%rp | 
|---|
| 561 |         copy    %rp,%arg0 | 
|---|
| 562 |  | 
|---|
| 563 |         mtctl   %mrp,%tr2 | 
|---|
| 564 |         bl      putc,%rp | 
|---|
| 565 |         ldi     CR,%arg0 | 
|---|
| 566 |         bl      putc,%rp | 
|---|
| 567 |         ldi     LF,%arg0 | 
|---|
| 568 |         mfctl   %tr2,%mrp | 
|---|
| 569 |         mfctl   %tr1,%r1 | 
|---|
| 570 |         bv      (%mrp) | 
|---|
| 571 |         mfctl   %tr0,%rp | 
|---|
| 572 | #endif | 
|---|
| 573 |         .space  $PRIVATE$ | 
|---|
| 574 |         .subspa $DATA$,align=4,access=0x1f | 
|---|
| 575 |  | 
|---|
| 576 | Exception_index | 
|---|
| 577 |         .word   0 | 
|---|
| 578 |          | 
|---|
| 579 | RegBlk | 
|---|
| 580 |         .block  R_SIZE          ; register block | 
|---|
| 581 |  | 
|---|
| 582 | Stub_stack | 
|---|
| 583 |         .block  1024 | 
|---|
| 584 |  | 
|---|
| 585 |         .end | 
|---|