Annotation of researchv9/cmd/adb/vax/mchsys.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * system-mode mapping
        !             3:  * vax version
        !             4:  */
        !             5: 
        !             6: #include "defs.h"
        !             7: #include "space.h"
        !             8: #include <sys/param.h>
        !             9: #include <sys/pte.h>
        !            10: #include <sys/pcb.h>
        !            11: #include "machine.h"
        !            12: 
        !            13: static struct pte *sbr;
        !            14: static WORD svpcbb;
        !            15: static struct pcb pcb;
        !            16: #define        HWPAGE  512
        !            17: 
        !            18: printkm()
        !            19: {
        !            20: 
        !            21:        if (sbr)
        !            22:                printf("%R$k\n", (WORD)sbr);
        !            23:        if (svpcbb)
        !            24:                printf("%R$p\np0 %R %R; p1 %R %R\n", svpcbb,
        !            25:                        (WORD)pcb.pcb_p0br, (WORD)pcb.pcb_p0lr,
        !            26:                        (WORD)pcb.pcb_p1br, (WORD)pcb.pcb_p1lr);
        !            27: }
        !            28: 
        !            29: kmsys()
        !            30: {
        !            31: 
        !            32:        if (adrflg)
        !            33:                sbr = (struct pte *)adrval;
        !            34:        else
        !            35:                printkm();
        !            36: }
        !            37: 
        !            38: kmproc()
        !            39: {
        !            40:        struct pte pte;
        !            41: 
        !            42:        if (adrflg == 0) {
        !            43:                printkm();
        !            44:                return;
        !            45:        }
        !            46:        if (adrval == -1) {
        !            47:                svpcbb = 0;
        !            48:                return;
        !            49:        }
        !            50:        if (sbr == 0)
        !            51:                error("map the kernel first");
        !            52:        if (INKERNEL(adrval)) {
        !            53:                *(long *)&pte = lget((ADDR)adrval, CORF|DATASP);
        !            54:                if (pte.pg_v == 0)
        !            55:                        error("pcb address not found");
        !            56:                adrval = pte.pg_pfnum * HWPAGE;
        !            57:        }
        !            58:        if (fget((ADDR)adrval, CORF|DATASP|RAWADDR, (char *)&pcb, sizeof(pcb)) == 0) {
        !            59:                svpcbb = 0;
        !            60:                chkerr();
        !            61:        }
        !            62:        svpcbb = adrval;
        !            63: }
        !            64: 
        !            65: /*
        !            66:  * map a kernel address to a physical address
        !            67:  * arg is a pointer to be filled in
        !            68:  * returns nonzero if address is valid
        !            69:  */
        !            70: 
        !            71: int
        !            72: kmap(paddr, sp)
        !            73: ADDR *paddr;
        !            74: {
        !            75:        long a;
        !            76:        long pte;
        !            77: #define        Ppte    (*(struct pte *)&pte)
        !            78:        register int off, pfn;
        !            79: 
        !            80:        if (sbr == 0)
        !            81:                return (1);
        !            82:        sp &=~ RAWADDR;
        !            83:        a = (long)*paddr & ~0xc0000000;
        !            84:        off = a % HWPAGE;
        !            85:        pfn = (a / HWPAGE);
        !            86:        switch ((int)*paddr & 0xc0000000) {
        !            87:        case 0xc0000000:                /* really illegal, but who cares? */
        !            88:        case 0x80000000:                /* system space */
        !            89:                pte = (long)lget((ADDR)(sbr + pfn), sp | RAWADDR);
        !            90:                break;
        !            91: 
        !            92:        case 0x40000000:                /* p1 */
        !            93:                if (svpcbb == 0)
        !            94:                        return (1);
        !            95:                if (pfn <= pcb.pcb_p1lr)
        !            96:                        return (0);
        !            97:                pte = lget((ADDR)(pcb.pcb_p1br + pfn), sp);
        !            98:                if (errflg)
        !            99:                        return (0);
        !           100:                break;
        !           101: 
        !           102:        case 0x00000000:                /* p0 */
        !           103:                if (svpcbb == 0)
        !           104:                        return (1);
        !           105:                if (pfn > pcb.pcb_p0lr)
        !           106:                        return (0);
        !           107:                pte = lget((ADDR)(pcb.pcb_p0br + pfn), sp);
        !           108:                if (errflg)
        !           109:                        return (0);
        !           110:                break;
        !           111:        }
        !           112:        if (Ppte.pg_v == 0)
        !           113:                return (0);
        !           114:        *paddr = (ADDR)(Ppte.pg_pfnum * HWPAGE + off);
        !           115:        return (1);
        !           116: }

unix.superglobalmegacorp.com

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