2017-12-22 21:24:30 +00:00
|
|
|
|
NEW
|
2019-04-19 05:42:43 +00:00
|
|
|
|
AUTO 3,1
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
* # ChMod
|
|
|
|
|
* change permissions of a file
|
|
|
|
|
* ## C
|
|
|
|
|
* `int chmod(const char *pathname, int mode);`
|
|
|
|
|
* ## ASM
|
2019-01-30 06:20:13 +00:00
|
|
|
|
* **In:**
|
2019-04-19 05:42:43 +00:00
|
|
|
|
* `>PUSHW mode`
|
|
|
|
|
* `>LDYA pathname`
|
|
|
|
|
* `>SYSCALL chmod`
|
2019-01-30 06:20:13 +00:00
|
|
|
|
* ## RETURN VALUE
|
2019-04-19 05:42:43 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
* only 777-555
|
|
|
|
|
*--------------------------------------
|
|
|
|
|
K.ChMod jsr PFT.CheckPathYA
|
2019-07-25 15:10:59 +00:00
|
|
|
|
bcs K.FStat.9
|
2019-01-30 06:20:13 +00:00
|
|
|
|
|
2019-04-19 05:42:43 +00:00
|
|
|
|
>PULLW K.S.STAT+S.STAT.MODE
|
|
|
|
|
lda K.S.STAT+S.STAT.MODE+1
|
|
|
|
|
and /S.STAT.MODE.RU
|
|
|
|
|
beq .9
|
|
|
|
|
lda K.S.STAT+S.STAT.MODE
|
|
|
|
|
and #S.STAT.MODE.XO+S.STAT.MODE.RO+S.STAT.MODE.XG+S.STAT.MODE.RG+S.STAT.MODE.XU+S.STAT.MODE.RU
|
|
|
|
|
cmp #S.STAT.MODE.XO+S.STAT.MODE.RO+S.STAT.MODE.XG+S.STAT.MODE.RG+S.STAT.MODE.XU+S.STAT.MODE.RU
|
|
|
|
|
bne .9
|
|
|
|
|
>MLICALL MLIGETFILEINFO
|
|
|
|
|
bcs .90
|
|
|
|
|
lda K.MLI.PARAMS+S.FI.A
|
|
|
|
|
and #$3D not S.FI.A.RN+S.FI.A.D+S.FI.A.W
|
|
|
|
|
ora #S.FI.A.R
|
|
|
|
|
tax
|
|
|
|
|
lda K.S.STAT+S.STAT.MODE
|
|
|
|
|
tay
|
|
|
|
|
bit #S.STAT.MODE.WG
|
|
|
|
|
beq .1
|
|
|
|
|
|
|
|
|
|
txa
|
|
|
|
|
ora #S.FI.A.RN
|
|
|
|
|
tax
|
|
|
|
|
tya
|
|
|
|
|
.1 bit #S.STAT.MODE.WU
|
|
|
|
|
beq .2
|
|
|
|
|
txa
|
|
|
|
|
ora #S.FI.A.D
|
|
|
|
|
tax
|
|
|
|
|
tya
|
|
|
|
|
.2 bit #S.STAT.MODE.WO
|
|
|
|
|
beq .3
|
|
|
|
|
txa
|
|
|
|
|
ora #S.FI.A.W
|
|
|
|
|
tax
|
|
|
|
|
.3 stx K.MLI.PARAMS+S.FI.A
|
2019-01-30 06:20:13 +00:00
|
|
|
|
|
2019-04-19 05:42:43 +00:00
|
|
|
|
>MLICALL MLISETFILEINFO
|
2019-01-30 06:20:13 +00:00
|
|
|
|
rts
|
2019-04-19 05:42:43 +00:00
|
|
|
|
.9 lda #E.SYN
|
|
|
|
|
sec
|
|
|
|
|
.90 rts
|
2019-07-25 15:10:59 +00:00
|
|
|
|
K.FStat.9 >RET 2 discard statbuf
|
2017-10-09 15:30:48 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
* # FStat
|
2018-10-04 15:30:14 +00:00
|
|
|
|
* Return information about a hFILE
|
2018-08-08 15:13:37 +00:00
|
|
|
|
* ## C
|
|
|
|
|
* `int fstat(short int hFILE, struct stat *statbuf);`
|
2018-07-20 11:51:08 +00:00
|
|
|
|
* ## ASM
|
2018-06-18 08:44:02 +00:00
|
|
|
|
* **In:**
|
2018-08-08 15:13:37 +00:00
|
|
|
|
* `>PUSHW statbuf`
|
|
|
|
|
* `lda hFILE`
|
|
|
|
|
* `>SYSCALL fstat`
|
2018-10-11 15:23:06 +00:00
|
|
|
|
* ## RETURN VALUE
|
2017-10-09 15:30:48 +00:00
|
|
|
|
*--------------------------------------
|
2018-08-08 15:13:37 +00:00
|
|
|
|
K.FStat jsr PFT.CheckNodeA
|
2018-11-16 16:04:20 +00:00
|
|
|
|
bcs K.FStat.9
|
|
|
|
|
tax
|
2019-02-27 15:00:56 +00:00
|
|
|
|
lda OF.Table.hPath-1,x
|
2018-10-04 15:30:14 +00:00
|
|
|
|
jsr K.GetMemPtr
|
2018-11-16 16:04:20 +00:00
|
|
|
|
jsr PFT.YAToMLIPATH
|
|
|
|
|
jsr K.Stat.I
|
2018-11-07 16:11:02 +00:00
|
|
|
|
bcs K.Stat.9
|
2018-11-16 16:04:20 +00:00
|
|
|
|
lda (pFD) #S.FD.T
|
|
|
|
|
bne K.Stat.BLK2SIZE
|
|
|
|
|
ldy #S.FD.REG.REF
|
|
|
|
|
lda (pFD),y
|
|
|
|
|
sta K.MLI.PARAMS+1
|
|
|
|
|
|
2018-11-07 16:11:02 +00:00
|
|
|
|
>MLICALL MLIGETEOF
|
|
|
|
|
bcs K.Stat.BLK2SIZE
|
|
|
|
|
ldy #S.STAT.SIZE+3
|
|
|
|
|
lda #0
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
ldx #2
|
|
|
|
|
.1 lda K.MLI.PARAMS+2,x
|
|
|
|
|
dey
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
dex
|
|
|
|
|
bpl .1
|
|
|
|
|
* clc
|
|
|
|
|
rts
|
2017-08-24 12:46:48 +00:00
|
|
|
|
*/--------------------------------------
|
|
|
|
|
* # Stat
|
|
|
|
|
* Return information about a file
|
2018-07-20 11:51:08 +00:00
|
|
|
|
* ## C
|
|
|
|
|
* `int stat(const char *pathname, struct stat *statbuf);`
|
|
|
|
|
* ## ASM
|
2018-06-18 08:44:02 +00:00
|
|
|
|
* **In:**
|
2018-07-20 11:51:08 +00:00
|
|
|
|
* `>PUSHW statbuf`
|
|
|
|
|
* `>LDYA pathname`
|
|
|
|
|
* `>SYSCALL stat`
|
2018-10-11 15:23:06 +00:00
|
|
|
|
* ## RETURN VALUE
|
2017-08-24 12:46:48 +00:00
|
|
|
|
*\--------------------------------------
|
2018-07-20 11:51:08 +00:00
|
|
|
|
K.Stat jsr PFT.CheckPathYA
|
2018-11-16 16:04:20 +00:00
|
|
|
|
bcs K.FStat.9 go discard statbuf
|
2018-11-07 16:11:02 +00:00
|
|
|
|
jsr K.Stat.I
|
|
|
|
|
bcs K.Stat.9
|
2019-10-03 06:25:27 +00:00
|
|
|
|
K.Stat.BLK2SIZE ldy #S.STAT.SIZE
|
2018-11-07 16:11:02 +00:00
|
|
|
|
lda #0
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
iny
|
|
|
|
|
lda K.MLI.PARAMS+S.FI.UBLKS
|
|
|
|
|
asl
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
iny
|
|
|
|
|
lda K.MLI.PARAMS+S.FI.UBLKS+1
|
|
|
|
|
rol
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
iny
|
|
|
|
|
lda #0
|
|
|
|
|
rol
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
* clc
|
|
|
|
|
K.Stat.9 rts
|
|
|
|
|
|
2018-11-16 16:04:20 +00:00
|
|
|
|
K.Stat.I >PULLW ZPPtr1 Get StatBuf
|
2017-08-24 12:46:48 +00:00
|
|
|
|
>MLICALL MLIGETFILEINFO
|
|
|
|
|
bcs .9
|
|
|
|
|
|
2019-04-15 05:40:13 +00:00
|
|
|
|
lda K.MLI.PARAMS+S.FI.A
|
|
|
|
|
jsr STAT.Access2Mode
|
|
|
|
|
.2 phy
|
2019-04-19 05:42:43 +00:00
|
|
|
|
ldy #S.STAT.MODE
|
2018-09-06 15:36:44 +00:00
|
|
|
|
sta (ZPPtr1),y
|
2019-04-19 05:42:43 +00:00
|
|
|
|
iny
|
2019-04-15 05:40:13 +00:00
|
|
|
|
pla
|
|
|
|
|
sta (ZPPtr1),y
|
2017-08-24 12:46:48 +00:00
|
|
|
|
ldx #K.Stat.DST-K.Stat.SRC
|
|
|
|
|
|
|
|
|
|
.3 ldy K.Stat.SRC-1,x
|
|
|
|
|
lda K.MLI.PARAMS,y
|
|
|
|
|
ldy K.Stat.DST-1,x
|
2018-09-06 15:36:44 +00:00
|
|
|
|
sta (ZPPtr1),y
|
2017-08-24 12:46:48 +00:00
|
|
|
|
dex
|
|
|
|
|
bne .3
|
|
|
|
|
clc
|
|
|
|
|
.9 rts
|
|
|
|
|
*--------------------------------------
|
2017-10-27 14:56:46 +00:00
|
|
|
|
K.Stat.SRC .DA #S.FI.T
|
|
|
|
|
.DA #S.FI.AUXTYPE,#S.FI.AUXTYPE+1
|
|
|
|
|
.DA #S.FI.UBLKS,#S.FI.UBLKS+1
|
2017-08-24 12:46:48 +00:00
|
|
|
|
K.Stat.DST .DA #S.STAT.P.TYPE
|
|
|
|
|
.DA #S.STAT.P.AUXTYPE,#S.STAT.P.AUXTYPE+1
|
|
|
|
|
.DA #S.STAT.BLOCKS,#S.STAT.BLOCKS+1
|
2019-04-15 05:40:13 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
STAT.Access2Mode
|
|
|
|
|
and #S.FI.A.FULL
|
|
|
|
|
cmp #S.FI.A.FULL
|
2019-04-19 05:42:43 +00:00
|
|
|
|
beq .7
|
|
|
|
|
tay
|
|
|
|
|
ldx #S.STAT.MODE.RO+S.STAT.MODE.RG+S.STAT.MODE.RU+S.STAT.MODE.XO+S.STAT.MODE.XG+S.STAT.MODE.XU
|
|
|
|
|
|
|
|
|
|
bit #S.FI.A.W
|
|
|
|
|
beq .1
|
|
|
|
|
txa
|
|
|
|
|
ora #S.STAT.MODE.WO
|
|
|
|
|
tax
|
|
|
|
|
tya
|
|
|
|
|
|
|
|
|
|
.1 asl D in C
|
|
|
|
|
|
|
|
|
|
bpl .2 RN in N
|
|
|
|
|
txa
|
|
|
|
|
ora #S.STAT.MODE.WG
|
|
|
|
|
tax
|
|
|
|
|
.2 txa
|
|
|
|
|
bcc .8
|
|
|
|
|
ora #S.STAT.MODE.WU
|
|
|
|
|
.HS 2C BIT ABS
|
|
|
|
|
.7 lda #S.STAT.MODE.FO+S.STAT.MODE.FG+S.STAT.MODE.FU rwxrwxrwx
|
|
|
|
|
.8 ldy /S.STAT.MODE.RU ??????R??
|
2019-04-15 05:40:13 +00:00
|
|
|
|
|
2019-06-03 15:50:41 +00:00
|
|
|
|
STAT.Access2Mode.RTS
|
2019-04-15 05:40:13 +00:00
|
|
|
|
rts
|
2017-08-24 15:29:22 +00:00
|
|
|
|
*/-------------------------------------
|
2018-06-21 15:12:10 +00:00
|
|
|
|
* # MKDir
|
2018-09-20 15:33:05 +00:00
|
|
|
|
* create a directory
|
|
|
|
|
* ## C
|
|
|
|
|
* `int mkdir(const char *pathname, int mode);`
|
|
|
|
|
* ## ASM
|
2018-06-14 15:31:36 +00:00
|
|
|
|
* **In:**
|
2018-09-20 15:33:05 +00:00
|
|
|
|
* `>PUSHW mode`
|
|
|
|
|
* `>LDYA pathname`
|
|
|
|
|
* `>SYSCALL mkdir`
|
2018-10-11 15:23:06 +00:00
|
|
|
|
* ## RETURN VALUE
|
2018-09-20 15:33:05 +00:00
|
|
|
|
* CC : success
|
|
|
|
|
* CS : error
|
|
|
|
|
* A = EC
|
2017-08-24 15:29:22 +00:00
|
|
|
|
*\-------------------------------------
|
2018-11-16 16:04:20 +00:00
|
|
|
|
K.MKDir jsr PFT.CheckPathYA
|
2019-06-03 15:50:41 +00:00
|
|
|
|
bcs STAT.Access2Mode.RTS
|
2017-10-27 14:56:46 +00:00
|
|
|
|
lda #S.FI.T.DIR
|
2018-12-19 16:45:09 +00:00
|
|
|
|
sta K.MLI.PARAMS+4
|
|
|
|
|
stz K.MLI.PARAMS+5
|
|
|
|
|
stz K.MLI.PARAMS+6
|
2017-10-27 14:56:46 +00:00
|
|
|
|
lda #S.FI.ST.DIR
|
2018-12-19 16:45:09 +00:00
|
|
|
|
jmp IO.MLI.CREATE
|
2017-08-24 15:29:22 +00:00
|
|
|
|
*/--------------------------------------
|
2019-06-03 15:50:41 +00:00
|
|
|
|
* # MKFIFO
|
|
|
|
|
* return a pathname to a new FIFO
|
|
|
|
|
* ## C
|
|
|
|
|
* `int mkfifo( char *pathname, int mode );`
|
|
|
|
|
* ## ASM
|
|
|
|
|
* **In:**
|
|
|
|
|
* `>PUSHW mode`
|
|
|
|
|
* `>LDYA pathname`
|
|
|
|
|
* `>SYSCALL mkfifo`
|
|
|
|
|
* ## RETURN VALUE
|
|
|
|
|
* CC = OK, CS = ERROR
|
|
|
|
|
* A = hFD
|
|
|
|
|
*\--------------------------------------
|
|
|
|
|
K.MKFIFO >STYA ZPPtr1 pathname buffer
|
|
|
|
|
>PULLW K.S.STAT+S.STAT.MODE
|
|
|
|
|
>LDYAI 512
|
|
|
|
|
jsr K.pipe
|
|
|
|
|
bcs STAT.Access2Mode.RTS
|
|
|
|
|
|
2019-07-12 06:22:32 +00:00
|
|
|
|
ldy #0
|
2019-07-29 15:38:55 +00:00
|
|
|
|
.1 lda IO.DEV.FIFO,y
|
2019-06-04 15:49:58 +00:00
|
|
|
|
sta (ZPPtr1),y
|
2019-07-12 06:22:32 +00:00
|
|
|
|
iny
|
|
|
|
|
cpy #9
|
|
|
|
|
bne .1
|
2019-06-04 15:49:58 +00:00
|
|
|
|
|
2019-07-12 14:51:57 +00:00
|
|
|
|
lda IO.hFD
|
2019-07-12 06:22:32 +00:00
|
|
|
|
jsr MATH.AToHexAX
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
txa
|
|
|
|
|
iny
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
iny
|
|
|
|
|
lda #0
|
|
|
|
|
sta (ZPPtr1),y
|
|
|
|
|
bra K.MkNod.I
|
2019-06-03 15:50:41 +00:00
|
|
|
|
*/--------------------------------------
|
2018-06-21 15:12:10 +00:00
|
|
|
|
* # MkNod
|
2018-10-02 15:52:30 +00:00
|
|
|
|
* Create a special or ordinary file.
|
2018-09-20 15:33:05 +00:00
|
|
|
|
* (CDEV, BDEV, DSOCKS, SSOCK, PIPE)
|
|
|
|
|
* ## C
|
2018-10-03 15:25:03 +00:00
|
|
|
|
* `hFILE mknod(const char *pathname, int mode, hFD fd);`
|
2018-09-20 15:33:05 +00:00
|
|
|
|
* ## ASM
|
2018-06-14 15:31:36 +00:00
|
|
|
|
* **In:**
|
2018-09-20 15:33:05 +00:00
|
|
|
|
* `>PUSHB fd`
|
|
|
|
|
* `>PUSHW mode`
|
|
|
|
|
* `>LDYA pathname`
|
|
|
|
|
* `>SYSCALL mknod`
|
2018-10-11 15:23:06 +00:00
|
|
|
|
* ## RETURN VALUE
|
2018-09-20 15:33:05 +00:00
|
|
|
|
* CC = OK, CS = ERROR
|
|
|
|
|
* A = hFILE
|
2017-08-24 15:29:22 +00:00
|
|
|
|
*\--------------------------------------
|
2018-09-20 15:33:05 +00:00
|
|
|
|
K.MkNod >STYA ZPPtr1 pathname
|
|
|
|
|
>PULLW K.S.STAT+S.STAT.MODE
|
2019-07-12 14:51:57 +00:00
|
|
|
|
>PULLB IO.hFD
|
2019-02-04 16:37:15 +00:00
|
|
|
|
|
2019-02-27 15:00:56 +00:00
|
|
|
|
K.MkNod.I ldx #2
|
|
|
|
|
.1 lda Nod.Table.hPath-2,x
|
2019-02-04 16:37:15 +00:00
|
|
|
|
beq .2
|
|
|
|
|
inx
|
2019-02-27 15:00:56 +00:00
|
|
|
|
cpx #K.Nod.MAX+2
|
2019-02-04 16:37:15 +00:00
|
|
|
|
bne .1
|
|
|
|
|
lda #E.OOH
|
2019-10-03 06:25:27 +00:00
|
|
|
|
* sec
|
2019-02-04 16:37:15 +00:00
|
|
|
|
rts
|
|
|
|
|
.2 stx .3+1 Store hFILE
|
2018-10-03 05:52:08 +00:00
|
|
|
|
>LDYA ZPPtr1
|
2019-05-04 21:13:50 +00:00
|
|
|
|
ldx #SYS.StrDup
|
2019-08-05 13:30:58 +00:00
|
|
|
|
jsr K.SYSCALL2
|
2019-02-04 16:37:15 +00:00
|
|
|
|
bcs .9
|
|
|
|
|
txa
|
|
|
|
|
.3 ldx #$ff SELF MODIFIED
|
2019-02-27 15:00:56 +00:00
|
|
|
|
sta Nod.Table.hPath-2,x
|
2019-07-12 14:51:57 +00:00
|
|
|
|
lda IO.hFD
|
2019-02-27 15:00:56 +00:00
|
|
|
|
sta Nod.Table.hFD-2,x
|
2019-02-04 16:37:15 +00:00
|
|
|
|
txa hNODE
|
2018-10-03 05:52:08 +00:00
|
|
|
|
clc
|
2019-02-04 16:37:15 +00:00
|
|
|
|
.9 rts
|
2017-08-24 15:29:22 +00:00
|
|
|
|
*/--------------------------------------
|
2019-02-04 16:37:15 +00:00
|
|
|
|
* # pipe
|
|
|
|
|
* ## C
|
2019-05-02 15:59:11 +00:00
|
|
|
|
* `hFD pipe(int size);`
|
2019-02-04 16:37:15 +00:00
|
|
|
|
* ## ASM
|
2019-05-02 15:59:11 +00:00
|
|
|
|
* `>LDYA size`
|
2019-02-04 16:37:15 +00:00
|
|
|
|
* `>SYSCALL pipe`
|
|
|
|
|
* ## RETURN VALUE
|
|
|
|
|
* CC = OK, CS = ERROR
|
|
|
|
|
* A = hFD
|
|
|
|
|
*\--------------------------------------
|
2019-06-03 15:50:41 +00:00
|
|
|
|
K.Pipe sta .1+1 SIZE HI
|
|
|
|
|
|
2019-05-23 15:38:32 +00:00
|
|
|
|
.DO AUXPIPE=1
|
2019-06-19 15:56:59 +00:00
|
|
|
|
ldx #SYS.NewStkObj
|
|
|
|
|
jsr K.SYSCALL2.AUX Buffer in AUX mem
|
2019-05-23 15:38:32 +00:00
|
|
|
|
.ELSE
|
2019-05-03 13:08:12 +00:00
|
|
|
|
jsr K.GetMem
|
2019-05-23 15:38:32 +00:00
|
|
|
|
.FIN
|
2017-08-24 15:29:22 +00:00
|
|
|
|
bcs .99
|
2019-06-03 15:50:41 +00:00
|
|
|
|
stx .8+1 save PIPE buffer
|
2019-07-12 14:51:57 +00:00
|
|
|
|
ldx #2
|
|
|
|
|
jsr IO.MkFD
|
2017-08-24 15:29:22 +00:00
|
|
|
|
bcs .9
|
2019-06-03 15:50:41 +00:00
|
|
|
|
.1 lda #$ff SELF MODIFIED
|
|
|
|
|
ldy #S.FD.PIPE.Free+1
|
2019-05-02 15:59:11 +00:00
|
|
|
|
sta (pFD),y
|
|
|
|
|
|
2019-06-03 15:50:41 +00:00
|
|
|
|
ldy #S.FD.PIPE.Size+1
|
2019-02-21 22:03:08 +00:00
|
|
|
|
sta (pFD),y
|
2019-02-26 16:50:42 +00:00
|
|
|
|
ldy #S.FD.PIPE.hMem
|
2019-06-03 15:50:41 +00:00
|
|
|
|
.8 lda #$ff Self Modified
|
2018-08-08 15:13:37 +00:00
|
|
|
|
sta (pFD),y
|
2019-05-03 13:08:12 +00:00
|
|
|
|
txa hFD
|
2019-02-15 16:38:17 +00:00
|
|
|
|
* clc
|
2017-08-24 15:29:22 +00:00
|
|
|
|
rts
|
|
|
|
|
.9 pha save error code
|
2019-06-03 15:50:41 +00:00
|
|
|
|
lda .8+1 get back PIPE buffer
|
2019-05-23 15:38:32 +00:00
|
|
|
|
.DO AUXPIPE=1
|
2019-06-19 15:56:59 +00:00
|
|
|
|
ldx #SYS.FreeStkObj
|
|
|
|
|
jsr K.SYSCALL2.AUX
|
2019-05-23 15:38:32 +00:00
|
|
|
|
.ELSE
|
2018-06-22 06:24:35 +00:00
|
|
|
|
jsr K.FreeMem
|
2019-05-24 06:09:19 +00:00
|
|
|
|
.FIN
|
2017-08-24 15:29:22 +00:00
|
|
|
|
pla
|
|
|
|
|
sec
|
2019-10-03 06:25:27 +00:00
|
|
|
|
.99 rts
|
2017-08-24 12:46:48 +00:00
|
|
|
|
*--------------------------------------
|
|
|
|
|
MAN
|
2018-11-17 17:17:13 +00:00
|
|
|
|
SAVE USR/SRC/SYS/KERNEL.S.STAT
|
|
|
|
|
LOAD USR/SRC/SYS/KERNEL.S
|
2017-08-24 12:46:48 +00:00
|
|
|
|
ASM
|