Annotation of 42BSD/sys/GENERIC/locore.c, revision 1.1

1.1     ! root        1: #ifdef LOCORE
        !             2: #define        P_LINK 0
        !             3: #define        P_RLINK 4
        !             4: #define        P_XLINK 100
        !             5: #define        P_ADDR 8
        !             6: #define        P_PRI 13
        !             7: #define        P_STAT 15
        !             8: #define        P_WCHAN 88
        !             9: #define        P_TSIZE 60
        !            10: #define        P_SSIZE 68
        !            11: #define        P_P0BR 96
        !            12: #define        P_SZPT 58
        !            13: #define        P_TEXTP 92
        !            14: #define        P_FLAG 36
        !            15: #define        SSLEEP 1
        !            16: #define        SRUN 3
        !            17: #define        UBA_BRRVR 48
        !            18: #define        UH_UBA 0
        !            19: #define        UH_VEC 8
        !            20: #define        UH_SIZE 52
        !            21: #define        RP_FLAG 12
        !            22: #define        X_CADDR 56
        !            23: #define        V_SWTCH 0
        !            24: #define        V_TRAP 4
        !            25: #define        V_SYSCALL 8
        !            26: #define        V_INTR 12
        !            27: #define        V_PDMA 16
        !            28: #define        V_FAULTS 88
        !            29: #define        V_PGREC 48
        !            30: #define        V_FASTPGREC 108
        !            31: #define        UPAGES 8
        !            32: #define        CLSIZE 2
        !            33: #define        SYSPTSIZE 3584
        !            34: #define        USRPTSIZE 1024
        !            35: #define        MSGBUFPTECNT 8
        !            36: #define        NMBCLUSTERS 256
        !            37: #define        U_PROCP 124
        !            38: #define        U_RU 1296
        !            39: #define        RU_MINFLT 32
        !            40: #else
        !            41: asm(".set      U_ARG,388");
        !            42: asm(".set      U_QSAVE,-1881318947");
        !            43: #endif
        !            44: /*     rpb.s   6.1     83/08/01        */
        !            45: 
        !            46: /*
        !            47:  * This has to get loaded first (physical 0) as 780 memory restart rom
        !            48:  * only looks for rpb on a 64K page boundary (doc isn't wrong,
        !            49:  * it never says what size "page boundary" rpb has to be on).
        !            50:  */
        !            51:        .globl  _rpb
        !            52: _rpb:
        !            53:        .space  508
        !            54: erpb:
        !            55:        .space  4
        !            56: /*     scb.s   6.1     83/08/11        */
        !            57: 
        !            58: #include "uba.h"
        !            59: 
        !            60: /*
        !            61:  * System control block
        !            62:  */
        !            63:        .set    INTSTK,1        # handle this interrupt on the interrupt stack
        !            64:        .set    HALT,3          # halt if this interrupt occurs
        !            65: 
        !            66: _scb:  .globl  _scb
        !            67: 
        !            68: #define        STRAY   .long   _Xstray+INTSTK
        !            69: #define        STRAY8  STRAY;STRAY;STRAY;STRAY;STRAY;STRAY;STRAY;STRAY
        !            70: #define        STRAY15 STRAY;STRAY;STRAY;STRAY;STRAY;STRAY;STRAY;STRAY8
        !            71: #define        KS(a)   .long   _X/**/a
        !            72: #define        IS(a)   .long   _X/**/a+INTSTK
        !            73: #define        STOP(a) .long   _X/**/a+HALT
        !            74: 
        !            75: /* 000 */      STRAY;          IS(machcheck);  IS(kspnotval);  STOP(powfail);
        !            76: /* 010 */      KS(privinflt);  KS(xfcflt);     KS(resopflt);   KS(resadflt);
        !            77: /* 020 */      KS(protflt);    KS(transflt);   KS(tracep);     KS(bptflt);
        !            78: /* 030 */      KS(compatflt);  KS(arithtrap);  STRAY;          STRAY;
        !            79: /* 040 */      KS(syscall);    KS(chme);       KS(chms);       KS(chmu);
        !            80: /* 050 */      STRAY;          IS(cmrd);       STRAY;          STRAY;
        !            81: /* 060 */      IS(wtime);      STRAY;          STRAY;          STRAY;
        !            82: /* 070 */      STRAY;          STRAY;          STRAY;          STRAY;
        !            83: /* 080 */      STRAY;          STRAY;          KS(astflt);     STRAY;
        !            84: /* 090 */      STRAY;          STRAY;          STRAY;          STRAY;
        !            85: /* 0a0 */      IS(softclock);  STRAY;          STRAY;          STRAY;
        !            86: /* 0b0 */      IS(netintr);    STRAY;          STRAY;          STRAY;
        !            87: /* 0c0 */      IS(hardclock);  STRAY;          STRAY;          STRAY;
        !            88: /* 0d0 */      STRAY;          STRAY;          STRAY;          STRAY;
        !            89: /* 0e0 */      STRAY;          STRAY;          STRAY;          STRAY;
        !            90: /* 0f0 */      IS(consdin);    IS(consdout);   IS(cnrint);     IS(cnxint);
        !            91: /* 100 */      IS(nexzvec); STRAY15;           /* ipl 0x14, nexus 0-15 */
        !            92: /* 140 */      IS(nexzvec); STRAY15;           /* ipl 0x15, nexus 0-15 */
        !            93: /* 180 */      IS(nexzvec); STRAY15;           /* ipl 0x16, nexus 0-15 */
        !            94: /* 1c0 */      IS(nexzvec); STRAY15;           /* ipl 0x17, nexus 0-15 */
        !            95: 
        !            96:        .globl  _UNIvec
        !            97: _UNIvec:       .space  512             # 750 unibus intr vector
        !            98:                                        # 1st UBA jump table on 780's
        !            99: #if NUBA > 1
        !           100:        .globl  _UNI1vec
        !           101: _UNI1vec:      .space  512             # 750 second unibus intr vector
        !           102:                                        # 2nd UBA jump table on 780's
        !           103: #endif
        !           104: /*     locore.s        6.3     83/08/12        */
        !           105: 
        !           106: #include "../machine/psl.h"
        !           107: #include "../machine/pte.h"
        !           108: 
        !           109: #include "../h/errno.h"
        !           110: 
        !           111: #include "../vax/mtpr.h"
        !           112: #include "../vax/trap.h"
        !           113: #include "../vax/cpu.h"
        !           114: #include "../vax/nexus.h"
        !           115: #include "../vax/cons.h"
        !           116: #include "../vax/clock.h"
        !           117: #include "../vaxuba/ubareg.h"
        !           118: 
        !           119: #include "dh.h"
        !           120: #include "dz.h"
        !           121: #include "uu.h"
        !           122: #include "ps.h"
        !           123: #include "mba.h"
        !           124: 
        !           125:        .set    HIGH,0x1f       # mask for total disable
        !           126:        .set    MCKVEC,4        # offset into scb of machine check vector
        !           127:        .set    NBPG,512
        !           128:        .set    PGSHIFT,9
        !           129: 
        !           130:        .set    NISP,3          # number of interrupt stack pages
        !           131: 
        !           132: /*
        !           133:  * User structure is UPAGES at top of user space.
        !           134:  */
        !           135:        .globl  _u
        !           136:        .set    _u,0x80000000 - UPAGES*NBPG
        !           137: 
        !           138:        .globl  _intstack
        !           139: _intstack:
        !           140:        .space  NISP*NBPG
        !           141: eintstack:
        !           142: 
        !           143: /*
        !           144:  * Do a dump.
        !           145:  * Called by auto-restart.
        !           146:  * May be called manually.
        !           147:  */
        !           148:        .align  2
        !           149:        .globl  _doadump
        !           150: _doadump:
        !           151:        nop; nop                                # .word 0x0101
        !           152: #define        _rpbmap _Sysmap                         # rpb, scb, UNI*vec, istack*4
        !           153:        bicl2   $PG_PROT,_rpbmap
        !           154:        bisl2   $PG_KW,_rpbmap
        !           155:        tstl    _rpb+RP_FLAG                    # dump only once!
        !           156:        bneq    1f
        !           157:        incl    _rpb+RP_FLAG
        !           158:        mtpr    $0,$TBIA
        !           159:        movl    sp,erpb
        !           160:        movab   erpb,sp
        !           161:        mfpr    $PCBB,-(sp)
        !           162:        mfpr    $MAPEN,-(sp)
        !           163:        mfpr    $IPL,-(sp)
        !           164:        mtpr    $0,$MAPEN
        !           165:        mtpr    $HIGH,$IPL
        !           166:        pushr   $0x3fff
        !           167:        calls   $0,_dumpsys
        !           168: 1:
        !           169:        mfpr    $TXCS,r0
        !           170:        bitl    $TXCS_RDY,r0
        !           171:        beql    1b
        !           172:        mtpr    $TXDB_BOOT,$TXDB
        !           173:        halt
        !           174: 
        !           175: /*
        !           176:  * Interrupt vector routines
        !           177:  */ 
        !           178:        .globl  _waittime
        !           179: 
        !           180: #define        SCBVEC(name)    .align 2; .globl _X/**/name; _X/**/name
        !           181: #define        PANIC(msg)      clrl _waittime; pushab 1f; \
        !           182:                        calls $1,_panic; 1: .asciz msg
        !           183: #define        PRINTF(n,msg)   pushab 1f; calls $n+1,_printf; MSG(msg)
        !           184: #define        MSG(msg)        .data; 1: .asciz msg; .text
        !           185: #define        PUSHR           pushr $0x3f
        !           186: #define        POPR            popr $0x3f
        !           187: 
        !           188: SCBVEC(machcheck):
        !           189:        PUSHR; pushab 6*4(sp); calls $1,_machinecheck; POPR;
        !           190:        addl2 (sp)+,sp; rei
        !           191: SCBVEC(kspnotval):
        !           192:        PUSHR; PANIC("KSP not valid");
        !           193: SCBVEC(powfail):
        !           194:        halt
        !           195: SCBVEC(chme): SCBVEC(chms): SCBVEC(chmu):
        !           196:        PUSHR; PANIC("CHM? in kernel");
        !           197: SCBVEC(stray):
        !           198:        PUSHR; PRINTF(0, "stray scb interrupt\n"); POPR;
        !           199:        rei
        !           200: SCBVEC(nexzvec):
        !           201:        PUSHR; mfpr $IPL,-(sp); PRINTF(1, "nexus stray intr ipl%x\n"); POPR; rei
        !           202: SCBVEC(cmrd):
        !           203:        PUSHR; calls $0,_memerr; POPR; rei
        !           204: SCBVEC(wtime):
        !           205:        PUSHR; pushl 6*4(sp); PRINTF(1,"write timeout %x\n"); POPR;
        !           206:        PANIC("wtimo");
        !           207: 
        !           208: #if NMBA > 0
        !           209: SCBVEC(mba3int):
        !           210:        PUSHR; pushl $3; brb 1f
        !           211: SCBVEC(mba2int):
        !           212:        PUSHR; pushl $2; brb 1f
        !           213: SCBVEC(mba1int):
        !           214:        PUSHR; pushl $1; brb 1f
        !           215: SCBVEC(mba0int):
        !           216:        PUSHR; pushl $0
        !           217: 1:     calls $1,_mbintr
        !           218:        POPR
        !           219:        incl    _cnt+V_INTR
        !           220:        rei
        !           221: #endif
        !           222: 
        !           223: #if VAX780
        !           224: /*
        !           225:  * Registers for the uba handling code
        !           226:  */
        !           227: #define        rUBANUM r0
        !           228: #define        rUBAHD  r1
        !           229: #define        rUVEC   r3
        !           230: #define        rUBA    r4
        !           231: /* r2,r5 are scratch */
        !           232: 
        !           233: SCBVEC(ua3int):
        !           234:        PUSHR; movl $3,rUBANUM; moval _uba_hd+(3*UH_SIZE),rUBAHD; brb 1f
        !           235: SCBVEC(ua2int):
        !           236:        PUSHR; movl $2,rUBANUM; moval _uba_hd+(2*UH_SIZE),rUBAHD; brb 1f
        !           237: SCBVEC(ua1int):
        !           238:        PUSHR; movl $1,rUBANUM; moval _uba_hd+(1*UH_SIZE),rUBAHD; brb 1f
        !           239: SCBVEC(ua0int):
        !           240:        PUSHR; movl $0,rUBANUM; moval _uba_hd+(0*UH_SIZE),rUBAHD;
        !           241: 1:
        !           242:        incl    _cnt+V_INTR
        !           243:        mfpr    $IPL,r2                         /* r2 = mfpr(IPL); */
        !           244:        movl    UH_UBA(rUBAHD),rUBA             /* uba = uhp->uh_uba; */
        !           245:        movl    UBA_BRRVR-0x14*4(rUBA)[r2],rUVEC
        !           246:                                        /* uvec = uba->uba_brrvr[r2-0x14] */
        !           247: ubanorm:
        !           248:        bleq    ubaerror 
        !           249:        addl2   UH_VEC(rUBAHD),rUVEC            /* uvec += uh->uh_vec */
        !           250:        bicl3   $3,(rUVEC),r1 
        !           251:        jmp     2(r1)                           /* 2 skips ``pushr $0x3f'' */
        !           252: ubaerror:
        !           253:        PUSHR; calls $0,_ubaerror; POPR         /* ubaerror r/w's r0-r5 */
        !           254:        tstl rUVEC; jneq ubanorm                /* rUVEC contains result */
        !           255:        POPR
        !           256:        rei
        !           257: #endif
        !           258: SCBVEC(cnrint):
        !           259:        PUSHR; calls $0,_cnrint; POPR; incl _cnt+V_INTR; rei
        !           260: SCBVEC(cnxint):
        !           261:        PUSHR; calls $0,_cnxint; POPR; incl _cnt+V_INTR; rei
        !           262: SCBVEC(hardclock):
        !           263:        PUSHR
        !           264:        mtpr $ICCS_RUN|ICCS_IE|ICCS_INT|ICCS_ERR,$ICCS
        !           265:        pushl 4+6*4(sp); pushl 4+6*4(sp);
        !           266:        calls $2,_hardclock                     # hardclock(pc,psl)
        !           267: #if NPS > 0
        !           268:        pushl   4+6*4(sp); pushl 4+6*4(sp);
        !           269:        calls   $2,_psextsync
        !           270: #endif
        !           271:        POPR;
        !           272:        incl    _cnt+V_INTR             ## temp so not to break vmstat -= HZ
        !           273:        rei
        !           274: SCBVEC(softclock):
        !           275:        PUSHR
        !           276: #if NDZ > 0
        !           277:        calls   $0,_dztimer
        !           278: #endif
        !           279: #if NDH > 0
        !           280:        calls   $0,_dhtimer
        !           281: #endif
        !           282:        pushl   4+6*4(sp); pushl 4+6*4(sp);
        !           283:        calls   $2,_softclock                   # softclock(pc,psl)
        !           284:        POPR; 
        !           285:        rei
        !           286: #include "../net/netisr.h"
        !           287:        .globl  _netisr
        !           288: SCBVEC(netintr):
        !           289:        PUSHR
        !           290:        bbcc    $NETISR_RAW,_netisr,1f; calls $0,_rawintr; 1:
        !           291: #ifdef INET
        !           292: #include "../netinet/in_systm.h"
        !           293:        bbcc    $NETISR_IP,_netisr,1f; calls $0,_ipintr; 1:
        !           294: #endif
        !           295: #ifdef NS
        !           296:        bbcc    $NETISR_NS,_netisr,1f; calls $0,_nsintr; 1:
        !           297: #endif
        !           298:        POPR
        !           299:        rei
        !           300: #if defined(VAX750) || defined(VAX730)
        !           301: SCBVEC(consdin):
        !           302:        PUSHR;
        !           303: #if defined(VAX750) && !defined(VAX730) && !defined(MRSP)
        !           304:        jsb     tudma
        !           305: #endif
        !           306:        calls $0,_turintr;
        !           307:        POPR;
        !           308:        incl _cnt+V_INTR;
        !           309:        rei
        !           310: SCBVEC(consdout):
        !           311:        PUSHR; calls $0,_tuxintr; POPR; incl _cnt+V_INTR; rei
        !           312: #else
        !           313: SCBVEC(consdin):
        !           314:        halt
        !           315: SCBVEC(consdout):
        !           316:        halt
        !           317: #endif
        !           318: 
        !           319: #if NDZ > 0
        !           320: /*
        !           321:  * DZ pseudo dma routine:
        !           322:  *     r0 - controller number
        !           323:  */
        !           324:        .align  1
        !           325:        .globl  dzdma
        !           326: dzdma:
        !           327:        mull2   $8*20,r0
        !           328:        movab   _dzpdma(r0),r3          # pdma structure base
        !           329:                                        # for this controller
        !           330: dzploop:
        !           331:        movl    r3,r0   
        !           332:        movl    (r0)+,r1                # device register address
        !           333:        movzbl  1(r1),r2                # get line number
        !           334:        bitb    $0x80,r2                # TRDY on?
        !           335:        beql    dzprei                  # no    
        !           336:        bicb2   $0xf8,r2                # clear garbage bits
        !           337:        mull2   $20,r2
        !           338:        addl2   r2,r0                   # point at line's pdma structure
        !           339:        movl    (r0)+,r2                # p_mem
        !           340:        cmpl    r2,(r0)+                # p_mem < p_end ?
        !           341:        bgequ   dzpcall                 # no, go call dzxint
        !           342:        movb    (r2)+,6(r1)             # dztbuf = *p_mem++
        !           343:        movl    r2,-8(r0)
        !           344:        brb     dzploop                 # check for another line
        !           345: dzprei:
        !           346:        POPR
        !           347:        incl    _cnt+V_PDMA
        !           348:        rei
        !           349: 
        !           350: dzpcall:
        !           351:        pushl   r3
        !           352:        pushl   (r0)+                   # push tty address
        !           353:        calls   $1,*(r0)                # call interrupt rtn
        !           354:        movl    (sp)+,r3
        !           355:        brb     dzploop                 # check for another line
        !           356: #endif
        !           357: 
        !           358: #if NUU > 0 && defined(UUDMA)
        !           359: /*
        !           360:  * Pseudo DMA routine for tu58 (on DL11)
        !           361:  *     r0 - controller number
        !           362:  */
        !           363:        .align  1
        !           364:        .globl  uudma
        !           365: uudma:
        !           366:        movl    _uudinfo[r0],r2
        !           367:        movl    16(r2),r2               # r2 = uuaddr
        !           368:        mull3   $48,r0,r3
        !           369:        movab   _uu_softc(r3),r5        # r5 = uuc
        !           370: 
        !           371:        cvtwl   2(r2),r1                # c = uuaddr->rdb
        !           372:        bbc     $15,r1,1f               # if (c & UUDB_ERROR)
        !           373:        movl    $13,16(r5)              #       uuc->tu_state = TUC_RCVERR;
        !           374:        rsb                             #       let uurintr handle it
        !           375: 1:
        !           376:        tstl    4(r5)                   # if (uuc->tu_rcnt) {
        !           377:        beql    1f
        !           378:        movb    r1,*0(r5)               #       *uuc->tu_rbptr++ = r1
        !           379:        incl    (r5)
        !           380:        decl    4(r5)                   #       if (--uuc->tu_rcnt)
        !           381:        beql    2f                      #               done
        !           382:        tstl    (sp)+
        !           383:        POPR                            #       registers saved in ubglue.s
        !           384:        rei                             # }
        !           385: 2:
        !           386:        cmpl    16(r5),$8               # if (uuc->tu_state != TUS_GETH)
        !           387:        beql    2f                      #       let uurintr handle it
        !           388: 1:
        !           389:        rsb
        !           390: 2:
        !           391:        mull2   $14,r0                  # sizeof(uudata[ctlr]) = 14
        !           392:        movab   _uudata(r0),r4          # data = &uudata[ctlr];
        !           393:        cmpb    $1,(r4)                 # if (data->pk_flag != TUF_DATA)
        !           394:        bneq    1b
        !           395: #ifdef notdef
        !           396:        /* this is for command packets */
        !           397:        beql    1f                      #       r0 = uuc->tu_rbptr
        !           398:        movl    (r5),r0
        !           399:        brb     2f
        !           400: 1:                                     # else
        !           401: #endif
        !           402:        movl    24(r5),r0               #       r0 = uuc->tu_addr
        !           403: 2:
        !           404:        movzbl  1(r4),r3                # counter to r3 (data->pk_count)
        !           405:        movzwl  (r4),r1                 # first word of checksum (=header)
        !           406:        mfpr    $IPL,-(sp)              # s = spl5();
        !           407:        mtpr    $0x15,$IPL              # to keep disk interrupts out
        !           408:        clrw    (r2)                    # disable receiver interrupts
        !           409: 3:     bbc     $7,(r2),3b              # while ((uuaddr->rcs & UUCS_READY)==0);
        !           410:        cvtwb   2(r2),(r0)+             # *buffer = uuaddr->rdb & 0xff
        !           411:        sobgtr  r3,1f                   # continue with next byte ...
        !           412:        addw2   2(r2),r1                # unless this was the last (odd count)
        !           413:        brb     2f
        !           414: 
        !           415: 1:     bbc     $7,(r2),1b              # while ((uuaddr->rcs & UUCS_READY)==0);
        !           416:        cvtwb   2(r2),(r0)+             # *buffer = uuaddr->rdb & 0xff
        !           417:        addw2   -2(r0),r1               # add to checksum..
        !           418: 2:
        !           419:        adwc    $0,r1                   # get the carry
        !           420:        sobgtr  r3,3b                   # loop while r3 > 0
        !           421: /*
        !           422:  * We're ready to get the checksum
        !           423:  */
        !           424: 1:     bbc     $7,(r2),1b              # while ((uuaddr->rcs & UUCS_READY)==0);
        !           425:        cvtwb   2(r2),12(r4)            # get first (lower) byte
        !           426: 1:     bbc     $7,(r2),1b
        !           427:        cvtwb   2(r2),13(r4)            # ..and second
        !           428:        cmpw    12(r4),r1               # is checksum ok?
        !           429:        beql    1f
        !           430:        movl    $14,16(r5)              # uuc->tu_state = TUS_CHKERR
        !           431:        brb     2f                      # exit
        !           432: 1:
        !           433:        movl    $11,16(r5)              # uuc->tu_state = TUS_GET (ok)
        !           434: 2:
        !           435:        movw    $0x40,(r2)              # enable receiver interrupts
        !           436:        mtpr    (sp)+,$IPL              # splx(s);
        !           437:        rsb                             # continue processing in uurintr
        !           438: #endif
        !           439: 
        !           440: #if defined(VAX750) && !defined(VAX730) && !defined(MRSP)
        !           441: /*
        !           442:  * Pseudo DMA routine for VAX-11/750 console tu58 
        !           443:  *         (without MRSP)
        !           444:  */
        !           445:        .align  1
        !           446:        .globl  tudma
        !           447: tudma:
        !           448:        movab   _tu,r5                  # r5 = tu
        !           449:        tstl    4(r5)                   # if (tu.tu_rcnt) {
        !           450:        beql    3f
        !           451:        mfpr    $CSRD,r1                # get data from tu58
        !           452:        movb    r1,*0(r5)               #       *tu.tu_rbptr++ = r1
        !           453:        incl    (r5)
        !           454:        decl    4(r5)                   #       if (--tu.tu_rcnt)
        !           455:        beql    1f                      #               done
        !           456:        tstl    (sp)+
        !           457:        POPR                            #       registers saved in ubglue.s
        !           458:        rei                             #       data handled, done
        !           459: 1:                                     # }
        !           460:        cmpl    16(r5),$8               # if (tu.tu_state != TUS_GETH)
        !           461:        beql    2f                      #       let turintr handle it
        !           462: 3:
        !           463:        rsb
        !           464: 2:
        !           465:        movab   _tudata,r4              # r4 = tudata
        !           466:        cmpb    $1,(r4)                 # if (tudata.pk_flag != TUF_DATA)
        !           467:        bneq    3b                      #       let turintr handle it
        !           468: 1:                                     # else
        !           469:        movl    24(r5),r1               # get buffer pointer to r1
        !           470:        movzbl  1(r4),r3                # counter to r3
        !           471:        movzwl  (r4),r0                 # first word of checksum (=header)
        !           472:        mtpr    $0,$CSRS                # disable receiver interrupts
        !           473: 3:
        !           474:        bsbw    5f                      # wait for next byte
        !           475:        mfpr    $CSRD,r5
        !           476:        movb    r5,(r1)+                # *buffer = rdb
        !           477:        sobgtr  r3,1f                   # continue with next byte ...
        !           478:        mfpr    $CSRD,r2                # unless this was the last (odd count)
        !           479:        brb     2f
        !           480: 
        !           481: 1:     bsbw    5f                      # wait for next byte
        !           482:        mfpr    $CSRD,r5
        !           483:        movb    r5,(r1)+                # *buffer = rdb
        !           484:        movzwl  -2(r1),r2               # get the last word back from memory
        !           485: 2:
        !           486:        addw2   r2,r0                   # add to checksum..
        !           487:        adwc    $0,r0                   # get the carry
        !           488:        sobgtr  r3,3b                   # loop while r3 > 0
        !           489: /*
        !           490:  * We're ready to get the checksum.
        !           491:  */
        !           492:        bsbw    5f
        !           493:        movab   _tudata,r4
        !           494:        mfpr    $CSRD,r5
        !           495:        movb    r5,12(r4)               # get first (lower) byte
        !           496:        bsbw    5f
        !           497:        mfpr    $CSRD,r5
        !           498:        movb    r5,13(r4)               # ..and second
        !           499:        movab   _tu,r5
        !           500:        cmpw    12(r4),r0               # is checksum ok?
        !           501:        beql    1f
        !           502:        movl    $14,16(r5)              # tu.tu_state = TUS_CHKERR
        !           503:        brb     2f                      # exit
        !           504: 1:
        !           505:        movl    $11,16(r5)              # tu.tu_state = TUS_GET
        !           506: 2:
        !           507:        mtpr    $0x40,$CSRS             # enable receiver interrupts
        !           508:        rsb                             # continue processing in turintr
        !           509: /*
        !           510:  * Loop until a new byte is ready from
        !           511:  * the tu58, make sure we don't loop forever
        !           512:  */
        !           513: 5:
        !           514:        movl    $5000,r5                # loop max 5000 times
        !           515: 1:
        !           516:        mfpr    $CSRS,r2
        !           517:        bbs     $7,r2,1f
        !           518:        sobgtr  r5,1b
        !           519:        movab   _tu,r5
        !           520:        movl    $13,16(r5)              # return TUS_RCVERR
        !           521:        tstl    (sp)+                   # and let turintr handle it
        !           522: 1:
        !           523:        rsb
        !           524: #endif
        !           525: 
        !           526: /*
        !           527:  * Stray UNIBUS interrupt catch routines
        !           528:  */
        !           529:        .data
        !           530:        .align  2
        !           531: #define        PJ      PUSHR;jsb _Xustray
        !           532:        .globl  _catcher
        !           533: _catcher:
        !           534:        PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ
        !           535:        PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ
        !           536:        PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ
        !           537:        PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ
        !           538:        PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ
        !           539:        PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ
        !           540:        PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ
        !           541:        PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ;PJ
        !           542: 
        !           543:        .globl  _cold
        !           544: _cold: .long   1
        !           545:        .data
        !           546: 
        !           547:        .text
        !           548: SCBVEC(ustray):
        !           549:        blbc    _cold,1f
        !           550:        mfpr    $IPL,r11
        !           551:        subl3   $_catcher+8,(sp)+,r10
        !           552:        ashl    $-1,r10,r10
        !           553:        POPR
        !           554:        rei
        !           555: 1:
        !           556:        subl3   $_catcher+8,(sp)+,r0
        !           557:        ashl    $-1,r0,-(sp)
        !           558:        mfpr    $IPL,-(sp)
        !           559:        PRINTF(2, "uba?: stray intr ipl %x vec %o\n")
        !           560:        POPR
        !           561:        rei
        !           562: 
        !           563: /*
        !           564:  * Trap and fault vector routines
        !           565:  */ 
        !           566: #define        TRAP(a) pushl $T_/**/a; jbr alltraps
        !           567: 
        !           568: /*
        !           569:  * Ast delivery (profiling and/or reschedule)
        !           570:  */
        !           571: SCBVEC(astflt):
        !           572:        pushl $0; TRAP(ASTFLT)
        !           573: SCBVEC(privinflt):
        !           574:        pushl $0; TRAP(PRIVINFLT)
        !           575: SCBVEC(xfcflt):
        !           576:        pushl $0; TRAP(XFCFLT)
        !           577: SCBVEC(resopflt):
        !           578:        pushl $0; TRAP(RESOPFLT)
        !           579: SCBVEC(resadflt):
        !           580:        pushl $0; TRAP(RESADFLT)
        !           581: SCBVEC(bptflt):
        !           582:        pushl $0; TRAP(BPTFLT)
        !           583: SCBVEC(compatflt):
        !           584:        TRAP(COMPATFLT);
        !           585: SCBVEC(tracep):
        !           586:        pushl $0; TRAP(TRCTRAP)
        !           587: SCBVEC(arithtrap):
        !           588:        TRAP(ARITHTRAP)
        !           589: SCBVEC(protflt):
        !           590:        blbs    (sp)+,segflt
        !           591:        TRAP(PROTFLT)
        !           592: segflt:
        !           593:        TRAP(SEGFLT)
        !           594: SCBVEC(transflt):
        !           595:        bitl    $2,(sp)+
        !           596:        bnequ   tableflt
        !           597:        jsb     Fastreclaim             # try and avoid pagein
        !           598:        TRAP(PAGEFLT)
        !           599: tableflt: 
        !           600:        TRAP(TABLEFLT)
        !           601: 
        !           602: alltraps:
        !           603:        mfpr    $USP,-(sp); calls $0,_trap; mtpr (sp)+,$USP
        !           604:        incl    _cnt+V_TRAP
        !           605:        addl2   $8,sp                   # pop type, code
        !           606:        mtpr    $HIGH,$IPL              ## dont go to a higher IPL (GROT)
        !           607:        rei
        !           608: 
        !           609: SCBVEC(syscall):
        !           610:        pushl   $T_SYSCALL
        !           611:        mfpr    $USP,-(sp); calls $0,_syscall; mtpr (sp)+,$USP
        !           612:        incl    _cnt+V_SYSCALL
        !           613:        addl2   $8,sp                   # pop type, code
        !           614:        mtpr    $HIGH,$IPL              ## dont go to a higher IPL (GROT)
        !           615:        rei
        !           616: 
        !           617: /*
        !           618:  * System page table
        !           619:  */ 
        !           620: #define        vaddr(x)        ((((x)-_Sysmap)/4)*NBPG+0x80000000)
        !           621: #define        SYSMAP(mname, vname, npte)                      \
        !           622: _/**/mname:    .globl  _/**/mname;             \
        !           623:        .space  npte*4;                         \
        !           624:        .globl  _/**/vname;                     \
        !           625:        .set    _/**/vname,vaddr(_/**/mname)
        !           626: 
        !           627:        .data
        !           628:        .align  2
        !           629:        SYSMAP(Sysmap   ,Sysbase        ,SYSPTSIZE      )
        !           630:        SYSMAP(UMBAbeg  ,umbabeg        ,0              )
        !           631:        SYSMAP(Nexmap   ,nexus          ,16*MAXNNEXUS   )
        !           632:        SYSMAP(UMEMmap  ,umem           ,512*MAXNUBA    )
        !           633:        SYSMAP(UMBAend  ,umbaend        ,0              )
        !           634:        SYSMAP(Usrptmap ,usrpt          ,USRPTSIZE      )
        !           635:        SYSMAP(Forkmap  ,forkutl        ,UPAGES         )
        !           636:        SYSMAP(Xswapmap ,xswaputl       ,UPAGES         )
        !           637:        SYSMAP(Xswap2map,xswap2utl      ,UPAGES         )
        !           638:        SYSMAP(Swapmap  ,swaputl        ,UPAGES         )
        !           639:        SYSMAP(Pushmap  ,pushutl        ,UPAGES         )
        !           640:        SYSMAP(Vfmap    ,vfutl          ,UPAGES         )
        !           641:        SYSMAP(CMAP1    ,CADDR1         ,1              )
        !           642:        SYSMAP(CMAP2    ,CADDR2         ,1              )
        !           643:        SYSMAP(mcrmap   ,mcr            ,1              )
        !           644:        SYSMAP(mmap     ,vmmap          ,1              )
        !           645:        SYSMAP(msgbufmap,msgbuf         ,MSGBUFPTECNT   )
        !           646:        SYSMAP(camap    ,cabase         ,16*CLSIZE      )
        !           647:        SYSMAP(ecamap   ,calimit        ,0              )
        !           648:        SYSMAP(Mbmap    ,mbutl          ,NMBCLUSTERS*CLSIZE)
        !           649: 
        !           650: eSysmap:
        !           651:        .globl  _Syssize
        !           652:        .set    _Syssize,(eSysmap-_Sysmap)/4
        !           653:        .text
        !           654: 
        !           655: /*
        !           656:  * Initialization
        !           657:  *
        !           658:  * ipl 0x1f; mapen 0; scbb, pcbb, sbr, slr, isp, ksp not set
        !           659:  */
        !           660:        .data
        !           661:        .globl  _cpu
        !           662: _cpu:  .long   0
        !           663:        .text
        !           664:        .globl  start
        !           665: start:
        !           666:        .word   0
        !           667: /* set system control block base and system page table params */
        !           668:        mtpr    $_scb-0x80000000,$SCBB
        !           669:        mtpr    $_Sysmap-0x80000000,$SBR
        !           670:        mtpr    $_Syssize,$SLR
        !           671: /* double map the kernel into the virtual user addresses of phys mem */
        !           672:        mtpr    $_Sysmap,$P0BR
        !           673:        mtpr    $_Syssize,$P0LR
        !           674: /* set ISP and get cpu type */
        !           675:        movl    $_intstack+NISP*NBPG,sp
        !           676:        mfpr    $SID,r0
        !           677:        movab   _cpu,r1
        !           678:        extzv   $24,$8,r0,(r1)
        !           679: /* init RPB */
        !           680:        movab   _rpb,r0
        !           681:        movl    r0,(r0)+                        # rp_selfref
        !           682:        movab   _doadump,r1
        !           683:        movl    r1,(r0)+                        # rp_dumprout
        !           684:        movl    $0x1f,r2
        !           685:        clrl    r3
        !           686: 1:     addl2   (r1)+,r3; sobgtr r2,1b
        !           687:        movl    r3,(r0)+                        # rp_chksum
        !           688: /* count up memory */
        !           689:        clrl    r7
        !           690: 1:     pushl   $4; pushl r7; calls $2,_badaddr; tstl r0; bneq 9f
        !           691:        acbl    $8192*1024-1,$64*1024,r7,1b
        !           692: 9:
        !           693: /* clear memory from kernel bss and pages for proc 0 u. and page table */
        !           694:        movab   _edata,r6
        !           695:        movab   _end,r5
        !           696:        bbcc    $31,r5,0f; 0:
        !           697:        addl2   $(UPAGES*NBPG)+NBPG+NBPG,r5
        !           698: 1:     clrq    (r6); acbl r5,$8,r6,1b
        !           699: /* trap() and syscall() save r0-r11 in the entry mask (per ../h/reg.h) */
        !           700:        bisw2   $0x0fff,_trap
        !           701:        bisw2   $0x0fff,_syscall
        !           702:        calls   $0,_fixctlrmask
        !           703: /* initialize system page table: scb and int stack writeable */
        !           704:        clrl    r2
        !           705:        movab   eintstack,r1; bbcc $31,r1,0f; 0: ashl $-PGSHIFT,r1,r1
        !           706: 1:     bisl3   $PG_V|PG_KW,r2,_Sysmap[r2]; aoblss r1,r2,1b
        !           707: /* make rpb read-only as red zone for interrupt stack */
        !           708:        bicl2   $PG_PROT,_rpbmap
        !           709:        bisl2   $PG_KR,_rpbmap
        !           710: /* make kernel text space read-only */
        !           711:        movab   _etext+NBPG-1,r1; bbcc $31,r1,0f; 0: ashl $-PGSHIFT,r1,r1
        !           712: 1:     bisl3   $PG_V|PG_KR,r2,_Sysmap[r2]; aoblss r1,r2,1b
        !           713: /* make kernel data, bss, read-write */
        !           714:        movab   _end+NBPG-1,r1; bbcc $31,r1,0f; 0:; ashl $-PGSHIFT,r1,r1
        !           715: 1:     bisl3   $PG_V|PG_KW,r2,_Sysmap[r2]; aoblss r1,r2,1b
        !           716: /* now go to mapped mode */
        !           717:        mtpr    $1,$TBIA; mtpr $1,$MAPEN; jmp *$0f; 0:
        !           718: /* init mem sizes */
        !           719:        ashl    $-PGSHIFT,r7,_maxmem
        !           720:        movl    _maxmem,_physmem
        !           721:        movl    _maxmem,_freemem
        !           722: /* setup context for proc[0] == Scheduler */
        !           723:        movab   _end+NBPG-1,r6
        !           724:        bicl2   $NBPG-1,r6              # make page boundary
        !           725: /* setup page table for proc[0] */
        !           726:        bbcc    $31,r6,0f; 0:
        !           727:        ashl    $-PGSHIFT,r6,r3                 # r3 = btoc(r6)
        !           728:        bisl3   $PG_V|PG_KW,r3,_Usrptmap        # init first upt entry
        !           729:        incl    r3
        !           730:        movab   _usrpt,r0
        !           731:        mtpr    r0,$TBIS
        !           732: /* init p0br, p0lr */
        !           733:        mtpr    r0,$P0BR
        !           734:        mtpr    $0,$P0LR
        !           735: /* init p1br, p1lr */
        !           736:        movab   NBPG(r0),r0
        !           737:        movl    $0x200000-UPAGES,r1
        !           738:        mtpr    r1,$P1LR
        !           739:        mnegl   r1,r1
        !           740:        moval   -4*UPAGES(r0)[r1],r2
        !           741:        mtpr    r2,$P1BR
        !           742: /* setup mapping for UPAGES of _u */
        !           743:        movl    $UPAGES,r2; movab _u+NBPG*UPAGES,r1; addl2 $UPAGES,r3; jbr 2f
        !           744: 1:     decl    r3
        !           745:        moval   -NBPG(r1),r1;
        !           746:        bisl3   $PG_V|PG_URKW,r3,-(r0)
        !           747:        mtpr    r1,$TBIS
        !           748: 2:     sobgeq  r2,1b
        !           749: /* initialize (slightly) the pcb */
        !           750:        movab   UPAGES*NBPG(r1),PCB_KSP(r1)
        !           751:        mnegl   $1,PCB_ESP(r1)
        !           752:        mnegl   $1,PCB_SSP(r1)
        !           753:        movl    r1,PCB_USP(r1)
        !           754:        mfpr    $P0BR,PCB_P0BR(r1)
        !           755:        mfpr    $P0LR,PCB_P0LR(r1)
        !           756:        movb    $4,PCB_P0LR+3(r1)               # disable ast
        !           757:        mfpr    $P1BR,PCB_P1BR(r1)
        !           758:        mfpr    $P1LR,PCB_P1LR(r1)
        !           759:        movl    $CLSIZE,PCB_SZPT(r1)            # init u.u_pcb.pcb_szpt
        !           760:        movl    r11,PCB_R11(r1)
        !           761:        movab   1f,PCB_PC(r1)                   # initial pc
        !           762:        clrl    PCB_PSL(r1)                     # mode(k,k), ipl=0
        !           763:        ashl    $PGSHIFT,r3,r3
        !           764:        mtpr    r3,$PCBB                        # first pcbb
        !           765: /* set regs, p0br, p0lr, p1br, p1lr, astlvl, ksp and change to kernel mode */
        !           766:        ldpctx
        !           767:        rei
        !           768: /* put signal trampoline code in u. area */
        !           769: 1:     movab   _u,r0
        !           770:        movc3   $16,sigcode,PCB_SIGC(r0)
        !           771: /* save reboot flags in global _boothowto */
        !           772:        movl    r11,_boothowto
        !           773: /* calculate firstaddr, and call main() */
        !           774:        movab   _end+NBPG-1,r0; bbcc $31,r0,0f; 0:; ashl $-PGSHIFT,r0,-(sp)
        !           775:        addl2   $UPAGES+1,(sp); calls $1,_main
        !           776: /* proc[1] == /etc/init now running here; run icode */
        !           777:        pushl   $PSL_CURMOD|PSL_PRVMOD; pushl $0; rei
        !           778: 
        !           779: /* signal trampoline code: it is known that this code takes exactly 16 bytes */
        !           780: /* in ../vax/pcb.h and in the movc3 above */
        !           781: sigcode:
        !           782:        calls   $4,5(pc)                        # params pushed by sendsig
        !           783:        chmk    $139                            # cleanup mask and onsigstack
        !           784:        rei
        !           785:        .word   0x7f                            # registers 0-6 (6==sp/compat)
        !           786:        callg   (ap),*16(ap)
        !           787:        ret
        !           788: 
        !           789: /*
        !           790:  * Primitives
        !           791:  */ 
        !           792: 
        !           793: /*
        !           794:  * badaddr(addr, len)
        !           795:  *     see if access addr with a len type instruction causes a machine check
        !           796:  *     len is length of access (1=byte, 2=short, 4=long)
        !           797:  */
        !           798:        .globl  _badaddr
        !           799: _badaddr:
        !           800:        .word   0
        !           801:        movl    $1,r0
        !           802:        mfpr    $IPL,r1
        !           803:        mtpr    $HIGH,$IPL
        !           804:        movl    _scb+MCKVEC,r2
        !           805:        movl    4(ap),r3
        !           806:        movl    8(ap),r4
        !           807:        movab   9f+INTSTK,_scb+MCKVEC
        !           808:        bbc     $0,r4,1f; tstb  (r3)
        !           809: 1:     bbc     $1,r4,1f; tstw  (r3)
        !           810: 1:     bbc     $2,r4,1f; tstl  (r3)
        !           811: 1:     clrl    r0                      # made it w/o machine checks
        !           812: 2:     movl    r2,_scb+MCKVEC
        !           813:        mtpr    r1,$IPL
        !           814:        ret
        !           815:        .align  2
        !           816: 9:
        !           817:        casel   _cpu,$1,$VAX_MAX
        !           818: 0:
        !           819:        .word   8f-0b           # 1 is 780
        !           820:        .word   5f-0b           # 2 is 750
        !           821:        .word   5f-0b           # 3 is 730
        !           822: 5:
        !           823: #if defined(VAX750) || defined(VAX730)
        !           824:        mtpr    $0xf,$MCESR
        !           825: #endif
        !           826:        brb     1f
        !           827: 8:
        !           828: #if VAX780
        !           829:        mtpr    $0,$SBIFS
        !           830: #endif
        !           831: 1:
        !           832:        addl2   (sp)+,sp                # discard mchchk trash
        !           833:        movab   2b,(sp)
        !           834:        rei
        !           835: 
        !           836: _addupc:       .globl  _addupc
        !           837:        .word   0x0
        !           838:        movl    8(ap),r2                # &u.u_prof
        !           839:        subl3   8(r2),4(ap),r0          # corrected pc
        !           840:        blss    9f
        !           841:        extzv   $1,$31,r0,r0            # logical right shift
        !           842:        extzv   $1,$31,12(r2),r1        # ditto for scale
        !           843:        emul    r1,r0,$0,r0
        !           844:        ashq    $-14,r0,r0
        !           845:        tstl    r1
        !           846:        bneq    9f
        !           847:        bicl2   $1,r0
        !           848:        cmpl    r0,4(r2)                # length
        !           849:        bgequ   9f
        !           850:        addl2   (r2),r0                 # base
        !           851:        probew  $3,$2,(r0)
        !           852:        beql    8f
        !           853:        addw2   12(ap),(r0)
        !           854: 9:
        !           855:        ret
        !           856: 8:
        !           857:        clrl    12(r2)
        !           858:        ret
        !           859: 
        !           860: _Copyin:       .globl  _Copyin         # <<<massaged for jsb by asm.sed>>>
        !           861:        movl    12(sp),r0               # copy length
        !           862:        blss    ersb
        !           863:        movl    4(sp),r1                # copy user address
        !           864:        cmpl    $NBPG,r0                # probing one page or less ?
        !           865:        bgeq    cishort                 # yes
        !           866: ciloop:
        !           867:        prober  $3,$NBPG,(r1)           # bytes accessible ?
        !           868:        beql    ersb                    # no
        !           869:        addl2   $NBPG,r1                # incr user address ptr
        !           870:        acbl    $NBPG+1,$-NBPG,r0,ciloop        # reduce count and loop
        !           871: cishort:
        !           872:        prober  $3,r0,(r1)              # bytes accessible ?
        !           873:        beql    ersb                    # no
        !           874:        movl    4(sp),r1
        !           875:        movl    8(sp),r3
        !           876:        jbr     2f
        !           877: 1:
        !           878:        subl2   r0,12(sp)
        !           879:        movc3   r0,(r1),(r3)
        !           880: 2:
        !           881:        movzwl  $65535,r0
        !           882:        cmpl    12(sp),r0
        !           883:        jgtr    1b
        !           884:        movc3   12(sp),(r1),(r3)
        !           885:        clrl    r0                      #redundant
        !           886:        rsb
        !           887: 
        !           888: ersb:
        !           889:        movl    $EFAULT,r0
        !           890:        rsb
        !           891: 
        !           892: _Copyout:      .globl  _Copyout        # <<<massaged for jsb by asm.sed >>>
        !           893:        movl    12(sp),r0               # get count
        !           894:        blss    ersb
        !           895:        movl    8(sp),r1                # get user address
        !           896:        cmpl    $NBPG,r0                # can do in one probew?
        !           897:        bgeq    coshort                 # yes
        !           898: coloop:
        !           899:        probew  $3,$NBPG,(r1)           # bytes accessible?
        !           900:        beql    ersb                    # no 
        !           901:        addl2   $NBPG,r1                # increment user address
        !           902:        acbl    $NBPG+1,$-NBPG,r0,coloop        # reduce count and loop
        !           903: coshort:
        !           904:        probew  $3,r0,(r1)              # bytes accessible?
        !           905:        beql    ersb                    # no
        !           906:        movl    4(sp),r1
        !           907:        movl    8(sp),r3
        !           908:        jbr     2f
        !           909: 1:
        !           910:        subl2   r0,12(sp)
        !           911:        movc3   r0,(r1),(r3)
        !           912: 2:
        !           913:        movzwl  $65535,r0
        !           914:        cmpl    12(sp),r0
        !           915:        jgtr    1b
        !           916:        movc3   12(sp),(r1),(r3)
        !           917:        clrl    r0                              #redundant
        !           918:        rsb
        !           919: 
        !           920: /*
        !           921:  * non-local goto's
        !           922:  */
        !           923:        .globl  _Setjmp
        !           924: _Setjmp:
        !           925:        movq    r6,(r0)+
        !           926:        movq    r8,(r0)+
        !           927:        movq    r10,(r0)+
        !           928:        movq    r12,(r0)+
        !           929:        addl3   $4,sp,(r0)+
        !           930:        movl    (sp),(r0)
        !           931:        clrl    r0
        !           932:        rsb
        !           933: 
        !           934:        .globl  _Longjmp
        !           935: _Longjmp:
        !           936:        movq    (r0)+,r6
        !           937:        movq    (r0)+,r8
        !           938:        movq    (r0)+,r10
        !           939:        movq    (r0)+,r12
        !           940:        movl    (r0)+,r1
        !           941:        cmpl    r1,sp                           # must be a pop
        !           942:        bgequ   lj2
        !           943:        pushab  lj1
        !           944:        calls   $1,_panic
        !           945: lj2:
        !           946:        movl    r1,sp
        !           947:        jmp     *(r0)                           # ``rsb''
        !           948: 
        !           949: lj1:   .asciz  "longjmp"
        !           950: 
        !           951:        .globl  _whichqs
        !           952:        .globl  _qs
        !           953:        .globl  _cnt
        !           954: 
        !           955:        .globl  _noproc
        !           956:        .comm   _noproc,4
        !           957:        .globl  _runrun
        !           958:        .comm   _runrun,4
        !           959: 
        !           960: /*
        !           961:  * The following primitives use the fancy VAX instructions
        !           962:  * much like VMS does.  _whichqs tells which of the 32 queues _qs
        !           963:  * have processes in them.  Setrq puts processes into queues, Remrq
        !           964:  * removes them from queues.  The running process is on no queue,
        !           965:  * other processes are on a queue related to p->p_pri, divided by 4
        !           966:  * actually to shrink the 0-127 range of priorities into the 32 available
        !           967:  * queues.
        !           968:  */
        !           969: 
        !           970: /*
        !           971:  * Setrq(p), using fancy VAX instructions.
        !           972:  *
        !           973:  * Call should be made at spl6(), and p->p_stat should be SRUN
        !           974:  */
        !           975:        .globl  _Setrq          # <<<massaged to jsb by "asm.sed">>>
        !           976: _Setrq:
        !           977:        tstl    P_RLINK(r0)             ## firewall: p->p_rlink must be 0
        !           978:        beql    set1                    ##
        !           979:        pushab  set3                    ##
        !           980:        calls   $1,_panic               ##
        !           981: set1:
        !           982:        movzbl  P_PRI(r0),r1            # put on queue which is p->p_pri / 4
        !           983:        ashl    $-2,r1,r1
        !           984:        movaq   _qs[r1],r2
        !           985:        insque  (r0),*4(r2)             # at end of queue
        !           986:        bbss    r1,_whichqs,set2        # mark queue non-empty
        !           987: set2:
        !           988:        rsb
        !           989: 
        !           990: set3:  .asciz  "setrq"
        !           991: 
        !           992: /*
        !           993:  * Remrq(p), using fancy VAX instructions
        !           994:  *
        !           995:  * Call should be made at spl6().
        !           996:  */
        !           997:        .globl  _Remrq          # <<<massaged to jsb by "asm.sed">>>
        !           998: _Remrq:
        !           999:        movzbl  P_PRI(r0),r1
        !          1000:        ashl    $-2,r1,r1
        !          1001:        bbsc    r1,_whichqs,rem1
        !          1002:        pushab  rem3                    # it wasn't recorded to be on its q
        !          1003:        calls   $1,_panic
        !          1004: rem1:
        !          1005:        remque  (r0),r2
        !          1006:        beql    rem2
        !          1007:        bbss    r1,_whichqs,rem2
        !          1008: rem2:
        !          1009:        clrl    P_RLINK(r0)             ## for firewall checking
        !          1010:        rsb
        !          1011: 
        !          1012: rem3:  .asciz  "remrq"
        !          1013: 
        !          1014: /*
        !          1015:  * Masterpaddr is the p->p_addr of the running process on the master
        !          1016:  * processor.  When a multiprocessor system, the slave processors will have
        !          1017:  * an array of slavepaddr's.
        !          1018:  */
        !          1019:        .globl  _masterpaddr
        !          1020:        .data
        !          1021: _masterpaddr:
        !          1022:        .long   0
        !          1023: 
        !          1024:        .text
        !          1025: sw0:   .asciz  "swtch"
        !          1026: /*
        !          1027:  * Swtch(), using fancy VAX instructions
        !          1028:  */
        !          1029:        .globl  _Swtch
        !          1030: _Swtch:                                # <<<massaged to jsb by "asm.sed">>>
        !          1031:        movl    $1,_noproc
        !          1032:        clrl    _runrun
        !          1033: sw1:   ffs     $0,$32,_whichqs,r0      # look for non-empty queue
        !          1034:        bneq    sw1a
        !          1035:        mtpr    $0,$IPL                 # must allow interrupts here
        !          1036:        jbr     sw1                     # this is an idle loop!
        !          1037: sw1a:  mtpr    $0x18,$IPL              # lock out all so _whichqs==_qs
        !          1038:        bbcc    r0,_whichqs,sw1         # proc moved via lbolt interrupt
        !          1039:        movaq   _qs[r0],r1
        !          1040:        remque  *(r1),r2                # r2 = p = highest pri process
        !          1041:        bvc     sw2                     # make sure something was there
        !          1042: sw1b:  pushab  sw0
        !          1043:        calls   $1,_panic
        !          1044: sw2:   beql    sw3
        !          1045:        insv    $1,r0,$1,_whichqs       # still more procs in this queue
        !          1046: sw3:
        !          1047:        clrl    _noproc
        !          1048:        tstl    P_WCHAN(r2)             ## firewalls
        !          1049:        bneq    sw1b                    ##
        !          1050:        movzbl  P_STAT(r2),r3           ##
        !          1051:        cmpl    $SRUN,r3                ##
        !          1052:        bneq    sw1b                    ##
        !          1053:        clrl    P_RLINK(r2)             ##
        !          1054:        movl    *P_ADDR(r2),r0
        !          1055:        movl    r0,_masterpaddr
        !          1056:        ashl    $PGSHIFT,r0,r0          # r0 = pcbb(p)
        !          1057: /*     mfpr    $PCBB,r1                # resume of current proc is easy
        !          1058:  *     cmpl    r0,r1
        !          1059:  */    beql    res0
        !          1060:        incl    _cnt+V_SWTCH
        !          1061: /* fall into... */
        !          1062: 
        !          1063: /*
        !          1064:  * Resume(pf)
        !          1065:  */
        !          1066:        .globl  _Resume         # <<<massaged to jsb by "asm.sed">>>
        !          1067: _Resume:
        !          1068:        mtpr    $0x18,$IPL                      # no interrupts, please
        !          1069:        movl    _CMAP2,_u+PCB_CMAP2     # yech
        !          1070:        svpctx
        !          1071:        mtpr    r0,$PCBB
        !          1072:        ldpctx
        !          1073:        movl    _u+PCB_CMAP2,_CMAP2     # yech
        !          1074:        mtpr    $_CADDR2,$TBIS
        !          1075: res0:
        !          1076:        tstl    _u+PCB_SSWAP
        !          1077:        beql    res1
        !          1078:        movl    _u+PCB_SSWAP,r0
        !          1079:        clrl    _u+PCB_SSWAP
        !          1080:        movab   _Longjmp,(sp)
        !          1081:        movl    $PSL_PRVMOD,4(sp)               # ``cheating'' (jfr)
        !          1082: res1:
        !          1083:        rei
        !          1084: 
        !          1085: /*
        !          1086:  * {fu,su},{byte,word}, all massaged by asm.sed to jsb's
        !          1087:  */
        !          1088:        .globl  _Fuword
        !          1089: _Fuword:
        !          1090:        prober  $3,$4,(r0)
        !          1091:        beql    fserr
        !          1092:        movl    (r0),r0
        !          1093:        rsb
        !          1094: fserr:
        !          1095:        mnegl   $1,r0
        !          1096:        rsb
        !          1097: 
        !          1098:        .globl  _Fubyte
        !          1099: _Fubyte:
        !          1100:        prober  $3,$1,(r0)
        !          1101:        beql    fserr
        !          1102:        movzbl  (r0),r0
        !          1103:        rsb
        !          1104: 
        !          1105:        .globl  _Suword
        !          1106: _Suword:
        !          1107:        probew  $3,$4,(r0)
        !          1108:        beql    fserr
        !          1109:        movl    r1,(r0)
        !          1110:        clrl    r0
        !          1111:        rsb
        !          1112: 
        !          1113:        .globl  _Subyte
        !          1114: _Subyte:
        !          1115:        probew  $3,$1,(r0)
        !          1116:        beql    fserr
        !          1117:        movb    r1,(r0)
        !          1118:        clrl    r0
        !          1119:        rsb
        !          1120: 
        !          1121: /*
        !          1122:  * Copy 1 relocation unit (NBPG bytes)
        !          1123:  * from user virtual address to physical address
        !          1124:  */
        !          1125: _copyseg:      .globl  _copyseg
        !          1126:        .word   0x0
        !          1127:        bisl3   $PG_V|PG_KW,8(ap),_CMAP2
        !          1128:        mtpr    $_CADDR2,$TBIS  # invalidate entry for copy 
        !          1129:        movc3   $NBPG,*4(ap),_CADDR2
        !          1130:        ret
        !          1131: 
        !          1132: /*
        !          1133:  * zero out physical memory
        !          1134:  * specified in relocation units (NBPG bytes)
        !          1135:  */
        !          1136: _clearseg:     .globl  _clearseg
        !          1137:        .word   0x0
        !          1138:        bisl3   $PG_V|PG_KW,4(ap),_CMAP1
        !          1139:        mtpr    $_CADDR1,$TBIS
        !          1140:        movc5   $0,(sp),$0,$NBPG,_CADDR1
        !          1141:        ret
        !          1142: 
        !          1143: /*
        !          1144:  * Check address.
        !          1145:  * Given virtual address, byte count, and rw flag
        !          1146:  * returns 0 on no access.
        !          1147:  */
        !          1148: _useracc:      .globl  _useracc
        !          1149:        .word   0x0
        !          1150:        movl    4(ap),r0                # get va
        !          1151:        movl    8(ap),r1                # count
        !          1152:        tstl    12(ap)                  # test for read access ?
        !          1153:        bneq    userar                  # yes
        !          1154:        cmpl    $NBPG,r1                        # can we do it in one probe ?
        !          1155:        bgeq    uaw2                    # yes
        !          1156: uaw1:
        !          1157:        probew  $3,$NBPG,(r0)
        !          1158:        beql    uaerr                   # no access
        !          1159:        addl2   $NBPG,r0
        !          1160:        acbl    $NBPG+1,$-NBPG,r1,uaw1
        !          1161: uaw2:
        !          1162:        probew  $3,r1,(r0)
        !          1163:        beql    uaerr
        !          1164:        movl    $1,r0
        !          1165:        ret
        !          1166: 
        !          1167: userar:
        !          1168:        cmpl    $NBPG,r1
        !          1169:        bgeq    uar2
        !          1170: uar1:
        !          1171:        prober  $3,$NBPG,(r0)
        !          1172:        beql    uaerr
        !          1173:        addl2   $NBPG,r0
        !          1174:        acbl    $NBPG+1,$-NBPG,r1,uar1
        !          1175: uar2:
        !          1176:        prober  $3,r1,(r0)
        !          1177:        beql    uaerr
        !          1178:        movl    $1,r0
        !          1179:        ret
        !          1180: uaerr:
        !          1181:        clrl    r0
        !          1182:        ret
        !          1183: 
        !          1184: /*
        !          1185:  * kernacc - check for kernel access privileges
        !          1186:  *
        !          1187:  * We can't use the probe instruction directly because
        !          1188:  * it ors together current and previous mode.
        !          1189:  */
        !          1190:        .globl  _kernacc
        !          1191: _kernacc:
        !          1192:        .word   0x0
        !          1193:        movl    4(ap),r0        # virtual address
        !          1194:        bbcc    $31,r0,kacc1
        !          1195:        bbs     $30,r0,kacerr
        !          1196:        mfpr    $SBR,r2         # address and length of page table (system)
        !          1197:        bbss    $31,r2,0f; 0:
        !          1198:        mfpr    $SLR,r3
        !          1199:        brb     kacc2
        !          1200: kacc1:
        !          1201:        bbsc    $30,r0,kacc3
        !          1202:        mfpr    $P0BR,r2        # user P0
        !          1203:        mfpr    $P0LR,r3
        !          1204:        brb     kacc2
        !          1205: kacc3:
        !          1206:        mfpr    $P1BR,r2        # user P1 (stack)
        !          1207:        mfpr    $P1LR,r3
        !          1208: kacc2:
        !          1209:        addl3   8(ap),r0,r1     # ending virtual address
        !          1210:        addl2   $NBPG-1,r1
        !          1211:        ashl    $-PGSHIFT,r0,r0
        !          1212:        ashl    $-PGSHIFT,r1,r1
        !          1213:        bbs     $31,4(ap),kacc6
        !          1214:        bbc     $30,4(ap),kacc6
        !          1215:        cmpl    r0,r3           # user stack
        !          1216:        blss    kacerr          # address too low
        !          1217:        brb     kacc4
        !          1218: kacc6:
        !          1219:        cmpl    r1,r3           # compare last page to P0LR or SLR
        !          1220:        bgtr    kacerr          # address too high
        !          1221: kacc4: 
        !          1222:        movl    (r2)[r0],r3
        !          1223:        bbc     $31,4(ap),kacc4a
        !          1224:        bbc     $31,r3,kacerr   # valid bit is off
        !          1225: kacc4a:
        !          1226:        cmpzv   $27,$4,r3,$1    # check protection code
        !          1227:        bleq    kacerr          # no access allowed
        !          1228:        tstb    12(ap)
        !          1229:        bneq    kacc5           # only check read access
        !          1230:        cmpzv   $27,$2,r3,$3    # check low 2 bits of prot code
        !          1231:        beql    kacerr          # no write access
        !          1232: kacc5:
        !          1233:        aoblss  r1,r0,kacc4     # next page
        !          1234:        movl    $1,r0           # no errors
        !          1235:        ret
        !          1236: kacerr:
        !          1237:        clrl    r0              # error
        !          1238:        ret
        !          1239: /*
        !          1240:  * Extracted and unrolled most common case of pagein (hopefully):
        !          1241:  *     resident and not on free list (reclaim of page is purely
        !          1242:  *     for the purpose of simulating a reference bit)
        !          1243:  *
        !          1244:  * Built in constants:
        !          1245:  *     CLSIZE of 2, USRSTACK of 0x7ffff000, any bit fields
        !          1246:  *     in pte's or the core map
        !          1247:  */
        !          1248:        .text
        !          1249:        .globl  Fastreclaim
        !          1250: Fastreclaim:
        !          1251:        PUSHR
        !          1252:        extzv   $9,$23,28(sp),r3        # virtual address
        !          1253:        bicl2   $1,r3                   # v = clbase(btop(virtaddr)); 
        !          1254:        movl    _u+U_PROCP,r5           # p = u.u_procp 
        !          1255:                                        # from vtopte(p, v) ...
        !          1256:        cmpl    r3,P_TSIZE(r5)
        !          1257:        jgequ   2f                      # if (isatsv(p, v)) {
        !          1258:        ashl    $2,r3,r4
        !          1259:        addl2   P_P0BR(r5),r4           #       tptopte(p, vtotp(p, v));
        !          1260:        movl    $1,r2                   #       type = CTEXT;
        !          1261:        jbr     3f
        !          1262: 2:
        !          1263:        subl3   P_SSIZE(r5),$0x3ffff8,r0
        !          1264:        cmpl    r3,r0
        !          1265:        jgequ   2f                      # } else if (isadsv(p, v)) {
        !          1266:        ashl    $2,r3,r4
        !          1267:        addl2   P_P0BR(r5),r4           #       dptopte(p, vtodp(p, v));
        !          1268:        clrl    r2                      #       type = !CTEXT;
        !          1269:        jbr     3f
        !          1270: 2:
        !          1271:        cvtwl   P_SZPT(r5),r4           # } else (isassv(p, v)) {
        !          1272:        ashl    $7,r4,r4
        !          1273:        subl2   $(0x3ffff8+UPAGES),r4
        !          1274:        addl2   r3,r4
        !          1275:        ashl    $2,r4,r4
        !          1276:        addl2   P_P0BR(r5),r4           #       sptopte(p, vtosp(p, v));
        !          1277:        clrl    r2                      #       type = !CTEXT;
        !          1278: 3:                                     # }
        !          1279:        bitb    $0x82,3(r4)
        !          1280:        beql    2f                      # if (pte->pg_v || pte->pg_fod)
        !          1281:        POPR; rsb                       #       let pagein handle it
        !          1282: 2:
        !          1283:        bicl3   $0xffe00000,(r4),r0
        !          1284:        jneq    2f                      # if (pte->pg_pfnum == 0)
        !          1285:        POPR; rsb                       #       let pagein handle it 
        !          1286: 2:
        !          1287:        subl2   _firstfree,r0
        !          1288:        ashl    $-1,r0,r0       
        !          1289:        incl    r0                      # pgtocm(pte->pg_pfnum) 
        !          1290:        mull2   $12,r0
        !          1291:        addl2   _cmap,r0                # &cmap[pgtocm(pte->pg_pfnum)] 
        !          1292:        tstl    r2
        !          1293:        jeql    2f                      # if (type == CTEXT &&
        !          1294:        jbc     $29,4(r0),2f            #     c_intrans)
        !          1295:        POPR; rsb                       #       let pagein handle it
        !          1296: 2:
        !          1297:        jbc     $30,4(r0),2f            # if (c_free)
        !          1298:        POPR; rsb                       #       let pagein handle it 
        !          1299: 2:
        !          1300:        bisb2   $0x80,3(r4)             # pte->pg_v = 1;
        !          1301:        jbc     $26,4(r4),2f            # if (anycl(pte, pg_m) 
        !          1302:        bisb2   $0x04,3(r4)             #       pte->pg_m = 1;
        !          1303: 2:
        !          1304:        bicw3   $0x7f,2(r4),r0
        !          1305:        bicw3   $0xff80,6(r4),r1
        !          1306:        bisw3   r0,r1,6(r4)             # distcl(pte);
        !          1307:        ashl    $PGSHIFT,r3,r0
        !          1308:        mtpr    r0,$TBIS
        !          1309:        addl2   $NBPG,r0
        !          1310:        mtpr    r0,$TBIS                # tbiscl(v); 
        !          1311:        tstl    r2
        !          1312:        jeql    2f                      # if (type == CTEXT) 
        !          1313:        movl    P_TEXTP(r5),r0
        !          1314:        movl    X_CADDR(r0),r5          # for (p = p->p_textp->x_caddr; p; ) {
        !          1315:        jeql    2f
        !          1316:        ashl    $2,r3,r3
        !          1317: 3:
        !          1318:        addl3   P_P0BR(r5),r3,r0        #       tpte = tptopte(p, tp);
        !          1319:        bisb2   $1,P_FLAG+3(r5)         #       p->p_flag |= SPTECHG;
        !          1320:        movl    (r4),(r0)+              #       for (i = 0; i < CLSIZE; i++)
        !          1321:        movl    4(r4),(r0)              #               tpte[i] = pte[i];
        !          1322:        movl    P_XLINK(r5),r5          #       p = p->p_xlink;
        !          1323:        jneq    3b                      # }
        !          1324: 2:                                     # collect a few statistics...
        !          1325:        incl    _u+U_RU+RU_MINFLT       # u.u_ru.ru_minflt++;
        !          1326:        moval   _cnt,r0
        !          1327:        incl    V_FAULTS(r0)            # cnt.v_faults++; 
        !          1328:        incl    V_PGREC(r0)             # cnt.v_pgrec++;
        !          1329:        incl    V_FASTPGREC(r0)         # cnt.v_fastpgrec++;
        !          1330:        incl    V_TRAP(r0)              # cnt.v_trap++;
        !          1331:        POPR
        !          1332:        addl2   $8,sp                   # pop pc, code
        !          1333:        mtpr    $HIGH,$IPL              ## dont go to a higher IPL (GROT)
        !          1334:        rei
        !          1335:        .globl  _Xrkintr0
        !          1336:        .align  2
        !          1337: _Xrkintr0:
        !          1338:        pushr   $0x3f
        !          1339:        pushl   $0
        !          1340:        calls   $1,_rkintr
        !          1341:        popr    $0x3f
        !          1342: #if defined(VAX750) || defined(VAX730)
        !          1343:        incl    _cnt+V_INTR
        !          1344: #endif
        !          1345:        rei
        !          1346: 
        !          1347:        .globl  _Xtmintr0
        !          1348:        .align  2
        !          1349: _Xtmintr0:
        !          1350:        pushr   $0x3f
        !          1351:        pushl   $0
        !          1352:        calls   $1,_tmintr
        !          1353:        popr    $0x3f
        !          1354: #if defined(VAX750) || defined(VAX730)
        !          1355:        incl    _cnt+V_INTR
        !          1356: #endif
        !          1357:        rei
        !          1358: 
        !          1359:        .globl  _Xutintr0
        !          1360:        .align  2
        !          1361: _Xutintr0:
        !          1362:        pushr   $0x3f
        !          1363:        pushl   $0
        !          1364:        calls   $1,_utintr
        !          1365:        popr    $0x3f
        !          1366: #if defined(VAX750) || defined(VAX730)
        !          1367:        incl    _cnt+V_INTR
        !          1368: #endif
        !          1369:        rei
        !          1370: 
        !          1371:        .globl  _Xupintr0
        !          1372:        .align  2
        !          1373: _Xupintr0:
        !          1374:        pushr   $0x3f
        !          1375:        pushl   $0
        !          1376:        calls   $1,_upintr
        !          1377:        popr    $0x3f
        !          1378: #if defined(VAX750) || defined(VAX730)
        !          1379:        incl    _cnt+V_INTR
        !          1380: #endif
        !          1381:        rei
        !          1382: 
        !          1383:        .globl  _Xudintr0
        !          1384:        .align  2
        !          1385: _Xudintr0:
        !          1386:        pushr   $0x3f
        !          1387:        pushl   $0
        !          1388:        calls   $1,_udintr
        !          1389:        popr    $0x3f
        !          1390: #if defined(VAX750) || defined(VAX730)
        !          1391:        incl    _cnt+V_INTR
        !          1392: #endif
        !          1393:        rei
        !          1394: 
        !          1395:        .globl  _Xidcintr0
        !          1396:        .align  2
        !          1397: _Xidcintr0:
        !          1398:        pushr   $0x3f
        !          1399:        pushl   $0
        !          1400:        calls   $1,_idcintr
        !          1401:        popr    $0x3f
        !          1402: #if defined(VAX750) || defined(VAX730)
        !          1403:        incl    _cnt+V_INTR
        !          1404: #endif
        !          1405:        rei
        !          1406: 
        !          1407:        .globl  _Xrlintr0
        !          1408:        .align  2
        !          1409: _Xrlintr0:
        !          1410:        pushr   $0x3f
        !          1411:        pushl   $0
        !          1412:        calls   $1,_rlintr
        !          1413:        popr    $0x3f
        !          1414: #if defined(VAX750) || defined(VAX730)
        !          1415:        incl    _cnt+V_INTR
        !          1416: #endif
        !          1417:        rei
        !          1418: 
        !          1419:        .globl  _Xdhrint0
        !          1420:        .align  2
        !          1421: _Xdhrint0:
        !          1422:        pushr   $0x3f
        !          1423:        pushl   $0
        !          1424:        calls   $1,_dhrint
        !          1425:        popr    $0x3f
        !          1426: #if defined(VAX750) || defined(VAX730)
        !          1427:        incl    _cnt+V_INTR
        !          1428: #endif
        !          1429:        rei
        !          1430: 
        !          1431:        .globl  _Xdhxint0
        !          1432:        .align  2
        !          1433: _Xdhxint0:
        !          1434:        pushr   $0x3f
        !          1435:        pushl   $0
        !          1436:        calls   $1,_dhxint
        !          1437:        popr    $0x3f
        !          1438: #if defined(VAX750) || defined(VAX730)
        !          1439:        incl    _cnt+V_INTR
        !          1440: #endif
        !          1441:        rei
        !          1442: 
        !          1443:        .globl  _Xdmintr0
        !          1444:        .align  2
        !          1445: _Xdmintr0:
        !          1446:        pushr   $0x3f
        !          1447:        pushl   $0
        !          1448:        calls   $1,_dmintr
        !          1449:        popr    $0x3f
        !          1450: #if defined(VAX750) || defined(VAX730)
        !          1451:        incl    _cnt+V_INTR
        !          1452: #endif
        !          1453:        rei
        !          1454: 
        !          1455:        .globl  _Xdhrint1
        !          1456:        .align  2
        !          1457: _Xdhrint1:
        !          1458:        pushr   $0x3f
        !          1459:        pushl   $1
        !          1460:        calls   $1,_dhrint
        !          1461:        popr    $0x3f
        !          1462: #if defined(VAX750) || defined(VAX730)
        !          1463:        incl    _cnt+V_INTR
        !          1464: #endif
        !          1465:        rei
        !          1466: 
        !          1467:        .globl  _Xdhxint1
        !          1468:        .align  2
        !          1469: _Xdhxint1:
        !          1470:        pushr   $0x3f
        !          1471:        pushl   $1
        !          1472:        calls   $1,_dhxint
        !          1473:        popr    $0x3f
        !          1474: #if defined(VAX750) || defined(VAX730)
        !          1475:        incl    _cnt+V_INTR
        !          1476: #endif
        !          1477:        rei
        !          1478: 
        !          1479:        .globl  _Xdzrint0
        !          1480:        .align  2
        !          1481: _Xdzrint0:
        !          1482:        pushr   $0x3f
        !          1483:        pushl   $0
        !          1484:        calls   $1,_dzrint
        !          1485:        popr    $0x3f
        !          1486: #if defined(VAX750) || defined(VAX730)
        !          1487:        incl    _cnt+V_INTR
        !          1488: #endif
        !          1489:        rei
        !          1490: 
        !          1491:        .globl  _Xdzxint0
        !          1492:        .align  2
        !          1493: _Xdzxint0:
        !          1494:        pushr   $0x3f
        !          1495:        movl    $0,r0
        !          1496:        jmp     dzdma
        !          1497: 
        !          1498:        .globl  _Xdzrint1
        !          1499:        .align  2
        !          1500: _Xdzrint1:
        !          1501:        pushr   $0x3f
        !          1502:        pushl   $1
        !          1503:        calls   $1,_dzrint
        !          1504:        popr    $0x3f
        !          1505: #if defined(VAX750) || defined(VAX730)
        !          1506:        incl    _cnt+V_INTR
        !          1507: #endif
        !          1508:        rei
        !          1509: 
        !          1510:        .globl  _Xdzxint1
        !          1511:        .align  2
        !          1512: _Xdzxint1:
        !          1513:        pushr   $0x3f
        !          1514:        movl    $1,r0
        !          1515:        jmp     dzdma
        !          1516: 
        !          1517:        .globl  _Xdzrint2
        !          1518:        .align  2
        !          1519: _Xdzrint2:
        !          1520:        pushr   $0x3f
        !          1521:        pushl   $2
        !          1522:        calls   $1,_dzrint
        !          1523:        popr    $0x3f
        !          1524: #if defined(VAX750) || defined(VAX730)
        !          1525:        incl    _cnt+V_INTR
        !          1526: #endif
        !          1527:        rei
        !          1528: 
        !          1529:        .globl  _Xdzxint2
        !          1530:        .align  2
        !          1531: _Xdzxint2:
        !          1532:        pushr   $0x3f
        !          1533:        movl    $2,r0
        !          1534:        jmp     dzdma
        !          1535: 
        !          1536:        .globl  _Xdzrint3
        !          1537:        .align  2
        !          1538: _Xdzrint3:
        !          1539:        pushr   $0x3f
        !          1540:        pushl   $3
        !          1541:        calls   $1,_dzrint
        !          1542:        popr    $0x3f
        !          1543: #if defined(VAX750) || defined(VAX730)
        !          1544:        incl    _cnt+V_INTR
        !          1545: #endif
        !          1546:        rei
        !          1547: 
        !          1548:        .globl  _Xdzxint3
        !          1549:        .align  2
        !          1550: _Xdzxint3:
        !          1551:        pushr   $0x3f
        !          1552:        movl    $3,r0
        !          1553:        jmp     dzdma
        !          1554: 
        !          1555:        .globl  _Xdzrint4
        !          1556:        .align  2
        !          1557: _Xdzrint4:
        !          1558:        pushr   $0x3f
        !          1559:        pushl   $4
        !          1560:        calls   $1,_dzrint
        !          1561:        popr    $0x3f
        !          1562: #if defined(VAX750) || defined(VAX730)
        !          1563:        incl    _cnt+V_INTR
        !          1564: #endif
        !          1565:        rei
        !          1566: 
        !          1567:        .globl  _Xdzxint4
        !          1568:        .align  2
        !          1569: _Xdzxint4:
        !          1570:        pushr   $0x3f
        !          1571:        movl    $4,r0
        !          1572:        jmp     dzdma
        !          1573: 
        !          1574:        .globl  _Xdzrint5
        !          1575:        .align  2
        !          1576: _Xdzrint5:
        !          1577:        pushr   $0x3f
        !          1578:        pushl   $5
        !          1579:        calls   $1,_dzrint
        !          1580:        popr    $0x3f
        !          1581: #if defined(VAX750) || defined(VAX730)
        !          1582:        incl    _cnt+V_INTR
        !          1583: #endif
        !          1584:        rei
        !          1585: 
        !          1586:        .globl  _Xdzxint5
        !          1587:        .align  2
        !          1588: _Xdzxint5:
        !          1589:        pushr   $0x3f
        !          1590:        movl    $5,r0
        !          1591:        jmp     dzdma
        !          1592: 
        !          1593:        .globl  _Xdzrint6
        !          1594:        .align  2
        !          1595: _Xdzrint6:
        !          1596:        pushr   $0x3f
        !          1597:        pushl   $6
        !          1598:        calls   $1,_dzrint
        !          1599:        popr    $0x3f
        !          1600: #if defined(VAX750) || defined(VAX730)
        !          1601:        incl    _cnt+V_INTR
        !          1602: #endif
        !          1603:        rei
        !          1604: 
        !          1605:        .globl  _Xdzxint6
        !          1606:        .align  2
        !          1607: _Xdzxint6:
        !          1608:        pushr   $0x3f
        !          1609:        movl    $6,r0
        !          1610:        jmp     dzdma
        !          1611: 
        !          1612:        .globl  _Xdzrint7
        !          1613:        .align  2
        !          1614: _Xdzrint7:
        !          1615:        pushr   $0x3f
        !          1616:        pushl   $7
        !          1617:        calls   $1,_dzrint
        !          1618:        popr    $0x3f
        !          1619: #if defined(VAX750) || defined(VAX730)
        !          1620:        incl    _cnt+V_INTR
        !          1621: #endif
        !          1622:        rei
        !          1623: 
        !          1624:        .globl  _Xdzxint7
        !          1625:        .align  2
        !          1626: _Xdzxint7:
        !          1627:        pushr   $0x3f
        !          1628:        movl    $7,r0
        !          1629:        jmp     dzdma
        !          1630: 
        !          1631:        .globl  _Xtsintr0
        !          1632:        .align  2
        !          1633: _Xtsintr0:
        !          1634:        pushr   $0x3f
        !          1635:        pushl   $0
        !          1636:        calls   $1,_tsintr
        !          1637:        popr    $0x3f
        !          1638: #if defined(VAX750) || defined(VAX730)
        !          1639:        incl    _cnt+V_INTR
        !          1640: #endif
        !          1641:        rei
        !          1642: 
        !          1643:        .globl  _Xdmfsrint0
        !          1644:        .align  2
        !          1645: _Xdmfsrint0:
        !          1646:        pushr   $0x3f
        !          1647:        pushl   $0
        !          1648:        calls   $1,_dmfsrint
        !          1649:        popr    $0x3f
        !          1650: #if defined(VAX750) || defined(VAX730)
        !          1651:        incl    _cnt+V_INTR
        !          1652: #endif
        !          1653:        rei
        !          1654: 
        !          1655:        .globl  _Xdmfsxint0
        !          1656:        .align  2
        !          1657: _Xdmfsxint0:
        !          1658:        pushr   $0x3f
        !          1659:        pushl   $0
        !          1660:        calls   $1,_dmfsxint
        !          1661:        popr    $0x3f
        !          1662: #if defined(VAX750) || defined(VAX730)
        !          1663:        incl    _cnt+V_INTR
        !          1664: #endif
        !          1665:        rei
        !          1666: 
        !          1667:        .globl  _Xdmfdaint0
        !          1668:        .align  2
        !          1669: _Xdmfdaint0:
        !          1670:        pushr   $0x3f
        !          1671:        pushl   $0
        !          1672:        calls   $1,_dmfdaint
        !          1673:        popr    $0x3f
        !          1674: #if defined(VAX750) || defined(VAX730)
        !          1675:        incl    _cnt+V_INTR
        !          1676: #endif
        !          1677:        rei
        !          1678: 
        !          1679:        .globl  _Xdmfdbint0
        !          1680:        .align  2
        !          1681: _Xdmfdbint0:
        !          1682:        pushr   $0x3f
        !          1683:        pushl   $0
        !          1684:        calls   $1,_dmfdbint
        !          1685:        popr    $0x3f
        !          1686: #if defined(VAX750) || defined(VAX730)
        !          1687:        incl    _cnt+V_INTR
        !          1688: #endif
        !          1689:        rei
        !          1690: 
        !          1691:        .globl  _Xdmfrint0
        !          1692:        .align  2
        !          1693: _Xdmfrint0:
        !          1694:        pushr   $0x3f
        !          1695:        pushl   $0
        !          1696:        calls   $1,_dmfrint
        !          1697:        popr    $0x3f
        !          1698: #if defined(VAX750) || defined(VAX730)
        !          1699:        incl    _cnt+V_INTR
        !          1700: #endif
        !          1701:        rei
        !          1702: 
        !          1703:        .globl  _Xdmfxint0
        !          1704:        .align  2
        !          1705: _Xdmfxint0:
        !          1706:        pushr   $0x3f
        !          1707:        pushl   $0
        !          1708:        calls   $1,_dmfxint
        !          1709:        popr    $0x3f
        !          1710: #if defined(VAX750) || defined(VAX730)
        !          1711:        incl    _cnt+V_INTR
        !          1712: #endif
        !          1713:        rei
        !          1714: 
        !          1715:        .globl  _Xdmflint0
        !          1716:        .align  2
        !          1717: _Xdmflint0:
        !          1718:        pushr   $0x3f
        !          1719:        pushl   $0
        !          1720:        calls   $1,_dmflint
        !          1721:        popr    $0x3f
        !          1722: #if defined(VAX750) || defined(VAX730)
        !          1723:        incl    _cnt+V_INTR
        !          1724: #endif
        !          1725:        rei
        !          1726: 
        !          1727:        .globl  _Xlpintr0
        !          1728:        .align  2
        !          1729: _Xlpintr0:
        !          1730:        pushr   $0x3f
        !          1731:        pushl   $0
        !          1732:        calls   $1,_lpintr
        !          1733:        popr    $0x3f
        !          1734: #if defined(VAX750) || defined(VAX730)
        !          1735:        incl    _cnt+V_INTR
        !          1736: #endif
        !          1737:        rei
        !          1738: 

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.