Annotation of coherent/d/PS2_KERNEL/io.386/vtmmas.s, revision 1.1.1.1

1.1       root        1: ////////
                      2: /
                      3: /      Memory mapped video driver assembler assist.
                      4: /
                      5: ////////
                      6: /
                      7: / State driven code
                      8: /
                      9: /      Input:  DS:SI - input string
                     10: /              ES:DI - current screen location
                     11: /              SS:BP - terminal information
                     12: /              CX    - input count
                     13: /              BP    - references terminal information
                     14: /              AH    - character attributes
                     15: /              AL    - character
                     16: /              BH    - (usually) kept zeroed for efficiency
                     17: /              DH    - current row
                     18: /              DL    - current column
                     19: /
                     20: ////////
                     21: 
                     22:        .set    NCOL, 80        / number of columns
                     23:        .set    NCB, 2          / number of horizontal bytes per char
                     24:        .set    SCB, 1          / log2(NCB)
                     25:        .set    NCR, 1          / number of horizontal lines per char
                     26:        .set    NHB, 160        / number of horizontal bytes per line
                     27:        .set    NRB, 160        / number of bytes per character row(NCR*NHB)
                     28: 
                     29: ATTR   .define %ah     /* attribute byte */
                     30: ZERO   .define %bh     /* (almost) always zero */
                     31: ROW    .define %dh     /* currently active vertical position */
                     32: COL    .define %dl     /* currently active horizontal position */
                     33: POS    .define %edi    /* currently active display address */
                     34: 
                     35:        .set    INTENSE,        0x08    / high intensity attribute bit
                     36:        .set    BLINK,          0x80    / blinking attribute bit
                     37:        .set    REVERSE,        0x70    / reverse video
                     38: 
                     39:        .set    SEG_386_UD,     0x10    / 32 bit user data segment descriptor
                     40:        .set    SEG_ROM,        0x40    / ROM descriptor         @ F0000
                     41:        .set    SEG_VIDEOa,     0x48    / 0x48: video descriptor @ B0000
                     42:        .set    SEG_VIDEOb,     0x50    / 0x50: video descriptor @ B8000
                     43: 
                     44: ////////
                     45: /
                     46: / Magic constants from <sys/io.h>
                     47: /
                     48: ////////
                     49: 
                     50:        .set    IO_SEG, 0
                     51:        .set    IO_IOC, 4
                     52:        .set    IO_BASE, 12
                     53: 
                     54:        .set    IOSYS, 0
                     55:        .set    IOUSR, 1
                     56: 
                     57: ////////
                     58: /
                     59: / Data
                     60: /
                     61: ////////
                     62: 
                     63:        .set    MM_FUNC,        0       / current state
                     64:        .set    MM_PORT,        4       / adapter base i/o port
                     65:        .set    MM_BASE,        8       / adapter base memory address
                     66:        .set    MM_OFFSET,      12      / offset within segment
                     67:        .set    MM_ROW,         16      / screen row
                     68:        .set    MM_COL,         20      / screen column
                     69:        .set    MM_POS,         24      / screen position
                     70:        .set    MM_ATTR,        28      / attributes
                     71:        .set    MM_N1,          32      / numeric argument 1
                     72:        .set    MM_N2,          36      / numeric argument 2
                     73:        .set    MM_BROW,        40      / base row
                     74:        .set    MM_EROW,        44      / end row
                     75:        .set    MM_LROW,        48      / legal row limit
                     76:        .set    MM_SROW,        52      / saved cursor row
                     77:        .set    MM_SCOL,        56      / saved cursor column
                     78:        .set    MM_IBROW,       60      / initial base row
                     79:        .set    MM_IEROW,       64      / initial end row
                     80:        .set    MM_INVIS,       68      / cursor invisible mask
                     81:        .set    MM_SLOW,        72      / slow [no flicker] video update
                     82:        .set    MM_WRAP,        76      / wrap to start of next line
                     83: 
                     84:        .set    MM_VISIBLE,     80      // set if screen is being displayed
                     85:        .set    MM_ESC,         84      // escape char. state
                     86: 
                     87:        .set    MM_MSEG,        88      // heap space copy
                     88:        .set    MM_MOFF,        92      //
                     89:        .set    MM_VSEG,        96      // video memory
                     90:        .set    MM_VOFF,        100
                     91:        .set    MM_LOCKED,      104     // keyboard locked state
                     92:        .set    MM_SIZE,        108     //
                     93: 
                     94:        .globl  VIDSLOW         / Patchable kernel variable.
                     95:        .globl  mminit
                     96: 
                     97:        .data
                     98: VIDSLOW:.long  0
                     99: 
                    100: LXXX:  .long   10              / constant (imull)
                    101: 
                    102:        .text
                    103: 
                    104: ////////
                    105: /
                    106: / mmgo( iop, vp, index )
                    107: / IO *iop;
                    108: / VTDATA *vp;
                    109: / int index;
                    110: /
                    111: ////////
                    112: 
                    113:        .set    FRAME,28                / ra, bx, si, di, ds, es, bp
                    114: 
                    115:        .globl  mmgo
                    116: mmgo:
                    117:        push    %ebx
                    118:        push    %esi
                    119:        push    %edi
                    120:        push    %ds
                    121:        push    %es
                    122:        push    %ebp
                    123:        movl    %esp,%ebp
                    124:        cld
                    125:        mov     FRAME+0(%ebp),%ebx              / iop
                    126:        mov     IO_BASE(%ebx),%esi              / iop->io_base
                    127:        mov     IO_IOC(%ebx),%ecx               / iop->io_ioc
                    128: 
                    129:        cmpl    $IOSYS,IO_SEG(%ebx)     / user address space
                    130:        je      loc1
                    131:        mov     $SEG_386_UD,%eax
                    132:        movw    %ax,%ds
                    133: loc1:
                    134:        mov     FRAME+4(%ebp),%ebp              / vtp
                    135:        mov     $0, %edx                / assume not visible
                    136:        cmpb    $0, MM_VISIBLE(%ebp)    / if this is the case, then
                    137:        je      loc2                    / don't mess with the video hw
                    138: 
                    139:        mov     MM_PORT(%ebp),%edx      / turn video off if color board
                    140:        cmp     $0x3B4,%edx
                    141:        je      loc2
                    142:        cmpb    $0,MM_SLOW(%ebp)        / check for slow [flicker-free]
                    143:        je      loc3
                    144: 
                    145:        mov     $0x3DA,%edx
                    146: loc4:  inb     (%dx)                   / wait for vertical retrace
                    147:        testb   $8,%al
                    148:        je      loc4
                    149: loc3:
                    150:        mov     $0x3D8,%edx             / disable video
                    151:        movb    $0x25,%al
                    152:        outb    (%dx)
                    153: loc2:
                    154:        movb    MM_ROW(%ebp),ROW
                    155:        movb    MM_COL(%ebp),COL
                    156:        movw    MM_BASE(%ebp),%es
                    157:        mov     MM_POS(%ebp),POS
                    158:        sub     %ebx,%ebx
                    159:        movb    MM_ATTR(%ebp),ATTR
                    160: 
                    161:        ijmp    MM_FUNC(%ebp)
                    162: 
                    163: exit:  pop     %ebx
                    164:        mov     %ebx,MM_FUNC(%ebp)
                    165:        movb    ATTR,MM_ATTR(%ebp)
                    166:        movb    ROW,MM_ROW(%ebp)                / save row,column
                    167:        movb    COL,MM_COL(%ebp)
                    168:        mov     POS,MM_POS(%ebp)                / save position
                    169: 
                    170: / ensure that only the screen associtated with the keyboard
                    171: / will actually get the cursor updated.
                    172:                                / physical index of screen to which the
                    173:        .globl  vtactive        / keyboard is currently attached
                    174:        mov     %esp, %ebx
                    175:        mov     vtactive, %edx
                    176:        cmp     FRAME+8(%ebx), %edx
                    177:        jne     exit0
                    178: 
                    179:        mov     MM_PORT(%ebp),%edx      / update cursor location
                    180:        mov     POS,%ebx
                    181:        add     MM_OFFSET(%ebp),%ebx    / adjust to screen
                    182:        or      MM_INVIS(%ebp),%ebx
                    183:        shr     $1,%ebx
                    184: 
                    185:        movb    $14,%al
                    186:        outb    (%dx)
                    187:        inc     %edx
                    188:        movb    %bh,%al
                    189:        outb    (%dx)
                    190:        dec     %edx
                    191:        movb    $15,%al
                    192:        outb    (%dx)
                    193:        inc     %edx
                    194:        movb    %bl,%al
                    195:        outb    (%dx)
                    196: exit0:
                    197:        mov     MM_PORT(%ebp),%edx              / turn video on
                    198:        cmp     $0, MM_VISIBLE(%ebp)            / iff screen is visible
                    199:        je      exit1
                    200: 
                    201:        add     $4,%edx
                    202:        movb    $0x29,%al
                    203:        outb    (%dx)
                    204:        mov     $600,%ss:mmvcnt         / 600 seconds before video disabled
                    205: exit1:
                    206:        mov     FRAME(%esp),%ebx
                    207:        mov     %ecx,%eax
                    208:        xchg    %ecx, %ss:IO_IOC(%ebx)
                    209:        sub     %ss:IO_IOC(%ebx),%ecx
                    210:        add     %ecx,%ss:IO_BASE(%ebx)
                    211:        pop     %ebp
                    212:        pop     %es
                    213:        pop     %ds
                    214:        pop     %edi
                    215:        pop     %esi
                    216:        pop     %ebx
                    217:        ret
                    218: 
                    219: 
                    220: ////////
                    221: /
                    222: / mminit - initialize screen
                    223: /
                    224: ////////
                    225: mminit:
                    226:        movw    MM_BASE(%ebp), %es
                    227:        movb    $0x63,MM_ESC(%ebp)              / schedule keyboard initialization
                    228: 
                    229:        mov     MM_BASE(%ebp), %edx
                    230:        mov     %dx, %es
                    231:        movw    MM_BASE(%ebp), %dx
                    232: 
                    233:        cmp     $0, MM_VISIBLE(%ebp)
                    234:        jne     mminit0
                    235: 
                    236: / DEBUG
                    237: /      mov     MM_PORT(%ebp),%edx              / turn video off
                    238: /      add     $4,%edx
                    239: /      movb    $0x21,%al
                    240: /      outb    (%dx)
                    241: / DEBUG
                    242: 
                    243:        mov     MM_PORT(%ebp),%edx              / zero display offset
                    244:        movb    $12,%al
                    245:        outb    (%dx)
                    246:        inc     %edx
                    247:        subb    %al,%al
                    248:        outb    (%dx)
                    249:        dec     %edx
                    250:        movb    $13,%al
                    251:        outb    (%dx)
                    252:        inc     %edx
                    253:        subb    %al,%al
                    254:        outb    (%dx)
                    255: 
                    256:        mov     MM_PORT(%ebp),%edx      / reset border to black
                    257:        add     $5,%edx
                    258:        subb    %al,%al
                    259:        outb    (%dx)
                    260: 
                    261:        inc     %edx                    / reset TECMAR XMSR register
                    262:        outb    (%dx)
                    263: mminit0:
                    264:        movl    $0,MM_INVIS(%ebp)
                    265:        movb    $0x07,ATTR
                    266:        movb    ATTR,MM_ATTR(%ebp)
                    267:        movb    $1,MM_WRAP(%ebp)
                    268:        movb    MM_IBROW(%ebp),ROW
                    269:        movb    ROW,MM_BROW(%ebp)
                    270:        movb    MM_IEROW(%ebp),%bl
                    271:        movb    %bl,MM_EROW(%ebp)
                    272:        sub     %ebx,%ebx
                    273:        movb    $2,MM_N1(%ebp)
                    274:        jmp     mm_ed
                    275: 
                    276: ////////
                    277: /
                    278: / mmspec - schedule special keyboard function
                    279: /
                    280: ////////
                    281: 
                    282: mmspec:        movb    %al,MM_ESC(%ebp)
                    283:        jmp     eval
                    284: 
                    285: ////////
                    286: /
                    287: / mmbell - schedule beep
                    288: /
                    289: ////////
                    290: 
                    291: mmbell:        movb    $-1,%ss:mmbeeps
                    292:        jmp     eval
                    293: 
                    294: ////////
                    295: /
                    296: / mm_cnl - cursor next line
                    297: /
                    298: /      Moves the active position to the next display line.
                    299: /      Scrolls the active display if necessary.
                    300: /
                    301: ////////
                    302: 
                    303: mm_cnl:
                    304:        incb    ROW
                    305:        cmpb    MM_EROW(%ebp),ROW
                    306:        jna     repos
                    307:        movb    MM_EROW(%ebp),ROW
                    308: 
                    309: /      jmp     scrollup
                    310: 
                    311: ////////
                    312: /
                    313: / scrollup - scroll display upwards
                    314: /
                    315: ////////
                    316: 
                    317: scrollup:
                    318:        push    %ds
                    319:        push    %esi
                    320:        push    %ecx
                    321: 
                    322:        movw    MM_BASE(%ebp),%ds
                    323:        movb    MM_BROW(%ebp),%bl
                    324:        mov     %cs:rowtab(,%ebx,4),%edi
                    325:        mov     %cs:rowtab+4(,%ebx,4),%esi
                    326: 
                    327:        movb    ROW,%bl
                    328:        mov     %cs:rowtab(,%ebx,4),%ecx
                    329: 
                    330:        push    %ecx
                    331:        sub     %edi,%ecx
                    332:        shr     $1,%ecx
                    333:        cld
                    334: 
                    335:        add     MM_OFFSET(%ebp), %esi   / adjust for screen
                    336:        add     MM_OFFSET(%ebp), %edi
                    337: 
                    338:        rep
                    339:        movsw
                    340:        movb    $0x20,%al
                    341:        mov     $NCOL,%ecx
                    342: 
                    343:        pop     %edi
                    344:        add     MM_OFFSET(%ebp), %edi
                    345:        rep
                    346:        stosw
                    347: 
                    348:        sub     MM_OFFSET(%ebp), %edi
                    349:        pop     %ecx
                    350:        pop     %esi
                    351:        pop     %ds
                    352:        movb    COL,%bl                 / reposition to ROW and COL
                    353:        mov     %cs:coltab(,%ebx,4),POS
                    354:        movb    ROW,%bl
                    355:        add     %cs:rowtab(,%ebx,4),POS
                    356:        call    exit
                    357: 
                    358:        jmp     eval
                    359: 
                    360: ////////
                    361: /
                    362: / repos - reposition cursor
                    363: /
                    364: ////////
                    365: 
                    366: repos: movb    COL,%bl                 / reposition to ROW and COL
                    367:        mov     %cs:coltab(,%ebx,4),POS
                    368:        movb    ROW,%bl
                    369:        add     %cs:rowtab(,%ebx,4),POS
                    370:        jmp     eval
                    371: 
                    372: ////////
                    373: /
                    374: / Ewait - wait for next input char to evaluate
                    375: /
                    376: / eval - evaluate input character
                    377: /
                    378: ////////
                    379: 
                    380: ewait:
                    381:        call    exit
                    382: eval:
                    383:        jcxz    ewait
                    384: 
                    385:        dec     %ecx                            / evaluate next char
                    386:        lodsb
                    387:        movb    %al,%bl
                    388:        shlb    $1,%bl
                    389:        jc      mmputc
                    390:        ijmp    %cs:asctab(,%ebx,2)
                    391: 
                    392: ////////
                    393: /
                    394: / mmputc - put character in al on screen
                    395: /
                    396: ////////
                    397: 
                    398: mmputc:
                    399:        add     MM_OFFSET(%ebp), POS    / adjust for screen
                    400:        stosw                           / Update display memory.
                    401:        sub     MM_OFFSET(%ebp), POS    / adjust for screen
                    402: 
                    403:        incb    COL
                    404:        cmpb    $NCOL,COL               / Past end of line?
                    405:        jge     loc6
                    406:        jcxz    ewait                   / Not past, evaluate next character.
                    407:        dec     %ecx
                    408:        lodsb
                    409:        movb    %al,%bl
                    410:        shlb    $1,%bl
                    411:        jc      mmputc
                    412:        ijmp    %cs:asctab(,%ebx,2)
                    413: 
                    414: loc6:  cmpb    $0,MM_WRAP(%ebp)        / Yes past, Wrap around?
                    415:        jne     loc7
                    416:        sub     $2,%edi                 / No wrap, adjust back to end of line.
                    417:        decb    COL
                    418:        jcxz    ewait                   / Not past, evaluate next character.
                    419:        dec     %ecx
                    420:        lodsb
                    421:        movb    %al,%bl
                    422:        shlb    $1,%bl
                    423:        jc      mmputc
                    424:        ijmp    %cs:asctab(,%ebx,2)
                    425: 
                    426: loc7:  subb    COL,COL         / Wrap to next line.
                    427:        incb    ROW
                    428:        cmpb    MM_EROW(%ebp),ROW       / Past scrolling region?
                    429:        jg      loc8
                    430:        jcxz    ewait                   / Not past, evaluate next character.
                    431:        dec     %ecx
                    432:        lodsb
                    433:        movb    %al,%bl
                    434:        shlb    $1,%bl
                    435:        jc      mmputc
                    436:        ijmp    %cs:asctab(,%ebx,2)
                    437: 
                    438: loc8:  movb    MM_EROW(%ebp),ROW       / Yes past, scroll up 1 line.
                    439:        jmp     scrollup
                    440: 
                    441: 
                    442: ////////
                    443: /
                    444: / mm_cr - carriage return
                    445: /
                    446: /      Moves the active position to first position of current display line.
                    447: /
                    448: ////////
                    449: 
                    450: mm_cr: subb    COL,COL
                    451:        movb    ROW,%bl
                    452:        mov     %cs:rowtab(,%ebx,4),POS
                    453:        jcxz    ewait
                    454:        dec     %ecx
                    455:        lodsb
                    456:        movb    %al,%bl
                    457:        shlb    $1,%bl
                    458:        jc      mmputc
                    459:        ijmp    %cs:asctab(,%ebx,2)
                    460: 
                    461: ////////
                    462: /
                    463: / mm_cub - cursor backwards
                    464: /
                    465: ////////
                    466: 
                    467: mm_cub:        sub     $2,POS
                    468:        decb    COL
                    469:        jge     loc9
                    470:        movb    $NCOL-1,COL
                    471:        decb    ROW
                    472:        cmpb    MM_BROW(%ebp),ROW
                    473:        jge     loc9
                    474:        subb    COL,COL
                    475:        movb    MM_BROW(%ebp),ROW
                    476:        movb    ROW,%bl
                    477:        mov     %cs:rowtab(,%ebx,4),POS
                    478: loc9:  jcxz    loc9a
                    479:        jmp     loc9b
                    480: loc9a: jmp     ewait
                    481: loc9b: dec     %ecx
                    482:        lodsb
                    483:        movb    %al,%bl
                    484:        shlb    $1,%bl
                    485:        jc      mmputc
                    486:        ijmp    %cs:asctab(,%ebx,2)
                    487: 
                    488: ////////
                    489: /
                    490: / Esc state - entered when last char was ESC - transient state.
                    491: /
                    492: ////////
                    493: 
                    494: loc10: call    exit
                    495: mm_esc:        jcxz    loc10
                    496:        dec     %ecx
                    497:        lodsb
                    498: /      movb    ZERO,MM_N1(%ebp)
                    499: /      movb    ZERO,MM_N2(%ebp)
                    500:        movb    $0, MM_N1(%ebp)
                    501:        movb    $0, MM_N2(%ebp)
                    502:        movb    %al,%bl
                    503:        shlb    $1,%bl
                    504:        jc      mmputc
                    505:        ijmp    %cs:esctab(,%ebx,2)
                    506: 
                    507: ////////
                    508: /
                    509: / Csi_n1 state - entered when last two chars were ESC [
                    510: /
                    511: /      Action: Evaluates numeric chars as numeric parameter 1.
                    512: /
                    513: ////////
                    514: 
                    515: loc11: call    exit
                    516: csi_n1:        jcxz    loc11
                    517:        dec     %ecx
                    518:        lodsb
                    519:        cmpb    $0x3b,%al
                    520:        je      csi_n2
                    521:        movb    %al,%bl
                    522:        subb    $0x30,%bl
                    523:        cmpb    $9,%bl
                    524:        ja      csival
                    525: 
                    526:        movb    MM_N1(%ebp),%al
                    527:        shlb    $2,%al
                    528:        addb    MM_N1(%ebp),%al
                    529:        shlb    $1,%al  
                    530:                                / n1 * 10
                    531: 
                    532:        addb    %bl,%al         / n1 * 10 + digit
                    533:        movb    %al,MM_N1(%ebp) / n1 = (n1 * 10) + digit
                    534:        jmp     csi_n1
                    535: 
                    536: ////////
                    537: /
                    538: / Csi_n2 state - entered after input sequence ESC [ n ;
                    539: /
                    540: ////////
                    541: 
                    542: loc12: call    exit
                    543: csi_n2:        jcxz    loc12
                    544:        dec     %ecx
                    545:        lodsb
                    546:        movb    %al,%bl
                    547:        subb    $0x30,%bl
                    548:        cmpb    $9,%bl
                    549:        ja      csival
                    550: 
                    551:        movb    MM_N2(%ebp),%al
                    552:        shlb    $2,%al
                    553:        addb    MM_N2(%ebp),%al
                    554:        shlb    $1,%al  
                    555:                                / n1 * 10
                    556: 
                    557:        addb    %bl,%al         / n2 * 10 + digit
                    558:        movb    %al,MM_N2(%ebp) / n2 = (n2 * 10) + digit
                    559:        jmp     csi_n2
                    560: 
                    561: csival:        movb    %al,%bl
                    562:        shlb    $1,%bl
                    563:        jc      mmputc
                    564:        ijmp    %cs:csitab(,%ebx,2)
                    565: 
                    566: ////////
                    567: /
                    568: / Csi_gt state - entered after input sequence ESC [ >
                    569: /      
                    570: ////////
                    571: 
                    572: loc13: call    exit
                    573: csi_gt:        jcxz    loc13
                    574:        dec     %ecx
                    575:        lodsb
                    576:        movb    %al,%bl
                    577:        subb    $0x30,%bl
                    578:        cmpb    $9,%bl
                    579:        ja      loc14
                    580:        mov     MM_N1(%ebp),%eax        / n1 * 2
                    581:        imull   %cs:LXXX,%eax   / n1 * 10
                    582:        add     %ebx,%eax       / n1 * 10 + digit
                    583:        movb    %al,MM_N1(%ebp) / n1 = (n1 * 10) + digit
                    584:        jmp     csi_gt
                    585: 
                    586: loc14: cmpb    $0x68,%al
                    587:        je      mm_cgh
                    588:        cmpb    $0x6c,%al
                    589:        je      mm_cgl
                    590:        jmp     eval
                    591: 
                    592: ////////
                    593: /
                    594: / Csi_q state - entered after input sequence ESC [ ?
                    595: /      
                    596: ////////
                    597: 
                    598: loc15: call    exit
                    599: csi_q: jcxz    loc15
                    600:        dec     %ecx
                    601:        lodsb
                    602:        movb    %al,%bl
                    603:        subb    $0x30,%bl
                    604:        cmpb    $9,%bl
                    605:        ja      loc16
                    606:        mov     MM_N1(%ebp),%eax
                    607:        imull   %cs:LXXX,%eax
                    608:        add     %ebx,%eax       / n1 * 10 + digit
                    609:        movb    %al,MM_N1(%ebp) / n1 = (n1 * 10) + digit
                    610:        jmp     csi_q
                    611: 
                    612: loc16: cmpb    $0x68,%al
                    613:        je      mm_cqh
                    614:        cmpb    $0x6c,%al
                    615:        je      mm_cql
                    616:        jmp     eval
                    617: 
                    618: ////////
                    619: /
                    620: / mm_cbt - cursor backward tabulation
                    621: /
                    622: /      Moves the active position horizontally in the backward direction
                    623: /      to the preceding in a series of predetermined positions.
                    624: /
                    625: ////////
                    626: 
                    627: mm_cbt:        orb     $7,COL                  / calculate next tab stop
                    628:        incb    COL
                    629:        subb    $16,COL         / step back two tab positions
                    630:        jg      loc17
                    631:        subb    COL,COL         / can't step past column 0
                    632: loc17: jmp     repos                   / reposition cursor
                    633: 
                    634: ////////
                    635: /
                    636: / mm_cgh - process 'ESC [ > N1 h' escape sequence
                    637: /
                    638: /      Recognized sequences:   ESC [ > 13 h    -- Set CRT saver enabled.
                    639: /
                    640: ////////
                    641: 
                    642: mm_cgh:        cmpb    $13,MM_N1(%ebp)
                    643:        jne     loc18
                    644:        movl    $1,%ss:mmcrtsav
                    645: loc18: jmp     eval
                    646: 
                    647: ////////
                    648: /
                    649: / mm_cgl - process 'ESC [ > N1 l' escape sequence
                    650: /
                    651: /      Recognized sequences:   ESC [ > 13 l    -- Reset CRT saver.
                    652: /
                    653: ////////
                    654: 
                    655: mm_cgl:        cmpb    $13,MM_N1(%ebp)
                    656:        jne     loc19
                    657:        movl    $0,%ss:mmcrtsav
                    658: loc19: jmp     eval
                    659: 
                    660: ////////
                    661: /
                    662: / mm_cha - cursor horizontal absolute
                    663: /
                    664: /      Advances the active position forward or backward along the active line
                    665: /      to the character position specified by the parameter.
                    666: /      A parameter value of zero or one moves the active position to the
                    667: /      first character position of the active line.
                    668: /      A parameter value of N moves the active position to character position
                    669: /      N of the active line.
                    670: /
                    671: ////////
                    672: 
                    673: mm_cha:        movb    MM_N1(%ebp),COL
                    674:        decb    COL
                    675:        jge     loc20
                    676:        subb    COL,COL
                    677: loc20: cmpb    $NCOL,COL
                    678:        jb      loc21
                    679:        movb    $NCOL-1,COL
                    680: loc21: jmp     repos                   / reposition cursor
                    681: 
                    682: 
                    683: ////////
                    684: /
                    685: / mm_cht - cursor horizontal tabulation
                    686: /
                    687: /      Advances the active position horizontally to the next or following
                    688: /      in a series of predetermined positions.
                    689: /
                    690: ////////
                    691: 
                    692: mm_cht:        push    %ecx
                    693:        sub     %ecx,%ecx
                    694:        movb    COL,%cl
                    695:        orb     $7,%cl
                    696:        incb    %cl
                    697:        subb    COL,%cl
                    698:        addb    %cl,COL
                    699:        movb    $0x20,%al
                    700: 
                    701:        add     MM_OFFSET(%ebp), POS    / adjust for screen
                    702:        rep
                    703:        stosw
                    704:        sub     MM_OFFSET(%ebp), POS            / adjust for screen
                    705: 
                    706:        pop     %ecx
                    707:        cmpb    $NCOL,COL
                    708:        jb      loc22
                    709:        subb    $NCOL,COL
                    710:        incb    ROW
                    711:        cmpb    MM_EROW(%ebp),ROW
                    712:        jna     loc22
                    713:        movb    MM_EROW(%ebp),ROW
                    714:        jmp     scrollup
                    715: loc22: jmp     eval
                    716: 
                    717: ////////
                    718: /
                    719: / mm_cpl - cursor preceding line
                    720: /
                    721: /      Moves the active position to the first position of the preceding
                    722: /      display line.
                    723: /
                    724: ////////
                    725: 
                    726: mm_cpl:        subb    COL,COL
                    727:        decb    ROW
                    728:        cmpb    MM_BROW(%ebp),ROW
                    729:        jnb     loc23
                    730:        movb    MM_BROW(%ebp),ROW
                    731:        jmp     scrolldown
                    732: loc23: jmp     repos                   / reposition cursor
                    733: 
                    734: ////////
                    735: /
                    736: / mm_cqh - process 'ESC [ ? N1 h' escape sequence
                    737: /
                    738: /      Recognized sequences:   ESC [ ? 4 h     -- Set smooth scroll.
                    739: /                              ESC [ ? 7 h     -- Set wraparound.
                    740: /
                    741: ////////
                    742: 
                    743: mm_cqh:        cmpb    $4,MM_N1(%ebp)          / Smooth scroll.
                    744:        jne     loc24
                    745:        movb    $1,MM_SLOW(%ebp)
                    746: loc24: cmpb    $7,MM_N1(%ebp)          / Wraparound.
                    747:        jne     loc25
                    748:        movb    $1,MM_WRAP(%ebp)
                    749: loc25: jmp     eval
                    750: 
                    751: ////////
                    752: /
                    753: / mm_cql - process 'ESC [ ? N1 l' escape sequence
                    754: /
                    755: /      Recognized sequences:   ESC [ ? 4 l     -- Set jump scroll.
                    756: /                              ESC [ ? 7 l     -- Reset wraparound.
                    757: /
                    758: ////////
                    759: 
                    760: mm_cql:        cmpb    $4,MM_N1(%ebp)          / Jump scroll.
                    761:        jne     loc26
                    762:        movb    $0,MM_SLOW(%ebp)
                    763: loc26: cmpb    $7,MM_N1(%ebp)          / No wraparound.
                    764:        jne     loc27
                    765:        movb    $0,MM_WRAP(%ebp)
                    766: loc27: jmp     eval
                    767: 
                    768: ////////
                    769: /
                    770: / mm_cud - cursor down
                    771: /
                    772: /      Moves the active position downward without altering the
                    773: /      horizontal position.
                    774: /
                    775: ////////
                    776: 
                    777: mm_cud:        incb    ROW
                    778:        cmpb    MM_EROW(%ebp),ROW
                    779:        jna     loc28
                    780:        movb    MM_EROW(%ebp),ROW
                    781: loc28: jmp     repos                   / reposition cursor
                    782: 
                    783: ////////
                    784: /
                    785: / mm_cuf - cursor forward
                    786: /
                    787: /      Moves the active position in the forward direction.
                    788: /
                    789: ////////
                    790: 
                    791: mm_cuf:        incb    COL
                    792:        cmpb    $NCOL,COL
                    793:        jb      loc29
                    794:        subb    $NCOL,COL
                    795:        incb    ROW
                    796:        cmpb    MM_EROW(%ebp),ROW
                    797:        jna     loc29
                    798:        movb    MM_EROW(%ebp),ROW
                    799:        movb    $NCOL-1,COL
                    800: loc29: jmp     repos
                    801: 
                    802: ////////
                    803: /
                    804: / mm_cup - cursor position
                    805: /
                    806: /      Moves the active position to the position specified by two parameters.
                    807: /      The first parameter (mm_n1) specifies the vertical position (MM_ROW(%ebp)).
                    808: /      The second parameter (mm_n2) specifies the horizontal position (MM_COL(%ebp)).
                    809: /      A parameter value of 0 or 1 for the first or second parameter
                    810: /      moves the active position to the first line or column in the
                    811: /      display respectively.
                    812: /
                    813: ////////
                    814: 
                    815: mm_cup:        movb    MM_N1(%ebp),ROW
                    816:        decb    ROW
                    817:        jg      loc30
                    818:        subb    ROW,ROW
                    819: loc30: addb    MM_BROW(%ebp),ROW
                    820:        cmpb    MM_EROW(%ebp),ROW
                    821:        jb      loc31
                    822:        movb    MM_EROW(%ebp),ROW
                    823: loc31: movb    MM_N2(%ebp),COL
                    824:        decb    COL
                    825:        jg      loc32
                    826:        subb    COL,COL
                    827: loc32: cmpb    $NCOL,COL
                    828:        jb      loc33
                    829:        movb    $NCOL-1,COL
                    830: loc33: jmp     repos                   / reposition cursor
                    831: 
                    832: ////////
                    833: /
                    834: / mm_cuu - cursor up
                    835: /
                    836: /      Moves the active position upward without altering the horizontal
                    837: /      position.
                    838: /
                    839: ////////
                    840: 
                    841: mm_cuu:        decb    ROW
                    842:        cmpb    MM_BROW(%ebp),ROW
                    843:        jge     loc34
                    844:        movb    MM_BROW(%ebp),ROW
                    845: loc34: jmp     repos                   / reposition cursor
                    846: 
                    847: ////////
                    848: /
                    849: / mm_dl - delete line
                    850: /
                    851: /      Removes the contents of the active line.
                    852: /      The contents of all following lines are shifted in a block
                    853: /      toward the active line.
                    854: /
                    855: ////////
                    856: 
                    857: mm_dl: push    %ds
                    858:        push    %esi
                    859:        push    %ecx
                    860:        movw    MM_BASE(%ebp),%ds
                    861:        movb    ROW,%bl
                    862:        mov     %cs:rowtab(,%ebx,4),%edi
                    863:        mov     %cs:rowtab+4(,%ebx,4),%esi
                    864:        movb    MM_EROW(%ebp),%bl
                    865:        mov     %cs:rowtab(,%ebx,4),%ecx
                    866:        sub     %edi,%ecx
                    867:        jle     loc35
                    868:        shr     $1,%ecx
                    869: 
                    870:        add     MM_OFFSET(%ebp), %esi   / adjust for screen
                    871:        add     MM_OFFSET(%ebp), %edi
                    872:        rep
                    873:        movsw
                    874:        sub     MM_OFFSET(%ebp), %esi
                    875: 
                    876:        mov     %cs:rowtab(,%ebx,4),%edi
                    877:        mov     $NCOL,%ecx
                    878:        movb    $0x20,%al
                    879: 
                    880:        add     MM_OFFSET(%ebp), %edi
                    881:        rep
                    882:        stosw
                    883:        sub     MM_OFFSET(%ebp), %edi
                    884: 
                    885:        subb    COL,COL
                    886:        movb    ROW,%bl
                    887:        mov     %cs:rowtab(,%ebx,4),%edi
                    888: loc35: pop     %ecx
                    889:        pop     %esi
                    890:        pop     %ds
                    891:        call    exit
                    892:        jmp     eval
                    893: 
                    894: ////////
                    895: /
                    896: / mm_dmi - disable manual input
                    897: /
                    898: /      Set flag preventing keyboard input, and causing cursor to vanish.
                    899: /
                    900: ////////
                    901: 
                    902: mm_dmi:
                    903:        movl    $1,%ss:islock
                    904:        jmp     eval
                    905: 
                    906: ////////
                    907: /
                    908: / mm_ea - erase in area
                    909: /
                    910: /      Erase some or all of the characters in the currently active area
                    911: /      according to the parameter:
                    912: /              0 - erase from active position to end inclusive (default)
                    913: /              1 - erase from start to active position inclusive
                    914: /              2 - erase all of active area
                    915: /
                    916: ////////
                    917: 
                    918: mm_ea: movb    MM_N1(%ebp),%al
                    919:        cmpb    $0,%al
                    920:        jne     loc36
                    921:        movb    MM_EROW(%ebp),%bl
                    922:        jmp     mm_e0
                    923: loc36: cmpb    $1,%al
                    924:        jne     loc37
                    925:        movb    MM_BROW(%ebp),%bl
                    926:        jmp     mm_e1
                    927: loc37: subb    COL,COL
                    928:        movb    MM_BROW(%ebp),ROW
                    929:        movb    ROW,%bl
                    930:        mov     %cs:rowtab(,%ebx,4),POS
                    931:        movb    MM_EROW(%ebp),%bl
                    932:        subb    ROW,%bl
                    933:        jmp     mm_e2
                    934: 
                    935: 
                    936: ////////
                    937: /
                    938: / mm_ed - erase in display
                    939: /
                    940: /      Erase some or all of the characters in the display according to the
                    941: /      parameter
                    942: /              0 - erase from active position to end inclusive (default)
                    943: /              1 - erase from start to active position inclusive
                    944: /              2 - erase all of display
                    945: /
                    946: ////////
                    947: 
                    948: mm_ed: movb    MM_N1(%ebp),%al
                    949:        cmpb    $0,%al
                    950:        jne     loc38
                    951:        movb    MM_LROW(%ebp),%bl
                    952:        jmp     mm_e0
                    953: loc38: cmpb    $1,%al
                    954:        jne     loc39
                    955:        subb    %bl,%bl
                    956:        jmp     mm_e1
                    957: loc39: subb    COL,COL
                    958:        movb    MM_BROW(%ebp),ROW
                    959:        sub     POS,POS
                    960:        movb    MM_LROW(%ebp),%bl
                    961:        jmp     mm_e2
                    962: 
                    963: ////////
                    964: /
                    965: / mm_el - erase in line
                    966: /
                    967: /      Erase some or all of the characters in the line according to the
                    968: /      parameter:
                    969: /              0 - erase from active position to end inclusive (default)
                    970: /              1 - erase from start to active position inclusive
                    971: /              2 - erase entire line
                    972: /
                    973: ////////
                    974: 
                    975: mm_el: movb    MM_N1(%ebp),%al
                    976:        movb    ROW,%bl
                    977:        cmpb    $0,%al
                    978:        je      mm_e0
                    979:        cmpb    $1,%al
                    980:        je      mm_e1
                    981:        mov     %cs:rowtab(,%ebx,4),POS
                    982:        subb    COL,COL
                    983:        subb    %bl,%bl
                    984: /      jmp     mm_e2
                    985: 
                    986: mm_e2: push    %ecx
                    987:        movb    $0x20,%al
                    988: 
                    989: loc40: mov     $NCOL,%ecx
                    990:        add     MM_OFFSET(%ebp), POS
                    991:        rep
                    992:        stosw
                    993:        sub     MM_OFFSET(%ebp), POS
                    994: 
                    995:        decb    %bl
                    996:        jge     loc40
                    997:        pop     %ecx
                    998:        jmp     repos
                    999: 
                   1000: mm_e1: push    %ecx
                   1001:        mov     POS,%ecx
                   1002:        mov     %cs:rowtab(,%ebx,4),POS
                   1003:        sub     POS,%ecx
                   1004:        jl      loc41
                   1005:        movb    $0x20,%al
                   1006:        shr     $1,%ecx
                   1007: 
                   1008:        add     MM_OFFSET(%ebp), POS
                   1009:        rep
                   1010:        stosw
                   1011:        sub     MM_OFFSET(%ebp), POS
                   1012: 
                   1013: loc41: pop     %ecx
                   1014:        jmp     repos
                   1015: 
                   1016: mm_e0: push    %ecx
                   1017:        mov     %cs:rowtab+4(,%ebx,4),%ecx
                   1018:        sub     POS,%ecx
                   1019:        jl      loc42
                   1020:        movb    $0x20,%al
                   1021:        shr     $1,%ecx
                   1022: 
                   1023:        add     MM_OFFSET(%ebp), POS
                   1024:        rep
                   1025:        stosw
                   1026:        sub     MM_OFFSET(%ebp), POS
                   1027: 
                   1028: loc42: pop     %ecx
                   1029:        jmp     repos
                   1030: 
                   1031: ////////
                   1032: /
                   1033: / mm_emi - enable manual input
                   1034: /
                   1035: /      Clear flag preventing keyboard input.
                   1036: /
                   1037: ////////
                   1038: 
                   1039: mm_emi:
                   1040:        movl    $0,%ss:islock
                   1041:        jmp     eval
                   1042: 
                   1043: ////////
                   1044: /
                   1045: / mm_il - insert line
                   1046: /
                   1047: /      Insert a erased line at the active line by shifting the contents
                   1048: /      of the active line and all following lines away from the active line.
                   1049: /      The contents of the last line in the scrolling region are removed.
                   1050: /
                   1051: ////////
                   1052: 
                   1053: scrolldown:
                   1054: mm_il: push    %ds
                   1055:        push    %esi
                   1056:        push    %ecx
                   1057:        movw    MM_BASE(%ebp),%ds
                   1058:        movb    MM_EROW(%ebp),%bl
                   1059:        mov     %cs:rowtab(,%ebx,4),%esi
                   1060:        mov     %esi,%ecx
                   1061:        sub     $2,%esi
                   1062:        mov     %cs:rowtab+4(,%ebx,4),%edi
                   1063:        sub     $2,%edi
                   1064:        movb    ROW,%bl
                   1065:        sub     %cs:rowtab(,%ebx,4),%ecx
                   1066:        jle     loc43
                   1067:        shr     $1,%ecx
                   1068:        std
                   1069: 
                   1070:        add     MM_OFFSET(%ebp), %esi
                   1071:        add     MM_OFFSET(%ebp), %edi
                   1072:        rep
                   1073:        movsw
                   1074:        sub     MM_OFFSET(%ebp), %esi
                   1075: 
                   1076:        mov     %cs:rowtab(,%ebx,4),%edi
                   1077:        mov     $NCOL,%ecx
                   1078:        movb    $0x20,%al
                   1079:        cld
                   1080: 
                   1081:        add     MM_OFFSET(%ebp), %edi
                   1082:        rep
                   1083:        stosw
                   1084:        sub     MM_OFFSET(%ebp), %edi
                   1085: 
                   1086:        subb    COL,COL
                   1087:        movb    ROW,%bl
                   1088:        mov     %cs:rowtab(,%ebx,4),%edi
                   1089: loc43: pop     %ecx
                   1090:        pop     %esi
                   1091:        pop     %ds
                   1092:        call    exit
                   1093:        jmp     eval
                   1094: 
                   1095: ////////
                   1096: /
                   1097: / mm_hpa - horizontal position absolute
                   1098: /
                   1099: /      Moves the active position within the active line to the position
                   1100: /      specified by the parameter.  A parameter value of zero or one
                   1101: /      moves the active position to the first position of the active line.
                   1102: /
                   1103: ////////
                   1104: 
                   1105: mm_hpa:        movb    MM_N1(%ebp),COL
                   1106:        decb    COL
                   1107:        jg      loc44
                   1108:        subb    COL,COL
                   1109: loc44: cmpb    $NCOL,COL
                   1110:        jb      loc45
                   1111:        movb    $NCOL-1,COL
                   1112: loc45: jmp     repos                   / reposition cursor
                   1113: 
                   1114: ////////
                   1115: /
                   1116: / mm_hpr - horizontal position relative
                   1117: /
                   1118: /      Moves the active position forward the number of positions specified
                   1119: /      by the parameter.  A parameter value of zero or one indicates a
                   1120: /      single-position move.
                   1121: /
                   1122: ////////
                   1123: 
                   1124: mm_hpr:        movb    MM_N1(%ebp),%al
                   1125:        orb     %al,%al
                   1126:        jne     loc46
                   1127:        incb    %al
                   1128: loc46: addb    %al,COL
                   1129:        cmpb    $NCOL,COL
                   1130:        jb      loc47
                   1131:        movb    $NCOL-1,COL
                   1132: loc47: jmp     repos                   / reposition cursor
                   1133: 
                   1134: ////////
                   1135: /
                   1136: / mm_hvp - horizontal and vertical position
                   1137: /
                   1138: /      Moves the active position to the position specified by two parameters.
                   1139: /      The first parameter specifies the vertical position (MM_ROW(%ebp)).
                   1140: /      The second parameter specifies the horizontal position (MM_COL(%ebp)).
                   1141: /      A parameter value of zero or one moves the active position to the
                   1142: /      first line or column in the display.
                   1143: /
                   1144: ////////
                   1145: 
                   1146: mm_hvp:        movb    MM_N1(%ebp),ROW
                   1147:        decb    ROW
                   1148:        jg      loc48
                   1149:        subb    ROW,ROW
                   1150: loc48: cmpb    MM_LROW(%ebp),ROW
                   1151:        jna     loc49
                   1152:        movb    MM_LROW(%ebp),ROW
                   1153: loc49: movb    MM_N2(%ebp),COL
                   1154:        decb    COL
                   1155:        jg      loc50
                   1156:        subb    COL,COL
                   1157: loc50: cmpb    $NCOL,COL
                   1158:        jb      loc51
                   1159:        movb    $NCOL-1,COL
                   1160: loc51: jmp     repos                   / reposition cursor
                   1161: 
                   1162: ////////
                   1163: /
                   1164: / mm_ind - index
                   1165: /
                   1166: /      Causes the active position to move downward one line without changing
                   1167: /      the horizontal position.  Scrolling occurs if below scrolling region.
                   1168: /
                   1169: ////////
                   1170: 
                   1171: mm_ind:        incb    ROW
                   1172:        cmpb    MM_EROW(%ebp),ROW
                   1173:        jg      loc52
                   1174:        jmp     repos
                   1175: loc52: movb    MM_EROW(%ebp),ROW
                   1176:        jmp     scrollup
                   1177: 
                   1178: ////////
                   1179: /
                   1180: / mm_new - save cursor position
                   1181: /
                   1182: ////////
                   1183: 
                   1184: mm_new:        movb    COL,MM_SCOL(%ebp)
                   1185:        movb    ROW,MM_SROW(%ebp)
                   1186:        jmp     eval
                   1187: 
                   1188: ////////
                   1189: /
                   1190: / mm_old - restore old cursor position
                   1191: /
                   1192: ////////
                   1193: 
                   1194: mm_old:        movb    MM_SCOL(%ebp),COL
                   1195:        movb    MM_SROW(%ebp),ROW
                   1196:        jmp     repos
                   1197: 
                   1198: ////////
                   1199: /
                   1200: / mm_ri - reverse index
                   1201: /
                   1202: /      Moves the active position to the same horizontal position on the
                   1203: /      preceding line.  Scrolling occurs if above scrolling region.
                   1204: /
                   1205: ////////
                   1206: 
                   1207: mm_ri: decb    ROW
                   1208:        cmpb    MM_BROW(%ebp),ROW
                   1209:        jge     loc53
                   1210:        movb    MM_BROW(%ebp),ROW
                   1211:        jmp     scrolldown
                   1212: loc53: jmp     repos
                   1213: 
                   1214: ////////
                   1215: /
                   1216: / mm_scr - select cursor rendition
                   1217: /
                   1218: /      Invokes the cursor rendition specified by the parameter.
                   1219: /
                   1220: /      Recognized renditions are:      0 - cursor visible
                   1221: /                                      1 - cursor invisible
                   1222: ////////
                   1223: 
                   1224: mm_scr:        decb     MM_N1(%ebp)
                   1225:        je      loc54
                   1226:        jg      loc55
                   1227:        movl    $0,MM_INVIS(%ebp)
                   1228:        jmp     eval
                   1229: 
                   1230: loc54: movl    $-1,MM_INVIS(%ebp)
                   1231: loc55: jmp     eval
                   1232: 
                   1233: ////////
                   1234: /
                   1235: / mm_sgr - select graphic rendition
                   1236: /
                   1237: /      Invokes the graphic rendition specified by the parameter.
                   1238: /      All following characters in the data stream are rendered
                   1239: /      according to the parameters until the next occurrence of
                   1240: /      SGR in the data stream.
                   1241: /
                   1242: /      Recognized renditions are:      1 - high intensity
                   1243: /                                      4 - underline
                   1244: /                                      5 - slow blink
                   1245: /                                      7 - reverse video
                   1246: /                                      8 - concealed on
                   1247: /                                      30-37 - foreground color
                   1248: /                                      40-47 - background color
                   1249: /                                      50-57 - border color
                   1250: /
                   1251: ////////
                   1252: 
                   1253: mm_sgr:        movb    MM_N1(%ebp),%al
                   1254: 
                   1255:        cmpb    $0,%al                  / reset all = 0
                   1256:        jne     loc56
                   1257:        movb    $0x07,ATTR
                   1258: loc57: jmp     eval
                   1259: 
                   1260: loc56: cmpb    $1,%al                  / bold =  1
                   1261:        jne     loc58
                   1262:        orb     $INTENSE,ATTR
                   1263:        jmp     loc57
                   1264: 
                   1265: loc58: cmpb    $4,%al                  / underline = 4
                   1266:        jne     loc59
                   1267:        cmp     $0x03D4,MM_PORT(%ebp)   / color card?
                   1268:        je      loc57                   / yes, ignore underline
                   1269:        andb    $0x88,ATTR
                   1270:        orb     $0x01,ATTR
                   1271:        jmp     loc57
                   1272: 
                   1273: loc59: cmpb    $5,%al                  / blinking = 5
                   1274:        jne     loc60
                   1275:        orb     $BLINK,ATTR
                   1276:        jmp     loc57
                   1277: 
                   1278: loc60: cmpb    $7,%al                  / reverse video = 7
                   1279:        jne     loc61
                   1280:        movb    $0x70,%al
                   1281:        cmp     $0x3D4,MM_PORT(%ebp)    / color card?
                   1282:        jne     loc62
                   1283:        movb    ATTR,%al                / yes, exchange foreground/background
                   1284:        andb    $0x77,%al
                   1285:        rolb    $1,%al
                   1286:        rolb    $1,%al
                   1287:        rolb    $1,%al
                   1288:        rolb    $1,%al
                   1289: loc62: andb    $0x88,ATTR
                   1290:        orb     %al,ATTR
                   1291:        jmp     loc57
                   1292: 
                   1293: loc61: cmpb    $8,%al                  / concealed on = 8
                   1294:        jne     loc63
                   1295:        cmp     $0x3D4,MM_PORT(%ebp)    / color card?
                   1296:        jne     loc64
                   1297: 
                   1298:        andb    $0x70,ATTR              / Yes,  Set foreground color
                   1299:        movb    ATTR,%al                /       to background color.
                   1300:        rorb    $1,%al
                   1301:        rorb    $1,%al
                   1302:        rorb    $1,%al
                   1303:        rorb    $1,%al
                   1304:        orb     %al,ATTR
                   1305:        jmp     loc57
                   1306: 
                   1307: loc64: andb    $0x80,ATTR              / No, set attributes to non-display.
                   1308:        jmp     loc57                   /       retain blink attribute.
                   1309: 
                   1310: loc63: cmp     $0x03D4,MM_PORT(%ebp)   / color card?
                   1311:        jne     loc57                   / no, ignore remaining options
                   1312: loc65: subb    $30,%al                 / foreground color
                   1313:        jl      loc66
                   1314:        cmpb    $7,%al
                   1315:        jg      loc67
                   1316:        movb    %al,%bl
                   1317:        andb    $0xf8,ATTR
                   1318:        orb     %cs:fcolor(%ebx),ATTR
                   1319:        jmp     loc66
                   1320: loc67: subb    $10,%al
                   1321:        jl      loc66
                   1322:        cmpb    $7,%al
                   1323:        jg      loc68
                   1324:        movb    %al,%bl
                   1325:        andb    $0x8f,ATTR
                   1326:        orb     %cs:bcolor(%ebx),ATTR
                   1327:        jmp     loc66
                   1328: loc68: subb    $10,%al
                   1329:        jl      loc66
                   1330:        cmpb    $7,%al
                   1331:        jg      loc69
                   1332:        movb    %al,%bl
                   1333:        movb    %cs:fcolor(%ebx),%al
                   1334:        push    %edx
                   1335:        mov     MM_PORT(%ebp),%edx
                   1336:        add     $5,%edx
                   1337:        outb    (%dx)
                   1338:        pop     %edx
                   1339: /      jmp     loc66
                   1340: loc69:
                   1341: loc66: jmp     eval
                   1342: 
                   1343: ////////
                   1344: /
                   1345: / mm_ssr - set scrolling region
                   1346: /
                   1347: ////////
                   1348: 
                   1349: mm_ssr:        movb    MM_N1(%ebp),%al
                   1350:        decb    %al
                   1351:        jge     loc70
                   1352:        subb    %al,%al
                   1353: loc70: cmpb    MM_LROW(%ebp),%al
                   1354:        ja      loc71
                   1355:        movb    MM_N2(%ebp),%bl
                   1356:        decb    %bl
                   1357:        jge     loc72
                   1358:        subb    %bl,%bl
                   1359: loc72: cmpb    MM_LROW(%ebp),%bl
                   1360:        ja      loc71
                   1361:        cmpb    %bl,%al
                   1362:        ja      loc71
                   1363:        movb    %al,MM_BROW(%ebp)
                   1364:        movb    %bl,MM_EROW(%ebp)
                   1365:        movb    %al,ROW
                   1366:        subb    COL,COL
                   1367: loc71: jmp     repos
                   1368: 
                   1369: ////////
                   1370: /
                   1371: / mm_vpa - vertical position absolute
                   1372: /
                   1373: /      Moves the active position to the line specified by the parameter
                   1374: /      without changing the horizontal position.
                   1375: /      A parameter value of 0 or 1 moves the active position vertically
                   1376: /      to the first line.
                   1377: /
                   1378: ////////
                   1379: 
                   1380: mm_vpa:        movb    MM_N1(%ebp),ROW
                   1381:        decb    ROW
                   1382:        jg      loc73
                   1383:        subb    ROW,ROW
                   1384: loc73: cmpb    MM_LROW(%ebp),ROW
                   1385:        jna     loc74
                   1386:        movb    MM_LROW(%ebp),ROW
                   1387: loc74: jmp     repos                   / reposition cursor
                   1388: 
                   1389: ////////
                   1390: /
                   1391: / mm_vpr - vertical position relative
                   1392: /
                   1393: /      Moves the active position downward the number of lines specified
                   1394: /      by the parameter without changing the horizontal position.
                   1395: /      A parameter value of zero or one moves the active position
                   1396: /      one line downward.
                   1397: /
                   1398: ////////
                   1399: 
                   1400: mm_vpr:        movb    MM_N1(%ebp),%al
                   1401:        orb     %al,%al
                   1402:        jne     loc75
                   1403:        incb    %al
                   1404: loc75: addb    %al,ROW
                   1405:        cmpb    MM_LROW(%ebp),ROW
                   1406:        jb      loc76
                   1407:        movb    MM_LROW(%ebp),ROW
                   1408: loc76: jmp     repos                   / reposition cursor
                   1409: 
                   1410: ////////
                   1411: /
                   1412: / asctab - table of functions indexed by ascii characters
                   1413: /
                   1414: ////////
                   1415: 
                   1416:        .align  4
                   1417: asctab:        .long   eval,   eval,   eval,   eval    /* NUL  SOH  STX  ETX  */
                   1418:        .long   eval,   eval,   eval,   mmbell  /* EOT  ENQ  ACK  BEL  */
                   1419:        .long   mm_cub, mm_cht, mm_cnl, mm_ind  /* BS   HT   LF   VT   */
                   1420:        .long   eval,   mm_cr,  eval,   eval    /* FF   CR   SO   SI   */
                   1421:        .long   eval,   eval,   eval,   eval    /* DLE  DC1  DC2  DC3  */
                   1422:        .long   eval,   eval,   eval,   eval    /* DC4  NAK  SYN  ETB  */
                   1423:        .long   eval,   eval,   eval,   mm_esc  /* CAN  EM   SUB  ESC  */
                   1424:        .long   eval,   eval,   eval,   eval    /* FS   GS   RS   US   */
                   1425:        .long   mmputc, mmputc, mmputc, mmputc  /*   ! " # \040 - \043 */
                   1426:        .long   mmputc, mmputc, mmputc, mmputc  /* $ % & ' \044 - \047 */
                   1427:        .long   mmputc, mmputc, mmputc, mmputc  /* ( ) * + \050 - \053 */
                   1428:        .long   mmputc, mmputc, mmputc, mmputc  /* , - . / \054 - \057 */
                   1429:        .long   mmputc, mmputc, mmputc, mmputc  /* 0 1 2 3 \060 - \063 */
                   1430:        .long   mmputc, mmputc, mmputc, mmputc  /* 4 5 6 7 \064 - \067 */
                   1431:        .long   mmputc, mmputc, mmputc, mmputc  /* 8 9 : ; \070 - \073 */
                   1432:        .long   mmputc, mmputc, mmputc, mmputc  /* < = > ? \074 - \077 */
                   1433:        .long   mmputc, mmputc, mmputc, mmputc  /* @ A B C \100 - \103 */
                   1434:        .long   mmputc, mmputc, mmputc, mmputc  /* D E F G \104 - \107 */
                   1435:        .long   mmputc, mmputc, mmputc, mmputc  /* H I J K \110 - \113 */
                   1436:        .long   mmputc, mmputc, mmputc, mmputc  /* L M N O \114 - \117 */
                   1437:        .long   mmputc, mmputc, mmputc, mmputc  /* P Q R S \120 - \123 */
                   1438:        .long   mmputc, mmputc, mmputc, mmputc  /* T U V W \124 - \127 */
                   1439:        .long   mmputc, mmputc, mmputc, mmputc  /* X Y Z [ \130 - \133 */
                   1440:        .long   mmputc, mmputc, mmputc, mmputc  /* \ ] ^ _ \134 - \137 */
                   1441:        .long   mmputc, mmputc, mmputc, mmputc  /* ` a b c \140 - \143 */
                   1442:        .long   mmputc, mmputc, mmputc, mmputc  /* d e f g \144 - \147 */
                   1443:        .long   mmputc, mmputc, mmputc, mmputc  /* h i j k \150 - \153 */
                   1444:        .long   mmputc, mmputc, mmputc, mmputc  /* l m n o \154 - \157 */
                   1445:        .long   mmputc, mmputc, mmputc, mmputc  /* p q r s \160 - \163 */
                   1446:        .long   mmputc, mmputc, mmputc, mmputc  /* t u v w \164 - \167 */
                   1447:        .long   mmputc, mmputc, mmputc, mmputc  /* x y z { \170 - \173 */
                   1448:        .long   mmputc, mmputc, mmputc, mmputc  /* | } ~ ? \174 - \177 */
                   1449: 
                   1450: ////////
                   1451: /
                   1452: / esctab - table of functions indexed by ESC characters.
                   1453: /
                   1454: ////////
                   1455: 
                   1456: esctab:        .long   mmputc, mmputc, mmputc, mmputc  /* NUL  SOH  STX  ETX  */
                   1457:        .long   mmputc, mmputc, mmputc, mmputc  /* EOT  ENQ  ACK  BEL  */
                   1458:        .long   mmputc, mmputc, mmputc, mmputc  /* BS   HT   LF   VT   */
                   1459:        .long   mmputc, mmputc, mmputc, mmputc  /* FF   CR   SO   SI   */
                   1460:        .long   mmputc, mmputc, mmputc, mmputc  /* DLE  DC1  DC2  DC3  */
                   1461:        .long   mmputc, mmputc, mmputc, mmputc  /* DC4  NAK  SYN  ETB  */
                   1462:        .long   mmputc, mmputc, mmputc, mmputc  /* CAN  EM   SUB  ESC  */
                   1463:        .long   mmputc, mmputc, mmputc, mmputc  /* FS   GS   RS   US   */
                   1464:        .long   eval,   eval,   eval,   eval    /*   ! " # \040 - \043 */
                   1465:        .long   eval,   eval,   eval,   eval    /* $ % & ' \044 - \047 */
                   1466:        .long   eval,   eval,   eval,   eval    /* ( ) * + \050 - \053 */
                   1467:        .long   eval,   eval,   eval,   eval    /* , - . / \054 - \057 */
                   1468:        .long   eval,   eval,   eval,   eval    /* 0 1 2 3 \060 - \063 */
                   1469:        .long   eval,   eval,   eval,   mm_new  /* 4 5 6 7 \064 - \067 */
                   1470:        .long   mm_old, eval,   eval,   eval    /* 8 9 : ; \070 - \073 */
                   1471:        .long   eval,   mmspec, mmspec, eval    /* < = > ? \074 - \077 */
                   1472:        .long   eval,   eval,   eval,   eval    /* @ A B C \100 - \103 */
                   1473:        .long   mm_ind, mm_cnl, eval,   eval    /* D E F G \104 - \107 */
                   1474:        .long   eval,   eval,   eval,   eval    /* H I J K \110 - \113 */
                   1475:        .long   eval,   mm_ri,  eval,   eval    /* L M N O \114 - \117 */
                   1476:        .long   eval,   eval,   eval,   eval    /* P Q R S \120 - \123 */
                   1477:        .long   eval,   eval,   eval,   eval    /* T U V W \124 - \127 */
                   1478:        .long   eval,   eval,   eval,   csi_n1  /* X Y Z [ \130 - \133 */
                   1479:        .long   eval,   eval,   eval,   eval    /* \ ] ^ _ \134 - \137 */
                   1480:        .long   mm_dmi, eval,   mm_emi, mminit  /* ` a b c \140 - \143 */
                   1481:        .long   eval,   eval,   eval,   eval    /* d e f g \144 - \147 */
                   1482:        .long   eval,   eval,   eval,   eval    /* h i j k \150 - \153 */
                   1483:        .long   eval,   eval,   eval,   eval    /* l m n o \154 - \157 */
                   1484:        .long   eval,   eval,   eval,   eval    /* p q r s \160 - \163 */
                   1485:        .long   mmspec, mmspec, eval,   eval    /* t u v w \164 - \167 */
                   1486:        .long   eval,   eval,   eval,   eval    /* x y z { \170 - \173 */
                   1487:        .long   eval,   eval,   eval,   eval    /* | } ~ ? \174 - \177 */
                   1488: 
                   1489: 
                   1490: ////////
                   1491: /
                   1492: / csitab - table of functions indexed by ESC [ characters.
                   1493: /
                   1494: ////////
                   1495: 
                   1496: csitab:        .long   eval,   eval,   eval,   eval    /* NUL  SOH  STX  ETX  */
                   1497:        .long   eval,   eval,   eval,   eval    /* EOT  ENQ  ACK  BEL  */
                   1498:        .long   eval,   eval,   eval,   eval    /* BS   HT   LF   VT   */
                   1499:        .long   eval,   eval,   eval,   eval    /* FF   CR   SO   SI   */
                   1500:        .long   eval,   eval,   eval,   eval    /* DLE  DC1  DC2  DC3  */
                   1501:        .long   eval,   eval,   eval,   eval    /* DC4  NAK  SYN  ETB  */
                   1502:        .long   eval,   eval,   eval,   eval    /* CAN  EM   SUB  ESC  */
                   1503:        .long   eval,   eval,   eval,   eval    /* FS   GS   RS   US   */
                   1504:        .long   eval,   eval,   eval,   eval    /*   ! " # \040 - \043 */
                   1505:        .long   eval,   eval,   eval,   eval    /* $ % & ' \044 - \047 */
                   1506:        .long   eval,   eval,   eval,   eval    /* ( ) * + \050 - \053 */
                   1507:        .long   eval,   eval,   eval,   eval    /* , - . / \054 - \057 */
                   1508:        .long   eval,   eval,   eval,   eval    /* 0 1 2 3 \060 - \063 */
                   1509:        .long   eval,   eval,   eval,   eval    /* 4 5 6 7 \064 - \067 */
                   1510:        .long   eval,   eval,   eval,   eval    /* 8 9 : ; \070 - \073 */
                   1511:        .long   eval,   eval,   csi_gt, csi_q   /* < = > ? \074 - \077 */
                   1512:        .long   eval,   mm_cuu, mm_cud, mm_cuf  /* @ A B C \100 - \103 */
                   1513:        .long   mm_cub, mm_cnl, mm_cpl, mm_cha  /* D E F G \104 - \107 */
                   1514:        .long   mm_cup, mm_cht, mm_ed,  mm_el   /* H I J K \110 - \113 */
                   1515:        .long   mm_il,  mm_dl,  eval,   mm_ea   /* L M N O \114 - \117 */
                   1516:        .long   eval,   eval,   eval,   mm_ind  /* P Q R S \120 - \123 */
                   1517:        .long   mm_ri,  eval,   eval,   eval    /* T U V W \124 - \127 */
                   1518:        .long   eval,   eval,   mm_cbt, eval    /* X Y Z [ \130 - \133 */
                   1519:        .long   eval,   eval,   eval,   eval    /* \ ] ^ _ \134 - \137 */
                   1520:        .long   mm_hpa, mm_hpr, eval,   eval    /* ` a b c \140 - \143 */
                   1521:        .long   mm_vpa, mm_vpr, mm_hvp, mm_cup  /* d e f g \144 - \147 */
                   1522:        .long   eval,   eval,   eval,   eval    /* h i j k \150 - \153 */
                   1523:        .long   eval,   mm_sgr, eval,   eval    /* l m n o \154 - \157 */
                   1524:        .long   eval,   eval,   mm_ssr, eval    /* p q r s \160 - \163 */
                   1525:        .long   eval,   eval,   mm_scr, eval    /* t u v w \164 - \167 */
                   1526:        .long   eval,   eval,   eval,   eval    /* x y z { \170 - \173 */
                   1527:        .long   eval,   eval,   eval,   eval    /* | } ~ ? \174 - \177 */
                   1528: 
                   1529: ////////
                   1530: /
                   1531: / coltab - integer array of offsets to each column
                   1532: /
                   1533: ////////
                   1534: 
                   1535: coltab:        .long    0<<SCB,         1<<SCB,         2<<SCB,         3<<SCB
                   1536:        .long    4<<SCB,         5<<SCB,         6<<SCB,         7<<SCB
                   1537:        .long    8<<SCB,         9<<SCB,        10<<SCB,        11<<SCB
                   1538:        .long   12<<SCB,        13<<SCB,        14<<SCB,        15<<SCB
                   1539:        .long   16<<SCB,        17<<SCB,        18<<SCB,        19<<SCB
                   1540:        .long   20<<SCB,        21<<SCB,        22<<SCB,        23<<SCB
                   1541:        .long   24<<SCB,        25<<SCB,        26<<SCB,        27<<SCB
                   1542:        .long   28<<SCB,        29<<SCB,        30<<SCB,        31<<SCB
                   1543:        .long   32<<SCB,        33<<SCB,        34<<SCB,        35<<SCB
                   1544:        .long   36<<SCB,        37<<SCB,        38<<SCB,        39<<SCB
                   1545:        .long   40<<SCB,        41<<SCB,        42<<SCB,        43<<SCB
                   1546:        .long   44<<SCB,        45<<SCB,        46<<SCB,        47<<SCB
                   1547:        .long   48<<SCB,        49<<SCB,        50<<SCB,        51<<SCB
                   1548:        .long   52<<SCB,        53<<SCB,        54<<SCB,        55<<SCB
                   1549:        .long   56<<SCB,        57<<SCB,        58<<SCB,        59<<SCB
                   1550:        .long   60<<SCB,        61<<SCB,        62<<SCB,        63<<SCB
                   1551:        .long   64<<SCB,        65<<SCB,        66<<SCB,        67<<SCB
                   1552:        .long   68<<SCB,        69<<SCB,        70<<SCB,        71<<SCB
                   1553:        .long   72<<SCB,        73<<SCB,        74<<SCB,        75<<SCB
                   1554:        .long   76<<SCB,        77<<SCB,        78<<SCB,        79<<SCB
                   1555: 
                   1556: ////////
                   1557: /
                   1558: / rowtab - array of offsets to each row
                   1559: /
                   1560: ////////
                   1561: 
                   1562: rowtab:        .long   0, 160, 320, 480 
                   1563:        .long   640, 800, 960, 1120
                   1564:        .long   1280, 1440, 1600, 1760
                   1565:        .long   1920, 2080, 2240, 2400
                   1566:        .long   2560, 2720, 2880, 3040
                   1567:        .long   3200, 3360, 3520, 3680
                   1568:        .long   3840, 4000, 4160, 4320
                   1569:        .long   4480, 4640, 4800, 4960
                   1570: 
                   1571: 
                   1572: ////////
                   1573: /
                   1574: / fcolor - foreground color
                   1575: / bcolor - background color
                   1576: /
                   1577: /      indexed by ansi color (black,red,green,brown,blue,magenta,cyan,white)
                   1578: /      yields graphics color (black,blue,green,cyan,red,magenta,brown,white)
                   1579: /              which is properly shifted for installation in attribute byte.
                   1580: /
                   1581: ////////
                   1582: 
                   1583: fcolor:        .byte   0x00, 0x04, 0x02, 0x06, 0x01, 0x05, 0x03, 0x07
                   1584: bcolor:        .byte   0x00, 0x40, 0x20, 0x60, 0x10, 0x50, 0x30, 0x70
                   1585: 
                   1586: ////////
                   1587: /
                   1588: / mm_voff()    -- turn video display off
                   1589: /
                   1590: ////////
                   1591:        .globl  mm_voff
                   1592: mm_voff:
                   1593:        push    %ebp
                   1594:        mov     %esp, %ebp
                   1595:        mov     8(%ebp), %ebp           / VTERM *
                   1596:        mov     MM_PORT(%ebp), %edx
                   1597: 
                   1598:        add     $4,%edx
                   1599:        movb    $0x21,%al
                   1600:        outb    (%dx)
                   1601:        pop     %ebp
                   1602:        ret
                   1603: 
                   1604: ////////
                   1605: /
                   1606: / mm_von( vp ) -- turn video display on
                   1607: / VTDATA *vp;
                   1608: ////////
                   1609:        .globl  mm_von
                   1610: mm_von:
                   1611:        push    %ebp
                   1612:        mov     %esp, %ebp
                   1613:        mov     8(%ebp), %ebp           / VTERM *
                   1614:        mov     MM_PORT(%ebp), %edx
                   1615: 
                   1616:        add     $4,%edx
                   1617:        movb    $0x29,%al
                   1618:        outb    (%dx)
                   1619:        mov     $900,mmvcnt             / 900 seconds before video disabled
                   1620:        pop     %ebp
                   1621:        ret
                   1622: 
                   1623: ASMdump:
                   1624:        pusha
                   1625:        mov     $0, %eax
                   1626:        mov     %es, %ax
                   1627:        push    %eax
                   1628:        mov     %ds, %ax
                   1629:        push    %eax
                   1630:        mov     %cs, %ax
                   1631:        push    %eax
                   1632:        call    asmdump
                   1633:        pop     %eax
                   1634:        pop     %eax
                   1635:        pop     %eax
                   1636:        popa
                   1637:        ret
                   1638: 
                   1639:        .globl  ds_sel
                   1640: ds_sel:
                   1641:        mov     $0, %eax
                   1642:        mov     %ds, %ax
                   1643:        ret

unix.superglobalmegacorp.com

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