Mercurial > hg > Members > kono > nitros9-code
view level1/cmds/os9gen.asm @ 1531:20841f236e32
'use rbfdefs' moved to upper defsfile
author | boisy |
---|---|
date | Fri, 16 Apr 2004 23:38:19 +0000 |
parents | 84ea83668304 |
children | 4a1da412e363 |
line wrap: on
line source
******************************************************************** * OS9Gen - OS-9 bootfile generator * * $Id$ * * Edt/Rev YYYY/MM/DD Modified by * Comment * ------------------------------------------------------------------ * 9 ????/??/?? * From OS-9 Level Two Vr. 2.00.01. * * 10 2003/06/28 Boisy G. Pitre * Added -t= option, fixed bug in single disk swap routine if key * besides 'C' was pressed, minor optimizations. * * l0r2 2003/07/24 Boisy G. Pitre * Fixed bug introduced in V03.01.03 where os9gen wouldn't write boot * track on DS disks. nam OS9Gen ttl OS-9 bootfile generator * Disassembled 02/07/06 13:11:11 by Disasm v1.6 (C) 1988 by RML IFP1 use defsfile ENDC DOHELP set 0 DOHD set 1 allow bootfile creation on HD tylg set Prgrm+Objct atrv set ReEnt+rev rev set $02 edition set 10 mod eom,name,tylg,atrv,start,size org 0 btfname rmb 2 btflag rmb 1 statptr rmb 2 bfpath rmb 1 devpath rmb 1 parmpath rmb 1 u0005 rmb 1 u0006 rmb 2 u0008 rmb 1 u0009 rmb 2 u000B rmb 2 u000D rmb 2 u000F rmb 2 u0011 rmb 2 u0013 rmb 2 u0015 rmb 2 u0017 rmb 7 devopts rmb 20 u0032 rmb 2 u0034 rmb 10 u003E rmb 2 sngldrv rmb 1 bootdev rmb 32 lsn0 rmb 26 u007B rmb 2 u007D rmb 1 sectbuff rmb 1024 u047E rmb 16 u048E rmb 1 u048F rmb 7 u0496 rmb 7018 size equ . name fcs /OS9Gen/ fcb edition IFNE DOHELP HelpMsg fcb C$LF fcc "Use (CAUTION): OS9Gen </devname> [-s]" fcb C$LF fcc " ..reads (std input) pathnames until EOF," fcb C$LF fcc " merging paths into New OS9Boot file." fcb C$LF fcc " -s = single drive operation" fcb C$LF fcc " -t=boottrack = set boot track file" fcb C$LF,C$CR ENDC fcc "Can't find: " ErrWrit fcb C$LF fcc "Error writing kernel track" fcb C$CR IFEQ DOHD HDGen fcb C$LF fcc "Error - cannot gen to hard disk" fcb C$CR ENDC IFGT Level-1 CantRel fcb C$LF fcc "Error - can't link to Rel module" fcb C$CR ENDC CarRet fcb C$CR TheBell fcb C$BELL TWarn fcb C$LF fcc "Warning - file(s) present" fcb C$LF fcc "on track " IFEQ Bt.Track-34 fcc "34" ELSE fcc "??" ENDC fcc " - this track" fcb C$LF fcc "not rewritten." fcb C$CR BootFrag fcb C$LF fcc "Error - OS9Boot file fragmented" fcb C$CR IFNE 0 BadTkMsg fcc "Error - Boot track file must be 4608 bytes" fcb C$CR BadTkMsgL equ *-BadTkMsg ENDC Source fcc "Ready SOURCE, hit C to continue: " SourceL equ *-Source Destin fcc "Ready DESTINATION, hit C to continue: " DestinL equ *-Destin Rename fcc "RENAME " TempBoot fcc "TempBoot " fcb $FF OS9Boot fcc "OS9Boot" fcb C$CR fcb $FF IFGT Level-1 TheRel fcc "Rel" fcb $FF ENDC start clrb stb <btflag assume no -t specified stb <u0005 stb <sngldrv assume multi-drive stu <statptr save statics pointer leas >u047E,u pshs u tfr y,d subd ,s++ subd #u047E clrb std <u0011 lda #PDELIM cmpa ,x lbne BadName os9 F$PrsNam lbcs ShowHelp lda #PDELIM cmpa ,y lbeq BadName pshs b,a L0216 lda ,y+ cmpa #'- beq L0222 cmpa #C$CR beq L0234 bra L0216 L0222 ldd ,y+ cmpa #C$CR beq L0234 cmpa #C$SPAC beq L0216 anda #$DF cmpa #'S beq L0232 cmpd #84*256+61 does D = 'T=' lbne SoftExit leay 1,y point past = sty <btfname save pointer to boottrack filename sta <btflag * Skip over non-spaces and non-CRs SkipNon lda ,y+ cmpa #C$CR beq L0234 cmpa #C$SPAC bne SkipNon bra L0216 L0232 inc <sngldrv set single drive flag bra L0222 L0234 puls b,a leay <bootdev,u L0239 sta ,y+ lda ,x+ decb bpl L0239 sty <u003E ldd #PENTIR*256+C$SPAC std ,y++ lbsr GetDest leax <bootdev,u lda #UPDAT. os9 I$Open sta <devpath lbcs ShowHelp leax <devopts,u clrb * ldb #SS.Opt os9 I$GetStt lbcs Bye IFEQ DOHD * If destination drive is hard disk, don't allow leax devopts,u lda <(PD.TYP-PD.OPT)+devopts,u get type byte bpl L0276 branch if not hard drive clrb leax >HDGen,pcr else tell user can't do hard drive lbra WritExit ENDC L0276 ldx <u003E leay >TempBoot,pcr lda #PDELIM L027E sta ,x+ lda ,y+ bpl L027E * Copy OS9Boot string to buffer leay >OS9Boot,pcr L0288 lda ,y+ sta ,x+ bpl L0288 tfr x,d leax <bootdev,u pshs x subd ,s++ std <u000D ldd #WRITE.*256+(READ.+WRITE.) * lda #WRITE. * ldb #READ.+WRITE. os9 I$Create sta <bfpath lbcs Bye ldx #$0000 upper 16 bits are zero stx <u0006 ldu #$3000 ldb #SS.Size os9 I$SetStt set size of newly created file lbcs Bye branch if error ldu <statptr retrieve static pointer bsr L032F * Read Bootlist file, line by line ReadBLst leax sectbuff,u ldy #256 clra standard input os9 I$ReadLn read line bcs L0312 branch if error lda ,x else get byte in A ldb #E$EOF and EOF error in B cmpa #C$CR CR? beq L0312 branch if so cmpa #'* comment? beq ReadBLst continue reading if so lda #READ. else use read perms os9 I$Open open file at X (line we read) bcs L031A branch if error sta <parmpath save path L02DD ldx <u0015 ldd <u0011 subd <u0013 tfr d,y lda <parmpath os9 I$Read bcc L02F9 cmpb #E$EOF lbne Bye os9 I$Close clr <parmpath bra ReadBLst L02F9 tfr y,d leax d,x stx <u0015 addd <u0013 std <u0013 cmpd <u0011 bcs L030C bsr L032B bcs L0328 L030C tst <parmpath bne L02DD bra ReadBLst L0312 cmpb #E$EOF end of file? bne L0328 branch if not bsr L033D bra L0377 L031A pshs b leax sectbuff,u ldy #256 lda #$02 standard error os9 I$WritLn write L0328 lbra Bye L032B bsr L033D bcs L033C L032F lbsr GetSrc clra clrb std <u0013 leax >u047E,u stx <u0015 L033C rts L033D lbsr GetDest ldd <u0013 beq L033C tst <sngldrv single drive? beq L0361 branch if not lda <devpath ldx #$0000 ldu #$0000 os9 I$Seek seek to LSN0 ldu <statptr +BGP+ added bcs L033C leax sectbuff,u ldy #256 os9 I$Read read LSN0 bcs L033C L0361 lda <bfpath leax >u047E,u ldy <u0013 os9 I$Write bcs L033C tfr y,d addd <u0006 std <u0006 clrb rts L0377 leax <devopts,u clrb * ldb #SS.Opt lda <bfpath os9 I$GetStt lbcs Bye lda <bfpath ldx #$0000 ldu <u0006 ldb #SS.Size os9 I$SetStt lbcs Bye ldu <statptr os9 I$Close lbcs ShowHelp ldx <u0032,u lda <u0034,u clrb tfr d,u lda <devpath os9 I$Seek ldu <statptr lbcs Bye leax >u047E,u ldy #256 os9 I$Read lbcs Bye ldd >u047E+(FD.SEG+FDSL.S+FDSL.B),u lbne ItsFragd if not zero, file is fragmented lda <devpath ldx #$0000 ldu #DD.BT os9 I$Seek seek to DD.BT ldu <statptr lbcs Bye leax u0008,u ldy #DD.DAT-DD.BT os9 I$Read read bootstrap sector and bootfile size lbcs Bye ldd <u000B beq L040D ldx <u003E leay >OS9Boot,pcr lda #PDELIM L03F3 sta ,x+ lda ,y+ bpl L03F3 leax <bootdev,u os9 I$Delete ldx <u003E leay >TempBoot,pcr lda #PDELIM L0407 sta ,x+ lda ,y+ bpl L0407 L040D tst <sngldrv beq L042E clra leax >Rename,pcr os9 F$Link bcc L0428 lbsr GetSrc os9 F$Load lbcs Bye lbsr GetDest L0428 tfr u,d ldu <statptr std u000F,u L042E lda #$01 clrb leax >Rename,pcr ldy <u000D leau <bootdev,u os9 F$Fork lbcs Bye os9 F$Wait lbcs Bye tstb lbne Bye tst <sngldrv beq L045F ldu <statptr ldd u000F,u tfr d,u os9 F$UnLink lbcs Bye L045F ldu <statptr ldb >u048E,u stb <u0008 ldd >u048F,u std <u0009 ldd <u0006 std <u000B ldx #$0000 ldu #DD.BT lda <devpath os9 I$Seek ldu <statptr lbcs Bye leax u0008,u ldy #DD.DAT-DD.BT os9 I$Write lbcs Bye pshs u clra clrb tfr d,x tfr d,u lda <devpath os9 I$Seek seek to LSN0 lbcs Bye puls u leax <lsn0,u ldy #DD.DAT lda <devpath os9 I$Read read first part of LSN0 lbcs Bye ldd #$0001 lbsr Seek2LSN leax sectbuff,u ldy <lsn0+DD.MAP,u get number of bytes in device's bitmap lda <devpath os9 I$Read lbcs Bye ldd #Bt.Track*256 boot track ldy #$0004 four bits lbsr ABMClear bcc L0520 ldd #Bt.Track*256 boot track lbsr Seek2LSN seek to it leax <u0017,u ldy #$0007 lda <devpath os9 I$Read read first seven bytes of boot track lbcs Bye leax <u0017,u ldd ,x cmpd #79*256+83 OS ?? lbne WarnUser * cmpb #'O * lbne WarnUser * cmpb #'S * lbne WarnUser lda $04,x cmpa #$12 beq L0512 ldd #Bt.Track*256+15 boot track, sector 16 ldy #$0003 sectors 16-18 lbsr ABMClear lbcs WarnUser L0512 clra ldb <lsn0+DD.TKS,u get number of tracks in D tfr d,y ldd #Bt.Track*256 boot track lbsr ABMSet bra L0531 L0520 ldd #Bt.Track*256+4 boot track ldy #$000E sectors 5-18 lbsr ABMClear lbcs WarnUser bra L0512 L0531 ldd #$0001 lbsr Seek2LSN leax sectbuff,u ldy <lsn0+DD.MAP,u get number of bytes in device's bitmap lda <devpath os9 I$Write write out the bitmap lbcs Bye * Code added to write alternate boottrack file * BGP - 2003/06/26 tst <btflag beq BTMem get boot track from memory lbsr GetSrc ldx btfname,u lda #READ. os9 I$Open lbcs Bye IFNE 0 * Determine if the size of the file is 4608 bytes * Note, this assumes 18 sectors per track and 256 * bytes per sector. ldb #SS.Size os9 I$GetStt get size tfr u,y put lower 16 bytes of file size in Y ldu <statptr lbcs Bye branch if error cmpx #$0000 correct size? bne BadBTrak branch if not cmpy #$1200 correct size? beq ReadBTrk branch if not BadBTrak leax BadTkMsg,pcr ldy #BadTkMsgL lda #$02 os9 I$WritLn lbra Bye ELSE ldy #$1200 ENDC * Read in boot track file * Y = proper boottrack size ReadBTrk leax u0496,u point to sector buffer os9 I$Read read sector buffer lbcs Bye os9 I$Close close path to boot track lbsr GetDest ldd #Bt.Track*256 boot track lbsr Seek2LSN bra WrBTrack BTMem IFGT Level-1 * OS-9 Level Two: Link to Rel, which brings in boot code pshs u lda #Systm+Objct leax >TheRel,pcr os9 F$Link lbcs L0724 tfr u,d puls u subd #$0006 std <u007B,u lda #$E0 anda <u007B,u ora #$1E ldb #$FF subd <u007B,u addd #$0001 tfr d,y ldd #Bt.Track*256 boot track lbsr Seek2LSN ldx <u007B,u ELSE * OS-9 Level One: Write out boot track data ldd #Bt.Track*256 lbsr Seek2LSN ldx #Bt.Start ldy #Bt.Size ENDC WrBTrack lda <devpath os9 I$Write lbcs WriteErr os9 I$Close lbcs Bye clrb lbra Bye * Convert Track/Sector to absolute LSN * Entry: A = track, B = sector * Returns in D AbsLSN pshs b ldb <lsn0+DD.FMT,u get format byte andb #FMT.SIDE test sides bit beq AbsLSN1 branch if 1 ldb #$02 else 2 sides fcb $8C skip next two bytes * bra AbsLSN2 AbsLSN1 ldb #$01 1 side AbsLSN2 mul multiply sides times track lda <lsn0+DD.TKS,u get device tracks mul multiply by (sides * track) addb ,s+ add in sector * addb ,s add in sector adca #$00 * leas $01,s rts * Bitmap conversion from bit to byte * Entry: X = pointer to bitmap * D = bit * Exit: A = bit mask * X = pointer to byte represented by bit D L05AA pshs y,b lsra divide D by 8 rorb lsra rorb lsra rorb leax d,x puls b leay <BitMask,pcr andb #$07 lda b,y puls pc,y BitMask fcb $80,$40,$20,$10,$08,$04,$02,$01 * Clear bits in the allocation bitmap * Entry: A = Track, B = Sector, Y = number of bits to clear ABMClear pshs x,y,b,a bsr AbsLSN convert A:B to LSN leax sectbuff,u bsr L05AA sta ,-s bmi L05EA L05D3 lda ,x get byte in bitmap sta u007D,u L05D9 anda ,s and with byte on stack bne L0616 leay -1,y beq L0612 lda u007D,u lsr ,s bcc L05D9 leax $01,x L05EA lda #$FF sta ,s bra L05FA L05F0 lda ,x anda ,s bne L0616 leax $01,x leay -$08,y L05FA cmpy #$0008 bhi L05F0 beq L060C lda ,s L0604 lsra leay -$01,y bne L0604 coma sta ,s L060C lda ,x anda ,s bne L0616 L0612 andcc #^Carry bra L0618 L0616 orcc #Carry L0618 leas $01,s puls pc,y,x,b,a * Set bits in the allocation bitmap * Entry: A = Track, B = Sector, Y = number of bits to set ABMSet pshs y,x,b,a lbsr AbsLSN leax sectbuff,u bsr L05AA sta ,-s bmi L063A lda ,x L062C ora ,s leay -$01,y beq L0658 lsr ,s bcc L062C sta ,x leax $01,x L063A lda #$FF bra L0644 L063E sta ,x leax $01,x leay -$08,y L0644 cmpy #$0008 bhi L063E beq L0658 L064C lsra leay -$01,y bne L064C coma sta ,s lda ,x ora ,s L0658 sta ,x leas $01,s puls pc,y,x,b,a Seek2LSN pshs u,y,x,b,a lbsr AbsLSN pshs a tfr b,a clrb tfr d,u puls b clra tfr d,x lda <devpath os9 I$Seek lbcs WriteErr puls pc,u,y,x,b,a clra clrb tfr d,x tfr d,u lda <devpath os9 I$Seek leax <lsn0,u ldy #DD.DAT lda <devpath os9 I$Write bcs Bye rts * Routine to write various error messages then exiting WriteErr leax >ErrWrit,pcr bra WritExit BadName ldb #E$BPNam ShowHelp equ * IFNE DOHELP leax >HelpMsg,pcr ELSE clrb bra Bye ENDC WritExit pshs b lda #$02 ldy #256 os9 I$WritLn puls b Bye os9 F$Exit * Source/Destination Disk Switch Routine GetSrc pshs u,y,x,b,a clra bra TstSingl GetDest pshs u,y,x,b,a lda #$01 TstSingl tst <sngldrv beq L06FD AskUser pshs a AskUser2 tsta bne Ask4Dst Ask4Src leax >Source,pcr ldy #SourceL bra L06D4 Ask4Dst leax >Destin,pcr ldy #DestinL L06D4 bsr DoWrite leax ,-s ldy #$0001 lda #$02 read from stderr os9 I$Read read one char lda ,s+ eora #'C anda #$DF beq L06F9 branch if it's a C leax >TheBell,pcr ldy #$0001 bsr DoWrite else ring the error bell bsr WriteCR * BUG FIX: in certain cases, puls a was being done twice. lda ,s ++ * puls a -- bra AskUser2 ++ * bne AskUser -- L06F9 bsr WriteCR puls a L06FD puls pc,u,y,x,b,a DoWrite lda #$01 os9 I$WritLn rts WriteCR pshs y,x,a lda #$01 leax >CarRet,pcr ldy #80 os9 I$WritLn puls pc,y,x,a ItsFragd leax >BootFrag,pcr SoftExit ldb #$01 bra WritExit WarnUser leax >TWarn,pcr bra SoftExit IFGT Level-1 L0724 leax >CantRel,pcr lbra WritExit ENDC emod eom equ * end