; M7MFIO-2.ASM For Electralogics Inc. MFIO. 04/30/84 ; ; You will want to look this file over carefully. There are a number of ; options that you can use to configure the program to suit your taste. ; This file places particular emphasis on using the Electralogics MFIO ; board with 8250 serial I/O. Much of the information contained here is ; not in the main file. ; ; Set serial port desired at 'sio' equate ; ; Use the "SET" command to change baudrate when desired. ; ; Edit this file for your preferences then follow the "TO USE:" example ; shown below. ; ; ; TO USE: First edit this file filling in answers for your own ; equipment. Then assemble with ASM.COM or equivalent ; assembler. Then use DDT to overlay the the results ; of this program to the original .COM file: ; ; A>DDT MDM7xx.COM ; DDT VERS 2.2 ; NEXT PC ; 4x00 0100 ; -IM7MFIO-2.HEX (note the "I" command) ; -R ("R" loads in the .HEX file) ; NEXT PC ; 4x00 0000 ; -G0 (return to CP/M) ; A>SAVE 73 MDM7xx.COM (now have a modified .COM file) ; ^ ; May vary depending upon version of MDM7xx ; ;---------------------------------------------------------------------------- ; NOTE: ; ; The MFIO is a very complex I/O board containing 8 serial ports, 2 parallel ; ports, a real time clock, and vectored interrupt controller. All of the ; above facilities can be accessed by the use of only 9 I/O port addresses. ; This requires that the active I/O block number be stored somewhere in memory ; so that when the current I/O operation is completed, the MFIO can be ; restored to its previous I/O block (normally the system console). I have ; selected location 0000FH for the purpose and called it 'BLKSTAT'. ; Any other unused memory location is equally suitable. ; ; If this procedure is adopted in all BIOS I/O routines, all that needs ; to be done in any other I/O routine is to select the current I/O block, ; set up the MFIO command port for that block and store that value at ; location 'BLKSTAT'. Following is my CONIN routine as an example: ; ; CONIN: mvi a,sio0 ; set sio0 for console I/O ; out cmdport ; and tell MFIO ; in linstat ; read the line status register ; ani ckrb ; & mask console kb rdy bit ; jz conin ; loop till ready ; in keydat ; read sio0 data register ; ani 7fh ; strip the parity bit ; push psw ; save the byte ; lda blkstat ; & get the previous I/O block ; out cmdport ; restore MFIO to prev block ; pop psw ; get the keyboard data byte ; ret ; and bail out ; ; The routine "mxdin" located near the end of this program is called from ; all routines which use BIOS I/O calls that utilize MFIO resources (in my ; system, ALL I/O except the disks is MFIO-oriented). Its only purpose is ; to ensure that the system keep track of the MFIO resource blocks. If you ; get really complicated (interrupts, for example) you may need to push ; and pop them using a 'stack'. ; 'nuff said. Luck!! ; ; - Bill Harnell ; = = = = = = = = = = = = = = = = = = ; ; 04/30/84 - Renamed and Revised for MDM7xx - Dennis Recla ; ; 08/14/83 - Revised to work with MFIO. - Vic Kass ; CONIN and CONOUT routines ; in your BIOS must reset ; modem port after any access! ; ; ; = = = = = = = = = = = = = = = = = ; BELL: EQU 07H ;bell CR: EQU 0DH ;carriage return ESC: EQU 1BH ;escape LF: EQU 0AH ;linefeed ; YES: EQU 0FFH NO: EQU 0 ; ; ; Change the value at MODDATP if it does not match what you are using. ; sio: equ 02H blkstat: equ 0000fh ;location to store current I/O block cmdport: equ 48H ; MODDATP: EQU 40H ;data port for MFIO MODCTL1: EQU MODDATP+5 ;status port for MFIO MODRCVB: EQU 1 ;bit to test for received data MODRCVR: EQU 1 ;modem receive ready MODSNDB: EQU 20H ;bit to test for ready to send MODSNDR: EQU 20H ;modem send ready bit ; ; ORG 100H ; ; Change the clock speed if needed, to match your system ; DS 3 ;(for "JMP START" instruction) ; PMMIMODEM: DB NO ;yes=PMMI S-100 Modem 103H SMARTMODEM: DB NO ;yes=Smartmodem TOUCHPULSE: DB 'T' ;T=touch, P=pulse (Smartmodem-only) 105H CLOCK: DB 40 ;clock speed in MHz x10, 25.5 MHz max. 106H ;20=2 MHh, 37=3.68 MHz, 40=4 MHz, etc. MSPEED: DB 1 ;0=110 1=300 2=450 3=600 4=710 5=1200 107H ;6=2400 7=4800 8=9600 9=19200 default BYTDLY: DB 5 ;0=0 delay 1=10ms 5=50 ms - 9=90 ms 108H ;default time to send character in ter- ;minal mode file transfer for slow BBS. CRDLY: DB 5 ;0=0 delay 1=100 ms 5=500 ms - 9=900 ms 109H ;default time for extra wait after CRLF ;in terminal mode file transfer NOOFCOL: DB 5 ;number of DIR columns shown 10AH SETUPTST: DB YES ;yes=user-added Setup routine 10BH SCRNTEST: DB YES ;Cursor control routine 10CH ACKNAK: DB YES ;yes=resend a record after any non-ACK 10DH ;no=resend a record after a valid NAK BAKUPBYTE: DB NO ;yes=change any file same name to .BAK 10EH CRCDFLT: DB YES ;yes=default to CRC checking 10FH TOGGLECRC: DB YES ;yes=allow toggling of CRC to Checksum 110H CONVBKSP: DB NO ;yes=convert backspace to rub 111H TOGGLEBK: DB NO ;yes=allow toggling of bksp to rub 112H ADDLF: DB NO ;no=no LF after CR to send file in 113H ;terminal mode (added by remote echo) TOGGLELF: DB YES ;yes=allow toggling of LF after CR 114H TRANLOGON: DB YES ;yes=allow transmission of logon 115H ;write logon sequence at location LOGON SAVCCP: DB YES ;yes=do not overwrite CCP 116H LOCONEXTCHR: DB NO ;yes=local command if EXTCHR precedes 117H ;no=external command if EXTCHR precedes TOGGLELOC: DB YES ;yes=allow toggling of LOCONEXTCHR 118H LSTTST: DB YES ;yes=printer available on printer port 119H XOFFTST: DB NO ;yes=checks for XOFF from remote while 11AH ;sending a file in terminal mode XONWAIT: DB NO ;yes=wait for XON after CR while 11BH ;sending a file in terminal mode TOGXOFF: DB YES ;yes=allow toggling of XOFF checking 11CH IGNORCTL: DB YES ;yes=CTL-chars above ^M not displayed 11DH EXTRA1: DB 0 ;for future expansion 11EH EXTRA2: DB 0 ;for future expansion 11FH BRKCHR: DB '@'-40H ;^@ = Send a 300 ms. break tone 120H NOCONNCT: DB 'N'-40H ;^N = Disconnect from the phone line 121H LOGCHR: DB 'O'-40H ;^O = Send logon 122H LSTCHR: DB 'P'-40H ;^P = Toggle printer 123H UNSAVE: DB 'R'-40H ;^R = Close input text buffer 124H TRANCHR: DB 'T'-40H ;^T = Transmit file to remote 125H SAVECHR: DB 'Y'-40H ;^Y = Open input text buffer 126H EXTCHR: DB '^'-40H ;^^ = Send next character 127H ; ; DS 2 ; 128H ; IN$MODCTL1: call mxdin ;set & store current I/O block IN MODCTL1 ! RET ;in modem control port 12AH DS 4 OUT$MODDATP: call mxdin OUT MODDATP ! RET ;out modem data port 134H DS 4 IN$MODDATP: call mxdin IN MODDATP ! RET ;in modem data port 13EH DS 4 ANI$MODRCVB: ANI MODRCVB ! RET ;bit to test for receive ready 148H CPI$MODRCVR: CPI MODRCVR ! RET ;value of rcv. bit when ready 14BH ANI$MODSNDB: ANI MODSNDB ! RET ;bit to test for send ready 14EH CPI$MODSNDR: CPI MODSNDR ! RET ;value of send bit when ready 151H DS 12 ;PMMI only calls 154H ; ; LOGONPTR: DW LOGON ;for user message. 160H DS 6 ; 162H JMP$GOODBYE: JMP GOODBYE ; 168H JMP$INITMOD: JMP INITMOD ;go to user written routine 16BH RET ! NOP ! NOP ;(by-passes PMMI routine) 16EH RET ! NOP ! NOP ;(by-passes PMMI routine) 171H RET ! NOP ! NOP ;(by-passes PMMI routine) 174H JMP$SETUPR: JMP SETUPR ; 177H JMP$SPCLMENU: JMP SPCLMENU ; 17AH JMP$SYSVER: JMP SYSVER ; 17DH JMP$BREAK: JMP SENDBRK ; 180H ; ; ; Do not change the following six lines. ; JMP$ILPRT: DS 3 ; 183H JMP$INBUF DS 3 ; 186H JMP$INLNCOMP: DS 3 ; 189H JMP$INMODEM DS 3 ; 18CH JMP$NXTSCRN: DS 3 ; 18FH JMP$TIMER DS 3 ; 192H ; ; ; Set the following clear screen codes for your terminal type ; CLREOS: CALL JMP$ILPRT ; 195H DB ESC,'Y',0,0,0 ; 198H RET ; 19DH ; CLRSCRN: CALL JMP$ILPRT ; 19EH DB ESC,'+',0,0,0 ; 1A1H RET ; 1A6H ; ; SYSVER: CALL JMP$ILPRT ; 1A7H DB 'Version for Electralogics Incorporated MFIO' DB CR,LF,0 RET ;..... ; ; ;----------------------------------------------------------------------- ; ; NOTE: You can change the SYSVER message to be longer or shorter. The ; end of your last routine should terminate by 0400H (601 bytes ; available after start of SYSVER) if using the Hayes Smartmodem ; or by address 0C00H (2659 bytes) otherwise. ; ;----------------------------------------------------------------------- ; ; You can put in a message at this location which can be called up with ; CTL-O if TRANLOGON has been set TRUE. You can put in several lines if ; desired. End with a 0. ; LOGON: DB 'Hello...... >> Bill Harnell<< here....',CR,LF,0 ;..... ; ; ; This routine sends a 300 ms. break tone to reset some time-share ; computers. ; SENDBRK: call mxdin ;set & store current I/O block MVI A,40H ;SET BREAK TONE OUT MODDATP+3 JMP GOODBYE1 ;SEND A 300 MS. BREAK TONE ;..... ; ; ; This routine sends a 300 ms. break tgone and set DTR low for the same ; length of time to disconnect some modems such as the Bell 212A, etc. ; GOODBYE: call mxdin XRA A OUT MODDATP+4 ;SET DTR AND RTS LOW MVI A,40H ;SET BREAK TONE OUT MODDATP+3 ; GOODBYE1: MVI B,3 ;WAIT 300 MS. CALL JMP$TIMER MVI A,03H ;RESET TO NORMAL 8 BITS OUT MODDATP+3 MVI A,01H OUT MODDATP+4 ;RESET DTR HIGH RET ;..... ; ; ; The following is used to initialize the MFIO 8250 I/O port 'SIO' ; INITMOD: MVI A,1 ;default transfer speed to 300 baud call mxdin STA MSPEED DI ;turn off interrupts for init. XRA A OUT MODDATP+1 ;interrupt enable register MVI A,80H ;insure out of mode to set baud rate OUT MODDATP+3 ;line control register OUT MODDATP+3 ; LSPSPD: MVI A,80H ;default 'LSP' speed for 300 baud OUT MODDATP ;register for 'LSP' speed if enabled ; MSPSPD: MVI A,01H ;default 'MSP' speed for 300 baud OUT MODDATP+1 ;register for 'MSP' speed if enabled ; MVI A,03H ;8-level, 1 stop bit, no parity OUT MODDATP+3 ;line control register MVI A,01H ;set 'DTR' for proper modem output level OUT MODDATP+4 ;modem control register EI ;restore interrupts to normal RET ;..... ; ; ; The following routine changes the baud rate for the MFIO with the SET ; command. ; SETUPR: call mxdin LXI D,BAUDBUF ;point to input buffer for INLNCOMP CALL JMP$ILPRT DB 'Input Baud Rate (300, 1200, etc.): ',0 CALL JMP$INBUF LXI D,BAUDBUF+2 CALL JMP$INLNCOMP ;compare BAUDBUF+2 with characters below DB '300',0 JNC OK300 ;go if got match CALL JMP$INLNCOMP DB '450',0 JNC OK450 CALL JMP$INLNCOMP DB '600',0 JNC OK600 CALL JMP$INLNCOMP DB '1200',0 JNC OK1200 CALL JMP$INLNCOMP DB '9600',0 JNC OK9600 CALL JMP$ILPRT ;all matches failed - tell operator DB '++ Incorrect entry ++',CR,LF,BELL,0 JMP SETUPR ;try again ; OK300: MVI A,1 ;MSPEED 300 baud value LHLD BD300 ;get 300 baud parameters in HL JMP LOADBD ;go load them ; OK450: MVI A,2 LHLD BD450 JMP LOADBD OK600: MVI A,3 LHLD BD600 JMP LOADBD ; OK1200: MVI A,5 LHLD BD1200 JMP LOADBD ; OK9600: MVI A,8 LHLD BD9600 ; LOADBD: STA INITMOD+1 ;store speed to show transfer time MOV A,L ;get least significant baud rate byte STA LSPSPD+1 ;store in INITMOD MOV A,H ;get most signifcant baud rate byte STA MSPSPD+1 ;store in INITMOD JMP INITMOD ;reset MFIO 8250 ; ; ; Table of baud rate parameters ; BD300: DW 0180H BD450: DW 0100H BD600: DW 00C0H BD1200: DW 0060H BD9600: DW 000CH ; BAUDBUF: DB 10,0 DS 10 ; ;----------------------------------------------------------------------- ; ; This routine can be used for your equipment, be sure to end with RET ; If using the Hayes Smartmodem this is unavailable without a special ; change. ; SPCLMENU: RET ; ;----------------------------------------------------------------------- ; mxdin: push psw mvi a,sio out cmdport sta blkstat ;store current I/O block pop psw ret ; ; NOTE: MUST TERMINATE PRIOR TO 0400H (with Smartmodem) ; 0C00H (without Smartmodem) ; END ;