A2osX/SYS/KERNEL.S.STAT.txt

371 lines
7.5 KiB
Plaintext
Raw Normal View History

2017-12-22 22:24:30 +01:00
NEW
2019-04-19 06:42:43 +01: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 06:42:43 +01:00
* `>PUSHW mode`
* `>LDYA pathname`
* `>SYSCALL chmod`
2019-01-30 06:20:13 +00:00
* ## RETURN VALUE
2019-04-19 06:42:43 +01:00
*--------------------------------------
* only 777-555
*--------------------------------------
K.ChMod jsr PFT.CheckPathYA
2019-12-02 08:09:58 +01:00
bcs K.ChMod.RET2
2019-01-30 06:20:13 +00:00
2019-04-19 06:42:43 +01: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 06:42:43 +01:00
>MLICALL MLISETFILEINFO
2019-01-30 06:20:13 +00:00
rts
2019-04-19 06:42:43 +01:00
.9 lda #E.SYN
sec
.90 rts
2019-12-02 08:09:58 +01:00
K.ChMod.RET2 >RET 2 discard statbuf
*--------------------------------------
* # FStat
2018-10-04 17:30:14 +02:00
* Return information about a hFILE
2018-08-08 17:13:37 +02:00
* ## C
* `int fstat(short int hFILE, struct stat *statbuf);`
2018-07-20 13:51:08 +02:00
* ## ASM
2018-06-18 10:44:02 +02:00
* **In:**
2018-08-08 17:13:37 +02:00
* `>PUSHW statbuf`
* `lda hFILE`
* `>SYSCALL fstat`
2018-10-11 17:23:06 +02:00
* ## RETURN VALUE
*--------------------------------------
2018-08-08 17:13:37 +02:00
K.FStat jsr PFT.CheckNodeA
2019-12-02 08:09:58 +01:00
bcs K.ChMod.RET2
2018-11-16 17:04:20 +01:00
tax
2019-02-27 15:00:56 +00:00
lda OF.Table.hPath-1,x
2018-10-04 17:30:14 +02:00
jsr K.GetMemPtr
2018-11-16 17:04:20 +01:00
jsr PFT.YAToMLIPATH
2019-12-02 08:09:58 +01:00
>PULLW K.Stat.Store.2+1
jsr SHARED.Stat.I
bcs K.Stat.Store.RTS
2018-11-16 17:04:20 +01:00
lda (pFD) #S.FD.T
2019-12-02 08:09:58 +01:00
bne K.Stat.Store
2018-11-16 17:04:20 +01:00
ldy #S.FD.REG.REF
lda (pFD),y
sta K.MLI.PARAMS+1
2018-11-07 17:11:02 +01:00
>MLICALL MLIGETEOF
2019-12-02 08:09:58 +01:00
bcs K.Stat.Store.RTS
2018-11-07 17:11:02 +01:00
ldx #2
2019-12-02 08:09:58 +01:00
2018-11-07 17:11:02 +01:00
.1 lda K.MLI.PARAMS+2,x
2019-12-02 08:09:58 +01:00
sta K.S.STAT+S.STAT.SIZE,x
2018-11-07 17:11:02 +01:00
dex
bpl .1
2019-12-02 08:09:58 +01: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 17:11:02 +01:00
* clc
2019-12-02 08:09:58 +01:00
K.Stat.Store.RTS
2018-11-07 17:11:02 +01:00
rts
*/--------------------------------------
* # Stat
* Return information about a file
2018-07-20 13:51:08 +02:00
* ## C
* `int stat(const char *pathname, struct stat *statbuf);`
* ## ASM
2018-06-18 10:44:02 +02:00
* **In:**
2018-07-20 13:51:08 +02:00
* `>PUSHW statbuf`
* `>LDYA pathname`
* `>SYSCALL stat`
2018-10-11 17:23:06 +02:00
* ## RETURN VALUE
*\--------------------------------------
2018-07-20 13:51:08 +02:00
K.Stat jsr PFT.CheckPathYA
2019-12-02 08:09:58 +01:00
bcs K.ChMod.RET2 go discard statbuf
2019-04-19 06:42:43 +01:00
2019-12-02 08:09:58 +01:00
>PULLW K.Stat.Store.2+1
2019-04-19 06:42:43 +01:00
2019-12-02 08:09:58 +01:00
jsr SHARED.Stat.I
bcc K.Stat.Store
2019-04-19 06:42:43 +01:00
2019-04-15 06:40:13 +01:00
rts
*/-------------------------------------
2018-06-21 17:12:10 +02:00
* # MKDir
2018-09-20 17:33:05 +02:00
* create a directory
* ## C
* `int mkdir(const char *pathname, int mode);`
* ## ASM
2018-06-14 17:31:36 +02:00
* **In:**
2018-09-20 17:33:05 +02:00
* `>PUSHW mode`
* `>LDYA pathname`
* `>SYSCALL mkdir`
2018-10-11 17:23:06 +02:00
* ## RETURN VALUE
2018-09-20 17:33:05 +02:00
* CC : success
* CS : error
* A = EC
*\-------------------------------------
2018-11-16 17:04:20 +01:00
K.MKDir jsr PFT.CheckPathYA
2019-12-02 08:09:58 +01:00
bcs K.Stat.Store.RTS
2017-10-27 16:56:46 +02:00
lda #S.FI.T.DIR
2018-12-19 17:45:09 +01:00
sta K.MLI.PARAMS+4
stz K.MLI.PARAMS+5
stz K.MLI.PARAMS+6
2017-10-27 16:56:46 +02:00
lda #S.FI.ST.DIR
2018-12-19 17:45:09 +01:00
jmp IO.MLI.CREATE
*/--------------------------------------
2019-06-03 17:50:41 +02: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 08:09:58 +01:00
bcs K.Stat.Store.RTS
2019-06-03 17:50:41 +02:00
2019-07-12 08:22:32 +02:00
ldy #0
2019-07-29 17:38:55 +02:00
.1 lda IO.DEV.FIFO,y
2019-06-04 17:49:58 +02:00
sta (ZPPtr1),y
2019-07-12 08:22:32 +02:00
iny
cpy #9
bne .1
2019-06-04 17:49:58 +02:00
2019-07-12 16:51:57 +02:00
lda IO.hFD
2019-07-12 08:22:32 +02: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 17:50:41 +02:00
*/--------------------------------------
2018-06-21 17:12:10 +02:00
* # MkNod
2018-10-02 17:52:30 +02:00
* Create a special or ordinary file.
2018-09-20 17:33:05 +02:00
* (CDEV, BDEV, DSOCKS, SSOCK, PIPE)
* ## C
2018-10-03 17:25:03 +02:00
* `hFILE mknod(const char *pathname, int mode, hFD fd);`
2018-09-20 17:33:05 +02:00
* ## ASM
2018-06-14 17:31:36 +02:00
* **In:**
2018-09-20 17:33:05 +02:00
* `>PUSHB fd`
* `>PUSHW mode`
* `>LDYA pathname`
* `>SYSCALL mknod`
2018-10-11 17:23:06 +02:00
* ## RETURN VALUE
2018-09-20 17:33:05 +02:00
* CC = OK, CS = ERROR
* A = hFILE
*\--------------------------------------
2018-09-20 17:33:05 +02:00
K.MkNod >STYA ZPPtr1 pathname
>PULLW K.S.STAT+S.STAT.MODE
2019-07-12 16:51:57 +02: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 08:25:27 +02:00
* sec
2019-02-04 16:37:15 +00:00
rts
.2 stx .3+1 Store hFILE
2018-10-03 07:52:08 +02:00
>LDYA ZPPtr1
2019-05-04 23:13:50 +02:00
ldx #SYS.StrDup
2019-08-05 15:30:58 +02: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 16:51:57 +02: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 07:52:08 +02: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 17:59:11 +02:00
* `hFD pipe(int size);`
2019-02-04 16:37:15 +00:00
* ## ASM
2019-05-02 17:59:11 +02:00
* `>LDYA size`
2019-02-04 16:37:15 +00:00
* `>SYSCALL pipe`
* ## RETURN VALUE
* CC = OK, CS = ERROR
* A = hFD
*\--------------------------------------
2019-06-03 17:50:41 +02:00
K.Pipe sta .1+1 SIZE HI
2019-05-23 17:38:32 +02:00
.DO AUXPIPE=1
2019-06-19 17:56:59 +02:00
ldx #SYS.NewStkObj
jsr K.SYSCALL2.AUX Buffer in AUX mem
2019-05-23 17:38:32 +02:00
.ELSE
2019-05-03 15:08:12 +02:00
jsr K.GetMem
2019-05-23 17:38:32 +02:00
.FIN
bcs .99
2019-06-03 17:50:41 +02:00
stx .8+1 save PIPE buffer
2019-07-12 16:51:57 +02:00
ldx #2
jsr IO.MkFD
bcs .9
2019-06-03 17:50:41 +02:00
.1 lda #$ff SELF MODIFIED
ldy #S.FD.PIPE.Free+1
2019-05-02 17:59:11 +02:00
sta (pFD),y
2019-06-03 17:50:41 +02: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 17:50:41 +02:00
.8 lda #$ff Self Modified
2018-08-08 17:13:37 +02:00
sta (pFD),y
2019-05-03 15:08:12 +02:00
txa hFD
2019-02-15 16:38:17 +00:00
* clc
rts
.9 pha save error code
2019-06-03 17:50:41 +02:00
lda .8+1 get back PIPE buffer
2019-05-23 17:38:32 +02:00
.DO AUXPIPE=1
2019-06-19 17:56:59 +02:00
ldx #SYS.FreeStkObj
jsr K.SYSCALL2.AUX
2019-05-23 17:38:32 +02:00
.ELSE
2018-06-22 08:24:35 +02:00
jsr K.FreeMem
2019-05-24 08:09:19 +02:00
.FIN
pla
sec
2019-12-02 17:47:53 +01: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 20:37:32 +01:00
>PUSHWI K.MLI.PARAMS+S.FI.CDATE
2019-12-04 07:56:03 +01:00
>PUSHWI K.S.STAT+S.STAT.CTIME
>SYSCALL2 PTime2Time BANK2
2019-12-02 17:47:53 +01:00
2020-01-18 20:37:32 +01:00
>PUSHWI K.MLI.PARAMS+S.FI.MDATE
2019-12-04 07:56:03 +01:00
>PUSHWI K.S.STAT+S.STAT.MTIME
>SYSCALL2 PTime2Time BANK2
2019-12-02 17:47:53 +01:00
clc
rts
*--------------------------------------
SHARED.DirEnt2Stat
2019-12-04 07:56:03 +01:00
* clc
* rts
2019-12-02 17:47:53 +01: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 18:17:13 +01:00
SAVE USR/SRC/SYS/KERNEL.S.STAT
LOAD USR/SRC/SYS/KERNEL.S
ASM