Mercurial > hg > Members > kono > nitros9-code
view level2/modules/krnp3_perr.asm @ 3222:c086a5d69b78
Corrected ,pc should have been ,pcr in KRNP3.asm
author | David Ladd <drencor-xeen@users.sourceforge.net> |
---|---|
date | Wed, 20 Dec 2017 23:28:18 -0600 |
parents | 00dc1ef6a7aa |
children | 7e268dfe3957 |
line wrap: on
line source
******************************************************************** * krnp3 - Printerr functionality for Level 2 * * $Id$ * * Peter E. Durham * The New Wentworth Timesharing System * summer: 6 Twin Brook Circle school: Quincy House D-24 * Andover, MA 01810 58 Plympton St. * (617) 475-4243 Cambridge, MA 02138 * (617) 498-3209 * cis: 73177,1215 delphi: PEDXING * unix: harvard!husc4!durham_2 intnet: durham_2@husc4.harvard.edu * * COPYRIGHT (C) 1987 by Peter Durham * Permission is given to all members of the OS-9 community to use, * modify, and share this program for their personal enjoyment. * Commercial use of this program, which was written for fun to share with * the community, is prohibited without the consent of the author. * Please share any extensions or modifications with the author, who * would be interested in hearing about them. * Small optimizations for size by L. Curtis Boyle 11/26/2017 * * NOTE * Quick poll... how does the above sound as a copyright notice? Clearly, * authors like to share their work while maintaining some control on it. * And it doesn't seem fair for someone else to make $ from something * someone else made for fun. I think the above conditions are what most * people want. Let me know what you think. * * NOTE * The inspiration for this utility was the os9p3 example in * the Tandy Level 2 manual. Tandy deserves praise for * including examples such as this one in their manuals. * * NOTE * There is something funny about KrnP3 modules... some versions * are not liked, others are. When developing this module, often * a version would fail... but if I added a "leas 0,s" right before * the "rts" in PrinBuf, it would work! Probably the location and * operation are not significant. This version here has never failed * to boot on my system; however, if it does on yours (or you change * it), try putting such things in. * * NOTE * For those people who just can't have enough... KrnP3 will look for * a module called KrnP4, and link to it, and execute it. Thanks to * Kev for this idea. Now we can keep additions to the kernel in nice * separate chunks. (How long 'til KrnP11 comes around...?) * * Edt/Rev YYYY/MM/DD Modified by * Comment * ------------------------------------------------------------------ * 1 1987/06/23 Peter E. Durham * First release. * 2 2017/11/26 L. Curtis Boyle * nam krnp3 ttl Printerr functionality for Level 2 ifp1 use defsfile endc Type set Systm ;System module, 6809 object code atrv set ReEnt+rev rev set 1 ; edition set 2 mod eom,name,Type,atrv,Entry,256 name fcs "KrnP3" fcb edition SvcTbl fcb F$PErr ;System call number fdb PErr-*-2 ;Offset to code fcb $80 ;End of table P4Name fcc "krnp4" fcb C$CR *+ * Initialization routine and table *- Entry equ * leay SvcTbl,pcr ;Get address of table os9 F$SSvc ;Install services in table lda #Type ;Get system module type for KrnP4 leax P4Name,pcr ;Get name for KrnP4 os9 F$Link ;Try to link to it bcs PErrBye ;If not found, exit jmp ,y ;Execute it, return from there *+ * The new F$Perr service call *- *+ * Data (in user space!) - reserved in users stack. 89 bytes *- BufLen equ 80 Buf rmb BufLen HunDig equ Buf+7 TenDig equ Buf+8 OneDig equ Buf+9 DataMem equ . ErrMsg fcc "Error #000" ErrLen equ *-ErrMsg FilNam fcc "/dd/sys/errmsg" fcb C$CR FilLen equ *-FilNam *+ * FUNCTION PErr * PURPOSE Top level routine * REGISTERS B = Error code (after Setup) * U = User memory area (after Setup) * Y = User process descriptor (after Setup) * A = Error file path number (after OpenFil) * X = Pointer to strings *- PErr equ * ldb R$B,u ;Get error code ldy D.Proc ;Get user's process descriptor ldu P$SP,y ;Get user's stack pointer leau -DataMem,u ;Reserve a little space (89 bytes) to build string leax ErrMsg,pcr ;Get pointer to "Error #000" bsr MoveBuf ;Go copy it over bsr WritNum ;Go copy the number into it pshs x,y,a ;Save regs lda P$Path+2,y ;Get Std Err path leax Buf,u ;Get ptr to message ldy #ErrLen ;Maximum ErrLen characters to print os9 I$Write ;Write out Error message puls x,y,a ;Restore regs bcs PErrBye ;If error, abort leax FilNam,pcr ;Get pointer to "/dd/sys/errmsg" bsr MoveBuf ;Go copy it over pshs x ;Preserve X lda #READ. ;Open path for read access leax Buf,u ;Get ptr to string os9 I$Open ;Open errmsg file puls x ;Restore X bcs PErrBye ;If error, abort Loop pshs y,x ;Save regs leax Buf,u ;Point to buffer ldy #BufLen ;Maximum BufLen characters to read os9 I$ReadLn ;Read a line puls y,x ;Restore regs bcs Error ;If error, print CR, and abort pshs b ;Save error code pshs b ;Save error code again for compare * Only called once, but may be to big to embed? bsr CalcNum ;What number is on this line? cmpb ,s+ ;Is this line the right line? puls b ;Restore error code bne Loop ;If not right line, loop again bsr PrinBuf ;If right line, write line out bra Close ;Done, so close the file Error bsr DoCR ;Go print a carriage return Close os9 I$Close ;Close the file PErrBye rts ;Return from system call *+ * FUNCTION MoveBuf * PURPOSE Copies string to user space * TAKES X = location of string in system space *- MoveBuf equ * pshs u,y,d ;Save registers lda D.SysTsk ;Get system process task number ldb P$Task,y ;Get user process task number leau Buf,u ;Get pointer to destination buffer ldy #BufLen ;Copy BufLen characters over (extras, oh well) os9 F$Move ;Move string to user space puls d,y,u,pc ;Restore registers and return *+ * FUNCTION WriteNum * PURPOSE Puts the ASCII value of the error code in user space * TAKES B = error code *- WritNum equ * pshs x,d ;Save registers clra ;Start A as 0 Huns cmpb #100 ;Is B >= 100? blo HunDone ;If not, go do Tens inca ;Increment hundreds digit subb #100 ;Subtract 100 from B bra Huns ;Go do again HunDone leax HunDig,u ;Where to put digit bsr WritDig ;Go put it there clra ;Start A again as 0 Tens cmpb #10 ;Is B >= 10? blo TenDone ;If not, go do Ones inca ;Increment hundreds digit subb #10 ;Subtract 10 from B bra Tens ;Go do again TenDone leax TenDig,u ;Where to put digit bsr WritDig ;Go put it there tfr b,a ;Get ones digit leax OneDig,u ;Where to put digit bsr WritDig ;Go put it there puls d,x,pc ;Restore registers and return *+ * FUNCTION WritDig * PURPOSE Copy digit into user space * TAKES A = digit to copy (not in ASCII yet) * X = where to put digit *- WritDig equ * pshs d ;Save registers adda #'0 ;Convert A to ASCII ldb P$Task,y ;Get task number os9 F$STABX ;Write that digit to user space puls d,pc ;Restore registers and return *+ * FUNCTION CalcNum * PURPOSE Converts ASCII number in user space to binary * TAKES Buf (in user space) = ASCII number * GIVES B = number converted * X = points to first nonnumeric character *- CalcNum equ * pshs a ;Save register leax Buf,u ;Get pointer to buffer clrb ;Clear result to 0 to start NextDig pshs b ;Save current result ldb P$Task,y ;Get user process task # os9 F$LDABX ;Get digit from user space puls b ;Get current result back suba #'0 ;Convert to binary; is it less than zero? bmi CalcBye ;If so, return cmpa #9 ;Is the digit more than nine? bhi CalcBye ;If so, return pshs a ;Save the digit while we multiply lda #10 ;Multiply current number by 10 mul ;Do it addb ,s+ ;Add new digit to number leax 1,x ;Advance X to next digit bra NextDig ;Go get the next digit CalcBye puls a,pc ;Restore register and return *+ * FUNCTION DoCR * PURPOSE Prints a carriage return *- 6809/6309 - only called once, embed above DoCR equ * pshs x,d ;Save registers ldb P$Task,y ;Get user task number lda #C$CR ;Load A with a CR leax Buf,u ;Get pointer to buffer os9 F$STABX ;Move the CR to the buffer bsr PrinBuf ;Go print it puls d,x,pc ;Restore registers and return *+ * FUNCTION PrinBuf * PURPOSE Prints out the string from user space * TAKES X (in user space) = String to print *- PrinBuf equ * pshs y,a ;Save registers lda P$Path+2,y ;Get StdErr path number ldy #BufLen ;Maximum BufLen characters to print os9 I$WritLn ;Write out message puls a,y,pc ;Restore registers and return emod eom equ * end