Annotation of 43BSD/sys/stand/autoconf.c, revision 1.1.1.1

1.1       root        1: /*
                      2:  * Copyright (c) 1982, 1986 Regents of the University of California.
                      3:  * All rights reserved.  The Berkeley software License Agreement
                      4:  * specifies the terms and conditions for redistribution.
                      5:  *
                      6:  *     @(#)autoconf.c  7.1 (Berkeley) 6/5/86
                      7:  */
                      8: 
                      9: #include "../machine/pte.h"
                     10: 
                     11: #include "../h/param.h"
                     12: 
                     13: #include "../vax/cpu.h"
                     14: #include "../vax/nexus.h"
                     15: #include "../vaxuba/ubareg.h"
                     16: #include "../vaxmba/mbareg.h"
                     17: #include "../vax/mtpr.h"
                     18: 
                     19: #include "savax.h"
                     20: 
                     21: #define        UTR(i)  ((struct uba_regs *)(NEX780+(i)))
                     22: #define        UMA(i)  ((caddr_t)UMEM780(i))
                     23: #define        MTR(i)  ((struct mba_regs *)(NEX780+(i)))
                     24: 
                     25: struct uba_regs *ubaddr780[] = { UTR(3), UTR(4), UTR(5), UTR(6) };
                     26: caddr_t        umaddr780[] = { UMA(0), UMA(1), UMA(2), UMA(3) };
                     27: struct mba_regs *mbaddr780[] = { MTR(8), MTR(9), MTR(10), MTR(11) };
                     28: 
                     29: #undef UTR
                     30: #undef UMA
                     31: #undef MTR
                     32: 
                     33: #define        UTR(i)  ((struct uba_regs *)(NEX750+(i)))
                     34: #define        UMA(i)  ((caddr_t)UMEM750(i))
                     35: #define        MTR(i)  ((struct mba_regs *)(NEX750+(i)))
                     36: 
                     37: struct uba_regs *ubaddr750[] = { UTR(8), UTR(9) };
                     38: caddr_t        umaddr750[] = { UMA(0), UMA(1) };
                     39: struct mba_regs *mbaddr750[] = { MTR(4), MTR(5), MTR(6), MTR(7) };
                     40: 
                     41: #undef UTR
                     42: #undef UMA
                     43: #undef MTR
                     44: 
                     45: #define        UTR(i)  ((struct uba_regs *)(NEX730+(i)))
                     46: #define        UMA     ((caddr_t)UMEM730)
                     47: 
                     48: struct uba_regs *ubaddr730[] = { UTR(3) };
                     49: caddr_t        umaddr730[] = { UMA };
                     50: 
                     51: #undef UTR
                     52: #undef UMA
                     53: 
                     54: configure()
                     55: {
                     56:        union cpusid cpusid;
                     57:        int nmba, nuba, i;
                     58: 
                     59:        cpusid.cpusid = mfpr(SID);
                     60:        cpu = cpusid.cpuany.cp_type;
                     61:        switch (cpu) {
                     62: 
                     63:        case VAX_8600:
                     64:        case VAX_780:
                     65:                mbaddr = mbaddr780;
                     66:                ubaddr = ubaddr780;
                     67:                umaddr = umaddr780;
                     68:                nmba = sizeof (mbaddr780) / sizeof (mbaddr780[0]);
                     69:                nuba = sizeof (ubaddr780) / sizeof (ubaddr780[0]);
                     70:                break;
                     71: 
                     72:        case VAX_750:
                     73:                mbaddr = mbaddr750;
                     74:                ubaddr = ubaddr750;
                     75:                umaddr = umaddr750;
                     76:                nmba = sizeof (mbaddr750) / sizeof (mbaddr750[0]);
                     77:                nuba = 0;
                     78:                break;
                     79: 
                     80:        case VAX_730:
                     81:                ubaddr = ubaddr730;
                     82:                umaddr = umaddr730;
                     83:                nmba = nuba = 0;
                     84:                break;
                     85:        }
                     86:        /*
                     87:         * Forward into the past...
                     88:         */
                     89: /*
                     90:        for (i = 0; i < nmba; i++)
                     91:                if (!badloc(mbaddr[i]))
                     92:                        mbaddr[i]->mba_cr = MBCR_INIT;
                     93: */
                     94:        for (i = 0; i < nuba; i++)
                     95:                if (!badloc(ubaddr[i]))
                     96:                        ubaddr[i]->uba_cr = UBACR_ADINIT;
                     97:        if ((cpu != VAX_780) && (cpu != VAX_8600))
                     98:                mtpr(IUR, 0);
                     99:        /* give unibus devices a chance to recover... */
                    100:        if (nuba > 0)
                    101:                DELAY(2000000);
                    102: }

unix.superglobalmegacorp.com

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