A2osX/SYS/KERNEL.S.STAT.txt

371 lines
7.5 KiB
Plaintext
Raw Normal View History

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-12-02 07:09:58 +00:00
bcs K.ChMod.RET2
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-12-02 07:09:58 +00:00
K.ChMod.RET2 >RET 2 discard statbuf
*--------------------------------------
* # 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
*--------------------------------------
2018-08-08 15:13:37 +00:00
K.FStat jsr PFT.CheckNodeA
2019-12-02 07:09:58 +00:00
bcs K.ChMod.RET2
2018-11-16 16:04:20 +00:00
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
2019-12-02 07:09:58 +00:00
>PULLW K.Stat.Store.2+1
jsr SHARED.Stat.I
bcs K.Stat.Store.RTS
2018-11-16 16:04:20 +00:00
lda (pFD) #S.FD.T
2019-12-02 07:09:58 +00:00
bne K.Stat.Store
2018-11-16 16:04:20 +00:00
ldy #S.FD.REG.REF
lda (pFD),y
sta K.MLI.PARAMS+1
2018-11-07 16:11:02 +00:00
>MLICALL MLIGETEOF
2019-12-02 07:09:58 +00:00
bcs K.Stat.Store.RTS
2018-11-07 16:11:02 +00:00
ldx #2
2019-12-02 07:09:58 +00:00
2018-11-07 16:11:02 +00:00
.1 lda K.MLI.PARAMS+2,x
2019-12-02 07:09:58 +00:00
sta K.S.STAT+S.STAT.SIZE,x
2018-11-07 16:11:02 +00:00
dex
bpl .1
2019-12-02 07:09:58 +00:00
K.Stat.Store ldy #S.STAT-1
K.Stat.Store.1 lda K.S.STAT,y
K.Stat.Store.2 sta $ffff,y SELF MODIFIED
dey
bpl K.Stat.Store.1
2018-11-07 16:11:02 +00:00
* clc
2019-12-02 07:09:58 +00:00
K.Stat.Store.RTS
2018-11-07 16:11:02 +00:00
rts
*/--------------------------------------
* # 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
*\--------------------------------------
2018-07-20 11:51:08 +00:00
K.Stat jsr PFT.CheckPathYA
2019-12-02 07:09:58 +00:00
bcs K.ChMod.RET2 go discard statbuf
2019-04-19 05:42:43 +00:00
2019-12-02 07:09:58 +00:00
>PULLW K.Stat.Store.2+1
2019-04-19 05:42:43 +00:00
2019-12-02 07:09:58 +00:00
jsr SHARED.Stat.I
bcc K.Stat.Store
2019-04-19 05:42:43 +00:00
2019-04-15 05:40:13 +00:00
rts
*/-------------------------------------
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
*\-------------------------------------
2018-11-16 16:04:20 +00:00
K.MKDir jsr PFT.CheckPathYA
2019-12-02 07:09:58 +00:00
bcs K.Stat.Store.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
*/--------------------------------------
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
2019-12-02 07:09:58 +00:00
bcs K.Stat.Store.RTS
2019-06-03 15:50:41 +00:00
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
*\--------------------------------------
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
*/--------------------------------------
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
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
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
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
pla
sec
2019-12-02 16:47:53 +00:00
.99
K.Pipe.RTS rts
*--------------------------------------
SHARED.Stat.I jsr SHARED.ClrStat
>MLICALL MLIGETFILEINFO
bcs K.Pipe.RTS
lda K.MLI.PARAMS+S.FI.A
jsr SHARED.Stat.Access2Mode
ldx #SHARED.Stat.DST-SHARED.Stat.SRC
.3 ldy SHARED.Stat.SRC-1,x
lda K.MLI.PARAMS,y
ldy SHARED.Stat.DST-1,x
sta K.S.STAT,y
dex
bne .3
2020-01-18 19:37:32 +00:00
>PUSHWI K.MLI.PARAMS+S.FI.CDATE
2019-12-04 06:56:03 +00:00
>PUSHWI K.S.STAT+S.STAT.CTIME
>SYSCALL2 PTime2Time BANK2
2019-12-02 16:47:53 +00:00
2020-01-18 19:37:32 +00:00
>PUSHWI K.MLI.PARAMS+S.FI.MDATE
2019-12-04 06:56:03 +00:00
>PUSHWI K.S.STAT+S.STAT.MTIME
>SYSCALL2 PTime2Time BANK2
2019-12-02 16:47:53 +00:00
clc
rts
*--------------------------------------
SHARED.DirEnt2Stat
2019-12-04 06:56:03 +00:00
* clc
* rts
2019-12-02 16:47:53 +00:00
*--------------------------------------
SHARED.ClrStat ldx #S.STAT-1
.1 stz K.S.STAT,x
dex
bpl .1
rts
*--------------------------------------
SHARED.Stat.Access2Mode
and #S.FI.A.FULL
cmp #S.FI.A.FULL
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 sta K.S.STAT+S.STAT.MODE
lda /S.STAT.MODE.RU ??????R??
ora K.S.STAT+S.STAT.MODE+1 preserve DIR
sta K.S.STAT+S.STAT.MODE+1
rts
*--------------------------------------
SHARED.Stat.SRC .DA #S.FI.T
.DA #S.FI.AUXTYPE,#S.FI.AUXTYPE+1
.DA #S.FI.UBLKS,#S.FI.UBLKS+1
SHARED.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
*--------------------------------------
MAN
2018-11-17 17:17:13 +00:00
SAVE USR/SRC/SYS/KERNEL.S.STAT
LOAD USR/SRC/SYS/KERNEL.S
ASM