Mercurial > hg > Members > kono > nitros9-code
view 3rdparty/p2mods/datmod.asm @ 3226:9749d0dfc4a2
Changed a puls PC to rts to save cycles
author | David Ladd <drencor-xeen@users.sourceforge.net> |
---|---|
date | Sat, 20 Jan 2018 19:32:22 -0600 |
parents | 020929a44372 |
children |
line wrap: on
line source
* F$DatMod * * Entry: * A = Type/Language * B = Attr/Rev * X = address of name * Y = size * * Exit: * X = address of last byte of name + 1 * Y = module entry point address * U = module header address Level equ 1 ifp1 use defsfile endc Type set Prgrm+Objct Revs set ReEnt+1 edition set $01 mod eom,name,Type,Revs,start,256 name fcs "DatMod" fcb $01 * routine cold start clra leax name,pcr os9 F$Link bcs error leay SvcTbl,pcr os9 F$SSvc clrb error os9 F$Exit F$DatMod equ $25 SvcTbl equ * fcb F$DatMod fdb DatMod-*-2 fcb $80 s.namlen equ 0 s.nextnm equ 2 s.modptr equ 6 s.size equ 8 DatMod leas -s.size,s * First, parse the name ldx R$X,u get the name of the module os9 F$PrsNam parse it: TODO /x/x crashes machine! lbcs DatModEr sty s.nextnm,s save updated name pointer tfr y,d get ptr to last char + 1 into D subd R$X,u get length of name in D std s.namlen,s save name length for later addd R$Y,u add name length to caller's specified size addd #M$IDSize+3 add module header size and CRC pshs u os9 F$SRqMem ask system for this memory stu s.modptr+2,s else save pointer to module puls u lbcs DatModEr branch if error ldy s.modptr,s get module pointer into Y * We have the memory for the Data Module, now populate it std M$Size,y save size in module ldd #M$ID12 get module ID bytes std M$ID,y save in module ldd R$D,u get passed type/lang and attr/rev bita #TypeMask is type zero? bne StoreIt branch if not... anda #Data else force type to be data StoreIt std M$Type,y and save in module ldd M$Size,y get module ptr's size subd s.namlen,s subtract name's length from size subd #3 and CRC std M$Name,y and save pointer to it in module header * Compute header parity pshs d save D (holds offset to name from within module) ldd #M$IDSize-1 pshs b clrb EorLoop eora b,y incb cmpb ,s bne EorLoop puls b coma sta M$Parity,y save parity byte * Copy name from caller's X to data module ldx R$X,u point to caller's passed name puls d get name ptr in module into D addd s.modptr,s add absolute address of module tfr d,y and put in Y ldb s.namlen+1,s get length of name CpyLoop lda ,x+ get char sta ,y+ put char decb decrement counter bne CpyLoop ora #$80 set high bit of last character we got sta -1,y and put it back in module * Initialize CRC with constant $FFFFFF ldd #$FFFF get CRC initializer std ,y and store sta 2,y * Compute CRC and validate Module pshs u tfr y,u U now holds pointer to CRC ldx s.modptr+2,s get pointer to module ldy M$Size,x get module size leay -3,y subtract CRC length os9 F$CRC update CRC ldd ,u get 1st two bytes of CRC coma complement them comb std ,u save them back lda 2,u get third byte of CRC coma complement them sta 2,u save it back os9 F$VModul and validate module puls u bcc DatModOk branch if all ok pshs cc,b preserve error info ldd M$Size,s get module size alloced from stack tfr x,u put module ptr from X to U os9 F$SRtMem return memory puls b,cc get error info bra DatModEr and exit * Put return info in caller's regs DatModOk ldx s.nextnm,s get pointer to char after name stx R$X,u save it in caller's X ldx s.modptr,s get module pointer stx R$U,u save it in caller's U leax M$IDSize,x get entry point stx R$Y,u save it in caller's Y DatModEr leas s.size,s rts emod eom equ * end