Annotation of 43BSDReno/sys/vaxuba/qdreg.h, revision 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:  *             @(#)qdreg.h     1.5  Berkeley  6/14/88
        !             7:  */
        !             8: 
        !             9: /************************************************************************
        !            10:  *                                                                     *
        !            11:  *                     Copyright (c) 1985, 1986 by                     *
        !            12:  *             Digital Equipment Corporation, Maynard, MA              *
        !            13:  *                     All rights reserved.                            *
        !            14:  *                                                                     *
        !            15:  *   This software is furnished under a license and may be used and    *
        !            16:  *   copied  only  in accordance with the terms of such license and    *
        !            17:  *   with the  inclusion  of  the  above  copyright  notice.   This    *
        !            18:  *   software  or  any other copies thereof may not be provided or     *
        !            19:  *   otherwise made available to any other person.  No title to and    *
        !            20:  *   ownership of the software is hereby transferred.                  *
        !            21:  *                                                                     *
        !            22:  *   The information in this software is subject to change  without    *
        !            23:  *   notice  and should not be construed as a commitment by Digital    *
        !            24:  *   Equipment Corporation.                                            *
        !            25:  *                                                                     *
        !            26:  *   Digital assumes no responsibility for the use  or reliability     *
        !            27:  *   of its software on equipment which is not supplied by Digital.    *
        !            28:  *                                                                     *
        !            29:  ************************************************************************/
        !            30: 
        !            31: /* Dragon ADDER reg map */
        !            32: /* ADDER register bit definitions */
        !            33: /* Y_SCROLL_CONSTANT */
        !            34: 
        !            35: #define SCROLL_ERASE           0x2000
        !            36: #define ADDER_SCROLL_DOWN      0x1000
        !            37: 
        !            38: /* ADDER status and interrupt enable registers [1], [2], [3] */
        !            39: 
        !            40: #define DISABLE                0x0000
        !            41: #define PAUSE_COMPLETE         0x0001
        !            42: #define FRAME_SYNC             0x0002
        !            43: #define INIT_COMPLETE          0x0004
        !            44: #define RASTEROP_COMPLETE      0x0008
        !            45: 
        !            46: #define ADDRESS_COMPLETE       0x0010
        !            47: #define RX_READY               0x0020
        !            48: #define TX_READY               0x0040
        !            49: #define ID_SCROLL_READY        0x0080
        !            50: 
        !            51: #define TOP_CLIP               0x0100
        !            52: #define BOTTOM_CLIP            0x0200
        !            53: #define LEFT_CLIP              0x0400
        !            54: #define RIGHT_CLIP             0x0800
        !            55: #define NO_CLIP                0x1000
        !            56: #define VSYNC                  0x2000
        !            57: 
        !            58: /* ADDER command register [8], [10] */
        !            59: 
        !            60: #define OCR_zero               0x0000
        !            61: #define Z_BLOCK0               0x0000
        !            62: #define OCRA                   0x0000
        !            63: #define OCRB                   0x0004
        !            64: #define RASTEROP               0x02c0
        !            65: #define PBT                    0x03c0
        !            66: #define BTPZ                   0x0bb0
        !            67: #define PTBZ                   0x07a0
        !            68: #define DTE                    0x0400
        !            69: #define S1E                    0x0800
        !            70: #define S2E                    0x1000
        !            71: #define VIPER_Z_LOAD           0x01A0
        !            72: #define ID_LOAD                0x0100
        !            73: #define CANCEL                 0x0000
        !            74: #define LF_R1                  0x0000
        !            75: #define LF_R2                  0x0010
        !            76: #define LF_R3                  0x0020
        !            77: #define LF_R4                  0x0030
        !            78: 
        !            79: /* ADDER rasterop mode register [9] */
        !            80: 
        !            81: #define NORMAL                 0x0000
        !            82: #define LINEAR_PATTERN         0x0002
        !            83: #define X_FILL                 0x0003
        !            84: #define Y_FILL                 0x0007
        !            85: #define BASELINE               0x0008
        !            86: #define HOLE_ENABLE            0x0010
        !            87: #define SRC_1_INDEX_ENABLE     0x0020
        !            88: #define DST_INDEX_ENABLE       0x0040
        !            89: #define DST_WRITE_ENABLE       0x0080
        !            90: 
        !            91: /* ADDER source 2 size register */
        !            92: 
        !            93: #define NO_TILE                0x0080
        !            94: 
        !            95: /* External registers base addresses */
        !            96: 
        !            97: #define CS_UPDATE_MASK         0x0060
        !            98: #define CS_SCROLL_MASK         0x0040
        !            99: 
        !           100: /* VIPER registers */
        !           101: 
        !           102: #define RESOLUTION_MODE        0x0080
        !           103: #define MEMORY_BUS_WIDTH       0x0081
        !           104: #define PLANE_ADDRESS          0x0083
        !           105: #define LU_FUNCTION_R1         0x0084
        !           106: #define LU_FUNCTION_R2         0x0085
        !           107: #define LU_FUNCTION_R3         0x0086
        !           108: #define LU_FUNCTION_R4         0x0087
        !           109: #define MASK_1                 0x0088
        !           110: #define MASK_2                 0x0089
        !           111: #define SOURCE                 0x008a
        !           112: #define SOURCE_Z               0x0000
        !           113: #define BACKGROUND_COLOR       0x008e
        !           114: #define BACKGROUND_COLOR_Z     0x000C
        !           115: #define FOREGROUND_COLOR       0x008f
        !           116: #define FOREGROUND_COLOR_Z     0x0004
        !           117: #define SRC1_OCR_A             0x0090
        !           118: #define SRC2_OCR_A             0x0091
        !           119: #define DST_OCR_A              0x0092
        !           120: #define SRC1_OCR_B             0x0094
        !           121: #define SRC2_OCR_B             0x0095
        !           122: #define DST_OCR_B              0x0096
        !           123: 
        !           124: /* VIPER scroll registers */
        !           125: 
        !           126: #define SCROLL_CONSTANT        0x0082
        !           127: #define SCROLL_FILL            0x008b
        !           128: #define SCROLL_FILL_Z          0x0008
        !           129: #define LEFT_SCROLL_MASK       0x008c
        !           130: #define RIGHT_SCROLL_MASK      0x008d
        !           131: 
        !           132: /* VIPER register bit definitions */
        !           133: 
        !           134: #define EXT_NONE               0x0000
        !           135: #define EXT_SOURCE             0x0001
        !           136: #define EXT_M1_M2              0x0002
        !           137: #define INT_NONE               0x0000
        !           138: #define INT_SOURCE             0x0004
        !           139: #define INT_M1_M2              0x0008
        !           140: #define ID                     0x0010
        !           141: #define NO_ID                  0x0000
        !           142: #define WAIT                   0x0020
        !           143: #define NO_WAIT                0x0000
        !           144: #define BAR_SHIFT_DELAY        WAIT
        !           145: #define NO_BAR_SHIFT_DELAY     NO_WAIT
        !           146: 
        !           147: 
        !           148: /* VIPER logical function unit codes */
        !           149: 
        !           150: #define LF_ZEROS               0x0000
        !           151: #define LF_D_XOR_S             0x0006
        !           152: #define LF_SOURCE              0x000A
        !           153: #define LF_D_OR_S              0x000E
        !           154: #define LF_ONES                0x000F
        !           155: #define INV_M1_M2              0x0030
        !           156: #define FULL_SRC_RESOLUTION    0X00C0 /* makes second pass like first pass */
        !           157: 
        !           158: /* VIPER scroll register [2] */
        !           159: 
        !           160: #define SCROLL_DISABLE         0x0040
        !           161: #define SCROLL_ENABLE          0x0020
        !           162: #define VIPER_LEFT             0x0000
        !           163: #define VIPER_RIGHT            0x0010
        !           164: #define VIPER_UP               0x0040
        !           165: #define VIPER_DOWN             0x0000
        !           166: 
        !           167: /* Adder scroll register */
        !           168: 
        !           169: #define ADDER_UP               0x0000
        !           170: #define ADDER_DOWN             0x1000
        !           171: 
        !           172: /* Misc scroll definitions */
        !           173: 
        !           174: #define UP             0
        !           175: #define DOWN           1
        !           176: #define LEFT           2
        !           177: #define RIGHT          3
        !           178: #define NODIR          4
        !           179: #define SCROLL_VMAX    31
        !           180: #define SCROLL_HMAX    15
        !           181: #define NEW            2
        !           182: #define OLD            1
        !           183: #define BUSY           1
        !           184: #define DRAG           1
        !           185: #define SCROLL         0
        !           186: 
        !           187: /* miscellaneous defines */
        !           188: 
        !           189: #define ALL_PLANES     0xffffffff
        !           190: #define UNITY          0x1fff           /* Adder scale factor */
        !           191: #define MAX_SCREEN_X   1024
        !           192: #define MAX_SCREEN_Y   864
        !           193: #define FONT_HEIGHT    32
        !           194: 
        !           195:        struct adder {
        !           196: 
        !           197:            /* adder control registers */
        !           198: 
        !           199:            u_short register_address;   /* ADDER reg pntr for use by DGA */
        !           200:            u_short request_enable;     /* DMA request enables */
        !           201:            u_short interrupt_enable;   /* interrupt enables */
        !           202:            u_short status;             /* ADDER status bits */
        !           203:            u_short reserved1;          /* test function only */
        !           204:            u_short spare1;             /* spare address (what else?) */
        !           205: 
        !           206:            u_short reserved2;          /* test function only */
        !           207:            u_short id_data;            /* data path to I/D bus */
        !           208:            u_short command;            /* ADDER chip command register */
        !           209:            u_short rasterop_mode;      /* sets rasterop execution modes */
        !           210:            u_short cmd;                /* duplicate path to above cmd reg */
        !           211:            u_short reserved3;          /* test function only */
        !           212: 
        !           213:            /* scroll registers */
        !           214: 
        !           215:            u_short ID_scroll_data;     /* I/D bus scroll data */
        !           216:            u_short ID_scroll_command;  /* I/D bus scroll command */
        !           217:            u_short scroll_x_min;       /* X scroll min - left boundary */
        !           218:            u_short scroll_x_max;       /* X scroll max - right boundary */
        !           219:            u_short scroll_y_min;       /* Y scroll min - upper boundary */
        !           220:            u_short scroll_y_max;       /* Y scroll max - lower boundary */
        !           221:            u_short pause;              /* Y coord to set stat when scanned */
        !           222:            u_short y_offset_pending;   /* vertical scroll control */
        !           223:            u_short y_scroll_constant;
        !           224: 
        !           225:            /* update control registers */
        !           226: 
        !           227:            u_short x_index_pending;    /* x pending index */
        !           228:            u_short y_index_pending;    /* y pending index */
        !           229:            u_short x_index_new;        /* new x index */
        !           230:            u_short y_index_new;                /* new y index */
        !           231:            u_short x_index_old;                /* old x index */
        !           232:            u_short y_index_old;                /* old y index */
        !           233:            u_short x_clip_min;         /* left clipping boundary */
        !           234:            u_short x_clip_max;         /* right clipping boundary */
        !           235:            u_short y_clip_min;         /* upper clipping boundary */
        !           236:            u_short y_clip_max;         /* lower clipping boundary */
        !           237:            u_short spare2;             /* spare address (another!) */
        !           238: 
        !           239:            /* rasterop control registers */
        !           240: 
        !           241:            u_short source_1_dx;        /* source #1 x vector */
        !           242:            u_short source_1_dy;        /* source #1 y vector*/
        !           243:            u_short source_1_x;         /* source #1 x origin */
        !           244:            u_short source_1_y;         /* source #1 y origin */
        !           245:            u_short destination_x;      /* destination x origin */
        !           246:            u_short destination_y;      /* destination y origin */
        !           247:            u_short fast_dest_dx;       /* destination x fast vector */
        !           248:            u_short fast_dest_dy;       /* destination y fast vector */
        !           249:            u_short slow_dest_dx;       /* destination x slow vector */
        !           250:            u_short slow_dest_dy;       /* destination y slow vector */
        !           251:            u_short fast_scale;         /* scale factor for fast vector */
        !           252:            u_short slow_scale;         /* scale factor for slow vector */
        !           253:            u_short source_2_x;         /* source #2 x origin */
        !           254:            u_short source_2_y;         /* source #2 y origin */
        !           255:            u_short source_2_size;      /* source #2 height & width */
        !           256:            u_short error_1;            /* error regs (?) */
        !           257:            u_short error_2;
        !           258: 
        !           259:            /* screen format control registers */
        !           260: 
        !           261:            u_short y_scan_count_0;     /* y scan counts for vert timing */
        !           262:            u_short y_scan_count_1;
        !           263:            u_short y_scan_count_2;
        !           264:            u_short y_scan_count_3;
        !           265:            u_short x_scan_conf;        /* x scan configuration */
        !           266:            u_short x_limit;
        !           267:            u_short y_limit;
        !           268:            u_short x_scan_count_0;     /* x scan count for horiz timing */
        !           269:            u_short x_scan_count_1;
        !           270:            u_short x_scan_count_2;
        !           271:            u_short x_scan_count_3;
        !           272:            u_short x_scan_count_4;
        !           273:            u_short x_scan_count_5;
        !           274:            u_short x_scan_count_6;
        !           275:            u_short sync_phase_adj;     /* sync phase (horiz sync count) */
        !           276:        };
        !           277: 
        !           278: /*---------------------
        !           279: * DUART definitions */
        !           280: 
        !           281:        /* command definitions */
        !           282: 
        !           283: #define EN_RCV         0x01
        !           284: #define DIS_RCV        0x02
        !           285: #define EN_XMT         0x04
        !           286: #define DIS_XMT        0x08
        !           287: #define RESET_M        0x10
        !           288: #define RESET_RCV      0x20
        !           289: #define RESET_XMT      0x30
        !           290: #define RESET_ERR      0x40
        !           291: #define RESET_BD       0x50
        !           292: #define START_BREAK    0x60
        !           293: #define STOP_BREAK     0x70
        !           294: 
        !           295:        /* interupt bit definitions */
        !           296: 
        !           297: #define EI_XMT_A       0x01
        !           298: #define EI_RCV_A       0x02
        !           299: #define EI_XMT_B       0x10
        !           300: #define EI_RCV_B       0x20
        !           301: 
        !           302: #define XMT_RDY_A      0x01
        !           303: #define RCV_RDY_A      0x02
        !           304: #define XMT_RDY_B      0x10
        !           305: #define RCV_RDY_B      0x20
        !           306: 
        !           307:        /* status register bit defintions */
        !           308: 
        !           309: #define RCV_RDY        0x01
        !           310: #define FIFO_FULL      0x02
        !           311: #define XMT_RDY        0x04
        !           312: #define XMT_EMT        0x08
        !           313: #define OVER_ERR       0x10
        !           314: #define ERR_PARITY     0x20
        !           315: #define FRAME_ERR      0x40
        !           316: #define RCVD_BREAK     0x80
        !           317: 
        !           318: 
        !           319:        struct duart {
        !           320: 
        !           321:            /* channel A - LK201 */
        !           322: 
        !           323:            short modeA;                /* ch.A mode reg (read/write) */
        !           324:            short statusA;              /* ch.A status reg (read) */
        !           325: #define clkselA statusA                /* ch.A clock slect reg (write) */
        !           326:            short cmdA;                 /* ch.A command reg (write) */
        !           327:            short dataA;                /* rcv/xmt data ch.A (read/write) */
        !           328:            short inchng;               /* input change state reg (read) */
        !           329: #define auxctl inchng                  /* auxiliary control reg (write) */
        !           330:            short istatus;              /* interrupt status reg (read) */
        !           331: #define imask istatus                  /* interrupt mask reg (write) */
        !           332:            short CThi;                 /* counter/timer hi byte (read) */
        !           333: #define CTRhi CThi                     /* counter/timer hi reg (write) */
        !           334:            short CTlo;                 /* counter/timer lo byte (read) */
        !           335: #define CTRlo CTlo                     /* counter/timer lo reg (write) */
        !           336: 
        !           337:            /* channel B - pointing device */
        !           338: 
        !           339:            short modeB;                /* ch.B mode reg (read/write) */
        !           340:            short statusB;              /* ch.B status reg (read) */
        !           341: #define clkselB statusB                /* ch.B clock select reg (write) */
        !           342:            short cmdB;                 /* ch.B command reg (write) */
        !           343:            short dataB;                /* ch.B rcv/xmt data (read/write) */
        !           344:            short rsrvd;
        !           345:            short inport;               /* input port (read) */
        !           346: #define outconf inport                 /* output port config reg (write) */
        !           347:            short strctr;               /* start counter command (read) */
        !           348: #define setbits setctr                 /* output bits set command (write) */
        !           349:            short stpctr;               /* stop counter command (read) */
        !           350: #define resetbits stpctr               /* output bits reset cmd (write) */
        !           351: 
        !           352: };

unix.superglobalmegacorp.com

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