| plan 9 kernel history: overview | file list | diff list |
1990/1231/ss/screen.c (diff list | history)
| 1990/1226/sys/src/9/ss/screen.c:20,30 – 1990/1231/sys/src/9/ss/screen.c:20,30 (short | long | prev | next) | ||
| 1990/1223 | int bwid; }out; | |
| 1990/1231 | void kbdstate(int); | |
| 1990/1223 | GBitmap gscreen = { | |
| 1990/1226/sys/src/9/ss/screen.c:39,45 – 1990/1231/sys/src/9/ss/screen.c:39,44 | ||
| 1990/1223 | void screeninit(void) { | |
| 1990/1226 |
| |
| 1990/1223 | gbitblt(&gscreen, Pt(0, 0), &gscreen, gscreen.r, 0); out.pos.x = MINX; | |
| 1990/1226/sys/src/9/ss/screen.c:80,402 – 1990/1231/sys/src/9/ss/screen.c:79,511 | ||
| 1990/1223 | } /* | |
| 1990/1231 | * Driver for the Z8530. | |
| 1990/1223 | */ | |
| 1990/1231 | enum { /* wr 0 */ ResExtPend= 2<<3, ResTxPend= 5<<3, ResErr= 6<<3, | |
| 1990/1223 |
| |
| 1990/1231 | /* wr 1 */ TxIntEna= 1<<1, RxIntDis= 0<<3, RxIntFirstEna= 1<<3, RxIntAllEna= 2<<3, | |
| 1990/1223 |
| |
| 1990/1231 | /* wr 3 */ RxEna= 1, Rx5bits= 0<<6, Rx7bits= 1<<6, Rx6bits= 2<<6, Rx8bits= 3<<6, | |
| 1990/1223 |
| |
| 1990/1231 | /* wr 4 */ SyncMode= 0<<2, Rx1stop= 1<<2, Rx1hstop= 2<<2, Rx2stop= 3<<2, X16= 1<<6, | |
| 1990/1223 |
| |
| 1990/1231 | /* wr 5 */ TxRTS= 1<<1, TxEna= 1<<3, TxBreak= 1<<4, TxDTR= 1<<7, Tx5bits= 0<<5, Tx7bits= 1<<5, Tx6bits= 2<<5, Tx8bits= 3<<5, | |
| 1990/1223 |
| |
| 1990/1231 | /* wr 9 */ IntEna= 1<<3, ResetB= 1<<6, ResetA= 2<<6, HardReset= 3<<6, | |
| 1990/1223 |
| |
| 1990/1231 | /* wr 11 */ TRxCOutBR= 2, TxClockBR= 2<<3, RxClockBR= 2<<5, TRxCOI= 1<<2, | |
| 1990/1223 |
| |
| 1990/1231 | /* wr 14 */ BREna= 1, BRSource= 2, | |
| 1990/1223 |
| |
| 1990/1231 | /* rr 0 */ RxReady= 1, TxReady= 1<<2, RxDCD= 1<<3, RxCTS= 1<<5, RxBreak= 1<<7, | |
| 1990/1223 |
| |
| 1990/1231 | /* rr 3 */ ExtPendB= 1, TxPendB= 1<<1, RxPendB= 1<<2, ExtPendA= 1<<3, TxPendA= 1<<4, RxPendA= 1<<5, }; typedef struct Z8530 Z8530; struct Z8530 | |
| 1990/1223 | { | |
| 1990/1231 | uchar ptrb; uchar dummy1; uchar datab; uchar dummy2; uchar ptra; uchar dummy3; uchar dataa; uchar dummy4; }; #define NDELIM 5 typedef struct Duart Duart; struct Duart | |
| 1990/1223 | { | |
| 1990/1231 | QLock; ushort sticky[16]; /* sticky write register values */ uchar *ptr; /* command/pointer register in Z8530 */ uchar *data; /* data register in Z8530 */ }; Duart duart[2]; | |
| 1990/1223 |
| |
| 1990/1231 | #define PRINTING 0x4 #define MASK 0x1 | |
| 1990/1223 | ||
| 1990/1231 | /* * Access registers using the pointer in register 0. */ | |
| 1990/1223 | void | |
| 1990/1231 | duartwrreg(Duart *dp, int addr, int value) | |
| 1990/1223 | { | |
| 1990/1231 | *dp->ptr = addr; *dp->ptr = dp->sticky[addr] | value; | |
| 1990/1223 | } | |
| 1990/1231 | ushort duartrdreg(Duart *dp, int addr) | |
| 1990/1223 | { | |
| 1990/1231 | *dp->ptr = addr; return *dp->ptr; | |
| 1990/1223 | } | |
| 1990/1231 | /* * set the baud rate by calculating and setting the baudrate * generator constant. This will work with fairly non-standard * baud rates. */ | |
| 1990/1223 | void | |
| 1990/1231 | duartsetbaud(Duart *dp, int rate) | |
| 1990/1223 | { | |
| 1990/1231 | int brconst; | |
| 1990/1223 |
| |
| 1990/1231 | brconst = 10000000/(16*2*rate) - 2; duartwrreg(dp, 12, brconst & 0xff); duartwrreg(dp, 13, (brconst>>8) & 0xff); | |
| 1990/1223 | } | |
| 1990/1231 | /* * Initialize just keyboard and mouse for now */ | |
| 1990/1223 | void | |
| 1990/1231 | duartinit(void) | |
| 1990/1223 | { | |
| 1990/1231 | Duart *dp; Z8530 *zp; KMap *k; | |
| 1990/1223 |
| |
| 1990/1231 | k = kmappa(KMDUART, PTEIO|PTENOCACHE); zp = (Z8530*)k->va; | |
| 1990/1223 |
| |
| 1990/1231 | /* * get port addresses */ duart[0].ptr = &zp->ptra; duart[0].data = &zp->dataa; duart[1].ptr = &zp->ptrb; duart[1].data = &zp->datab; | |
| 1990/1223 |
| |
| 1990/1231 | for(dp=duart; dp < &duart[2]; dp++){ memset(dp->sticky, 0, sizeof(dp->sticky)); | |
| 1990/1223 |
| |
| 1990/1231 | /* * enable I/O, 8 bits/character */ dp->sticky[3] = RxEna | Rx8bits; duartwrreg(dp, 3, 0); dp->sticky[5] = TxEna | Tx8bits; duartwrreg(dp, 5, 0); /* * turn on interrupts */ dp->sticky[1] |= TxIntEna | RxIntAllEna; duartwrreg(dp, 1, 0); dp->sticky[9] |= IntEna; duartwrreg(dp, 9, 0); } /* * turn on DTR and RTS */ dp = &duart[1]; dp->sticky[5] |= TxRTS | TxDTR; duartwrreg(dp, 5, 0); | |
| 1990/1223 | } void | |
| 1990/1231 | duartintr(void) | |
| 1990/1223 | { | |
| 1990/1231 | char ch; int cause; Duart *dp; | |
| 1990/1223 |
| |
| 1990/1231 | cause = duartrdreg(&duart[0], 3); | |
| 1990/1223 | /* | |
| 1990/1231 | * Keyboard | |
| 1990/1223 | */ | |
| 1990/1231 | dp = &duart[0]; if(cause & ExtPendA) duartwrreg(dp, 0, ResExtPend); if(cause & RxPendA){ ch = *dp->data; kbdstate(ch); } if(cause & TxPendA) duartwrreg(dp, 0, ResTxPend); | |
| 1990/1223 | /* | |
| 1990/1231 | * Mouse | |
| 1990/1223 | */ | |
| 1990/1231 | dp = &duart[1]; if(cause & ExtPendB) duartwrreg(dp, 0, ResExtPend); if(cause & RxPendB){ ch = *dp->data; mousechar(ch); } if(cause & TxPendB) duartwrreg(dp, 0, ResTxPend); } /* * Map is indexed by keyboard char, output is ASCII */ uchar keymap[128] = { /* 00 L1 02 L2 04 F1 F2 07 */ 0xFF, 0x80, 0xFF, 0x81, 0xFF, 0x82, 0x83, 0xFF, /* F3 09 F4 0b F5 0d F6 0f */ 0x84, 0xFF, 0x85, 0xFF, 0x86, 0xFF, 0x87, 0xFF, /* F7 F8 F9 Alt 14 R1 R2 R3 */ 0x88, 0x89, 0x8a, 0x8b, 0xFF, 0x8c, 0x8d, 0x8e, /* 18 L3 L4 1b 1c Esc 1 2 */ 0xFF, 0x8f, 0x90, 0xFF, 0xFF, 0x1b, '1', '2', /* 3 4 5 6 7 8 9 0 */ '3', '4', '5', '6', '7', '8', '9', '0', /* - = ` bs 2c R4 R5 R6 */ '-', '=', '`', '\b', 0xFF, 0x91, 0x92, 0x93, /* 30 L5 L6 33 34 tab q w */ 0xFF, 0x94, 0x95, 0xFF, 0xFF, '\t', 'q', 'w', /* e r t y u i o p */ 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', /* [ ] del 43 R7 R8 R9 47 */ '[', ']', 0x7F, 0xFF, 0x96, 0x97, 0x98, 0xFF, /* L7 L8 4a 4b ctrl a s d */ 0x99, 0x9a, 0xFF, 0xFF, 0xF0, 'a', 's', 'd', /* f g h j k l ; ' */ 'f', 'g', 'h', 'j', 'k', 'l', ';', '\'', /* \ ret 5a R10 R11 R12 5e L9 */ '\\', '\n', 0xFF, 0x9b, 0x9c, 0x9d, 0xFF, 0x9e, /* 60 L10 62 shift z x c v */ 0xFF, 0x9f, 0xFF, 0xF1, 'z', 'x', 'c', 'v', /* b n m , . / shift lf */ 'b', 'n', 'm', ',', '.', '/', 0xF1, '\r', /* R13 R14 R15 73 74 75 76 caps */ 0xA0, 0xA1, 0xA2, 0xFF, 0xFF, 0xFF, 0xFF, 0xF2, /* left 79 right 7b 7c 7d 7e 7f */ 0xA3, ' ', 0xA4, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, }; uchar keymapshift[128] = { /* 00 L1 02 L2 04 F1 F2 07 */ 0xFF, 0x80, 0xFF, 0x81, 0xFF, 0x82, 0x83, 0xFF, /* F3 09 F4 0b F5 0d F6 0f */ 0x84, 0xFF, 0x85, 0xFF, 0x86, 0xFF, 0x87, 0xFF, /* F7 F8 F9 Alt 14 R1 R2 R3 */ 0x88, 0x89, 0x8a, 0x8b, 0xFF, 0x8c, 0x8d, 0x8e, /* 18 L3 L4 1b 1c Esc 1 2 */ 0xFF, 0x8f, 0x90, 0xFF, 0xFF, 0x1b, '!', '@', /* 3 4 5 6 7 8 9 0 */ '#', '$', '%', '^', '&', '*', '(', ')', /* - = ` bs 2c R4 R5 R6 */ '_', '+', '~', '\b', 0xFF, 0x91, 0x92, 0x93, /* 30 L5 L6 33 34 tab q w */ 0xFF, 0x94, 0x95, 0xFF, 0xFF, '\t', 'Q', 'W', /* e r t y u i o p */ 'E', 'R', 'T', 'Y', 'U', 'I', 'O', 'P', /* [ ] del 43 R7 R8 R9 47 */ '{', '}', 0x7F, 0xFF, 0x96, 0x97, 0x98, 0xFF, /* L7 L8 4a 4b ctrl a s d */ 0x99, 0x9a, 0xFF, 0xFF, 0xF0, 'A', 'S', 'D', /* f g h j k l ; ' */ 'F', 'G', 'H', 'J', 'K', 'L', ':', '"', /* \ ret 5a R10 R11 R12 5e L9 */ '|', '\n', 0xFF, 0x9b, 0x9c, 0x9d, 0xFF, 0x9e, /* 60 L10 62 shift z x c v */ 0xFF, 0x9f, 0xFF, 0xF1, 'Z', 'X', 'C', 'V', /* b n m , . / shift lf */ 'B', 'N', 'M', '<', '>', '?', 0xF1, '\r', /* R13 R14 R15 73 74 75 76 caps */ 0xA0, 0xA1, 0xA2, 0xFF, 0xFF, 0xFF, 0xFF, 0xF2, /* left 79 right 7b 7c 7d 7e 7f */ 0xA3, ' ', 0xA4, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, }; uchar keymapctrl[128] = { /* 00 L1 02 L2 04 F1 F2 07 */ 0xFF, 0x80, 0xFF, 0x81, 0xFF, 0x82, 0x83, 0xFF, /* F3 09 F4 0b F5 0d F6 0f */ 0x84, 0xFF, 0x85, 0xFF, 0x86, 0xFF, 0x87, 0xFF, /* F7 F8 F9 Alt 14 R1 R2 R3 */ 0x88, 0x89, 0x8a, 0x8b, 0xFF, 0x8c, 0x8d, 0x8e, /* 18 L3 L4 1b 1c Esc 1 2 */ 0xFF, 0x8f, 0x90, 0xFF, 0xFF, 0x1b, '!', '@', /* 3 4 5 6 7 8 9 0 */ '#', '$', '%', '^', '&', '*', '(', ')', /* - = ` bs 2c R4 R5 R6 */ '_', '+', '~', '\b', 0xFF, 0x91, 0x92, 0x93, /* 30 L5 L6 33 34 tab q w */ 0xFF, 0x94, 0x95, 0xFF, 0xFF, '\t', 0x11, 0x17, /* e r t y u i o p */ 0x05, 0x12, 0x14, 0x19, 0x15, 0x09, 0x0F, 0x10, /* [ ] del 43 R7 R8 R9 47 */ 0x1B, 0x1D, 0x7F, 0xFF, 0x96, 0x97, 0x98, 0xFF, /* L7 L8 4a 4b ctrl a s d */ 0x99, 0x9a, 0xFF, 0xFF, 0xF0, 0x01, 0x13, 0x04, /* f g h j k l ; ' */ 0x06, 0x07, 0x08, 0x0A, 0x0B, 0x0C,':', '"', /* \ ret 5a R10 R11 R12 5e L9 */ 0x1C, '\n', 0xFF, 0x9b, 0x9c, 0x9d, 0xFF, 0x9e, /* 60 L10 62 shift z x c v */ 0xFF, 0x9f, 0xFF, 0xF1, 0x1A, 0x18, 0x03, 0x16, /* b n m , . / shift lf */ 0x02, 0x0E, 0x0D, '<', '>', '?', 0xF1, '\r', /* R13 R14 R15 73 74 75 76 caps */ 0xA0, 0xA1, 0xA2, 0xFF, 0xFF, 0xFF, 0xFF, 0xF2, /* left 79 right 7b 7c 7d 7e 7f */ 0xA3, ' ', 0xA4, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, }; uchar keymapshiftctrl[128] = { /* 00 L1 02 L2 04 F1 F2 07 */ 0xFF, 0x80, 0xFF, 0x81, 0xFF, 0x82, 0x83, 0xFF, /* F3 09 F4 0b F5 0d F6 0f */ 0x84, 0xFF, 0x85, 0xFF, 0x86, 0xFF, 0x87, 0xFF, /* F7 F8 F9 Alt 14 R1 R2 R3 */ 0x88, 0x89, 0x8a, 0x8b, 0xFF, 0x8c, 0x8d, 0x8e, /* 18 L3 L4 1b 1c Esc 1 2 */ 0xFF, 0x8f, 0x90, 0xFF, 0xFF, 0x1b, '!', 0x00, /* 3 4 5 6 7 8 9 0 */ '#', '$', '%', 0x1E, '&', '*', '(', ')', /* - = ` bs 2c R4 R5 R6 */ 0x1F, '+', '~', '\b', 0xFF, 0x91, 0x92, 0x93, /* 30 L5 L6 33 34 tab q w */ 0xFF, 0x94, 0x95, 0xFF, 0xFF, '\t', 0x11, 0x17, /* e r t y u i o p */ 0x05, 0x12, 0x14, 0x19, 0x15, 0x09, 0x0F, 0x10, /* [ ] del 43 R7 R8 R9 47 */ 0x1B, 0x1D, 0x7F, 0xFF, 0x96, 0x97, 0x98, 0xFF, /* L7 L8 4a 4b ctrl a s d */ 0x99, 0x9a, 0xFF, 0xFF, 0xF0, 0x01, 0x13, 0x04, /* f g h j k l ; ' */ 0x06, 0x07, 0x08, 0x0A, 0x0B, 0x0C,':', '"', /* \ ret 5a R10 R11 R12 5e L9 */ 0x1C, '\n', 0xFF, 0x9b, 0x9c, 0x9d, 0xFF, 0x9e, /* 60 L10 62 shift z x c v */ 0xFF, 0x9f, 0xFF, 0xF1, 0x1A, 0x18, 0x03, 0x16, /* b n m , . / shift lf */ 0x02, 0x0E, 0x0D, '<', '>', '?', 0xF1, '\r', /* R13 R14 R15 73 74 75 76 caps */ 0xA0, 0xA1, 0xA2, 0xFF, 0xFF, 0xFF, 0xFF, 0xF2, /* left 79 right 7b 7c 7d 7e 7f */ 0xA3, ' ', 0xA4, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, }; static uchar *kbdmap[4] = { keymap, keymapshift, keymapctrl, keymapshiftctrl }; void kbdstate(int c) { static shift = 0x00; static caps = 0; static repeatc = -1; static long startclick; int tc; tc = kbdmap[shift][c&0x7F]; /* if(c==0xFFFF && repeatc!=-1 && clicks>startclick+40 && (clicks-startclick)%3==0){ kbdc = repeatc; | |
| 1990/1223 | return; } | |
| 1990/1231 | */ if(c==0x7F){ /* all keys up */ repeatc = -1; return; } if(tc == 0xFF) /* shouldn't happen; ignore */ return; if(c & 0x80){ /* key went up */ if(tc == 0xF0){ /* control */ shift &= ~2; repeatc =- 1; return; | |
| 1990/1223 | } | |
| 1990/1231 | if(tc == 0xF1){ /* shift */ shift &= ~1; repeatc = -1; return; } if(tc == 0xF2){ /* caps */ repeatc = -1; return; } if(tc == repeatc) repeatc = -1; return; | |
| 1990/1223 | } | |
| 1990/1231 | if(tc == 0xF0){ /* control */ shift |= 2; repeatc = -1; return; | |
| 1990/1223 | } | |
| 1990/1231 | if(tc==0xF1){ /* shift */ shift |= 1; repeatc = -1; return; } if(tc==0xF2){ /* caps */ caps ^= 1; repeatc =- 1; return; } if(caps && 'a'<=tc && tc<='z') tc |= ' '; repeatc = tc; /* startclick = clicks; */ if(tc == 0x10) /* ctrl-p */ reset(); kbdchar(tc); | |
| 1990/1223 | } | |