A2osX/SYS/KERNEL.S.UNISTD.txt

335 lines
6.8 KiB
Plaintext
Raw Normal View History

2019-07-27 20:51:39 +00:00
NEW
AUTO 3,1
*/--------------------------------------
* # open
* ## C
* `hFD open(const char *pathname, short int flags);`
* ## ASM
* **In:**
* `>PUSHB flags`
* `>LDYA pathname`
* `>SYSCALL open`
* ## RETURN VALUE
* A = hFD
* REG File created on ProDOS : T=TXT,X=$0000
*\--------------------------------------
.DUMMY
.OR ZPTMP+20 7 Bytes
IO.Open.FLAGS .BS 1
IO.Open.TYPE .BS 1
IO.Open.AUXTYPE .BS 2
IO.hFD .BS 1
.ED
2020-06-30 14:30:14 +00:00
*--------------------------------------
2019-07-27 20:51:39 +00:00
K.Open jsr PFT.YAToMLIPATH
>PULLB IO.Open.FLAGS
lda #S.FI.T.TXT
sta IO.Open.TYPE
stz IO.Open.AUXTYPE
stz IO.Open.AUXTYPE+1
*--------------------------------------
2020-06-30 14:30:14 +00:00
UNISTD.Open ldx #5 /DEV/
cpx K.MLI.PATH
bcs .99
.1 lda K.MLI.PATH,x
cmp DEV.FIFO-1,x
bne .99
dex
bne .1
*--------------------------------------
2020-03-16 06:50:15 +00:00
* /DEV/xxxxxx (CDEV,BDEV,DSOCK,SSOCK,PIPE)
2020-06-30 14:30:14 +00:00
*--------------------------------------
2019-07-27 20:51:39 +00:00
>LDYAI K.MLI.PATH+6 skip $/DEV/
2020-03-13 16:10:36 +00:00
jsr K.GetDevByName
2019-07-27 20:51:39 +00:00
bcc .7
2020-06-30 14:30:14 +00:00
2019-07-27 20:51:39 +00:00
ldx #2
.10 lda Nod.Table.hPath-2,x
beq .3
jsr K.GetMemPtr
>STYA ZPPtr1
2020-06-30 14:30:14 +00:00
2019-07-27 20:51:39 +00:00
ldy #0
2020-03-13 16:10:36 +00:00
2019-07-27 20:51:39 +00:00
.2 lda (ZPPtr1),y
iny
cmp K.MLI.PATH,y
bne .3
2020-06-30 14:30:14 +00:00
2019-07-27 20:51:39 +00:00
cmp #0 end of string ?
2020-03-13 16:10:36 +00:00
2019-07-27 20:51:39 +00:00
bne .2
2020-03-13 16:10:36 +00:00
2019-07-27 20:51:39 +00:00
lda Nod.Table.hFD-2,x return hFD
2019-07-31 15:10:59 +00:00
jsr UNISTD.GetPFD
2019-07-27 20:51:39 +00:00
bra .71
2020-06-30 14:30:14 +00:00
2019-07-27 20:51:39 +00:00
.3 inx
cpx #K.NOD.MAX+2
bne .10
2020-06-30 14:30:14 +00:00
2019-07-27 20:51:39 +00:00
lda #MLI.E.NODEV
2019-10-03 06:25:27 +00:00
* sec
2019-07-27 20:51:39 +00:00
rts no OF found
2020-06-30 14:30:14 +00:00
*--------------------------------------
2020-03-11 16:41:45 +00:00
.7 stx IO.hFD
2019-07-27 20:51:39 +00:00
>STYA pFD
2020-03-10 16:42:07 +00:00
2019-07-27 20:51:39 +00:00
.71 lda (pFD) #S.FD.T
tax
2020-05-04 20:46:21 +00:00
2020-03-16 06:50:15 +00:00
jmp (.8-2,x)
2019-10-03 06:25:27 +00:00
.8
2019-07-29 15:38:55 +00:00
* .DA STDIO.IOERR REG
2020-03-16 06:50:15 +00:00
.DA STDIO.IOERR DIR
2019-07-27 20:51:39 +00:00
.DA IO.OPEN.CDEV
.DA IO.OPEN.BDEV
.DA STDIO.IOERR LNK
.DA IO.OPEN.DSOCK
.DA IO.OPEN.SSOCK
.DA IO.OPEN.PIPE
2020-03-11 16:41:45 +00:00
2020-06-30 14:30:14 +00:00
.99 jmp IO.OPEN.REG
2019-07-27 20:51:39 +00:00
*/--------------------------------------
* # close
* ## C
* `int close(hFD fd);`
* ## ASM
* **In:**
* `lda fd`
* `>SYSCALL close`
*\--------------------------------------
2019-07-31 15:10:59 +00:00
K.Close jsr UNISTD.GetPFD
2019-07-27 20:51:39 +00:00
UNISTD.Close lda (pFD) #S.FD.T
tax
jmp (.1,x)
2020-09-09 12:47:18 +00:00
.1 .DA FS.CLOSE.REG
.DA FS.CLOSE.DIR
2019-07-27 20:51:39 +00:00
.DA IO.CLOSE.CDEV
.DA IO.CLOSE.BDEV
.DA STDIO.IOERR LNK
.DA IO.CLOSE.DSOCK
.DA IO.CLOSE.SSOCK
.DA IO.CLOSE.PIPE
*/--------------------------------------
* # read
* ## C
* `int read(hFD fd, void *buf, int count);`
* ## ASM
* **In:**
* `>PUSHWI count`
* `>PUSHW buf`
* `lda fd`
* `>SYSCALL read`
* ## RETURN VALUE
* CC: Y,A = bytes read
* CS: A = EC
*\--------------------------------------
2019-07-31 15:10:59 +00:00
K.Read jsr UNISTD.GetPFD
2020-02-16 20:45:16 +00:00
2019-07-27 20:51:39 +00:00
UNISTD.Read lda (pFD) #S.FD.T
tax
jmp (.1,x)
.1 .DA IO.READ.REG
.DA STDIO.IOERR DIR
.DA IO.READ.CDEV
.DA STDIO.IOERR BDEV
.DA STDIO.IOERR LNK
.DA STDIO.IOERR DSOCK
.DA IO.READ.SSOCK
.DA IO.READ.PIPE
*/--------------------------------------
* # write
* ## C
* `int write(hFD fd, const void *buf, int count);`
* ## ASM
* **In:**
* `>PUSHWI count`
* `>PUSHW buf`
* `lda fd`
* `>SYSCALL write`
* ## RETURN VALUE
* CC: Y,A = bytes written
* CS: A = EC
*\--------------------------------------
2019-07-31 15:10:59 +00:00
K.Write jsr UNISTD.GetPFD
2019-07-27 20:51:39 +00:00
UNISTD.Write lda (pFD) #S.FD.T
tax
jmp (.1,x)
.1 .DA IO.WRITE.REG
.DA STDIO.IOERR DIR
.DA IO.WRITE.CDEV
.DA STDIO.IOERR BDEV
.DA STDIO.IOERR LNK
.DA STDIO.IOERR DSOCK
.DA IO.WRITE.SSOCK
.DA IO.WRITE.PIPE
*--------------------------------------
2019-07-31 15:10:59 +00:00
UNISTD.GetPFD sta IO.hFD
jsr K.GetMemPtr
>STYA pFD
rts
*--------------------------------------
2020-03-17 06:23:07 +00:00
IO.OPEN.CDEV
IO.OPEN.BDEV jsr SHARED.GetPDrv
ldx #IOCTL.OPEN
lda IO.hFD
jsr SHARED.pDrvJmp
2020-06-30 14:30:14 +00:00
bcs IO.WRITE.CDEV.RTS
2020-05-04 20:46:21 +00:00
*--------------------------------------
IO.OPEN.DSOCK
*--------------------------------------
2020-06-30 14:30:14 +00:00
IO.OPEN.SSOCK
2020-03-17 06:23:07 +00:00
lda IO.hFD
*--------------------------------------
IO.CLOSE.CDEV
IO.CLOSE.BDEV
clc
rts
*--------------------------------------
IO.READ.CDEV ldx #IOCTL.READ
.HS 2C BIT ABS
*--------------------------------------
IO.WRITE.CDEV ldx #IOCTL.WRITE
>PULLW K.S.IOCTL+S.IOCTL.BUFPTR
>PULLW K.S.IOCTL+S.IOCTL.BYTECNT
2020-05-04 20:46:21 +00:00
jsr SHARED.GetPDrv
2020-03-17 06:23:07 +00:00
>LDYAI K.S.IOCTL
jsr SHARED.pDrvJmp
bcs .9
>LDYA K.S.IOCTL+S.IOCTL.BYTECNT
2020-06-30 14:30:14 +00:00
.9
IO.WRITE.CDEV.RTS
rts
2020-03-17 06:23:07 +00:00
*--------------------------------------
IO.CLOSE.DSOCK
2020-06-30 14:30:14 +00:00
IO.CLOSE.SSOCK
2020-03-17 06:23:07 +00:00
ldy #S.FD.SSOCK.CLOSE
.HS 2C BIT ABS
*--------------------------------------
IO.EOF.SSOCK ldy #S.FD.SSOCK.EOF
.HS 2C BIT ABS
*--------------------------------------
IO.READ.SSOCK ldy #S.FD.SSOCK.READ
.HS 2C BIT ABS
*--------------------------------------
IO.WRITE.SSOCK ldy #S.FD.SSOCK.WRITE
lda (pFD),y
tax Function Offset in LIB
ldy #S.FD.SSOCK.IOHANDLER
lda (pFD),y
jsr K.GetMemPtr
>STYA .1+1
lda IO.hFD
.1 jmp $FFFF SELF MODIFIED
*--------------------------------------
IO.EOF.CDEV lda #S.IOCTL.STATCODE.EOF
jmp SHARED.GetDevStatus
*--------------------------------------
* X = 0 > REG
* X = 1 > DIR
* X = 2 > PIPE
*--------------------------------------
IO.MkFD stx .8+1
ldy IO.MkFD.Y,x
lda #0
ldx #S.MEM.F.INIT0+S.MEM.F.FD
jsr MEM.GetMem.YAX
bcs .9
2020-06-30 14:30:14 +00:00
2020-03-17 06:23:07 +00:00
>STYA pFD
stx IO.hFD
2020-06-30 14:30:14 +00:00
2020-03-17 06:23:07 +00:00
.8 ldx #$ff SELF MODIFIED
lda IO.MkFD.T,x
sta (pFD) X = hFD, A = T
* clc
.9 rts
IO.MkFD.Y .DA #S.FD.REG,#S.FD.DIR,#S.FD.PIPE
IO.MkFD.T .DA #S.FD.T.REG,#S.FD.T.DIR,#S.FD.T.PIPE
*--------------------------------------
IO.CLOSE.NOD ldx #2
lda IO.hFD
.1 cmp Nod.Table.hFD-2,x
bne .2
stz Nod.Table.hFD-2,x
lda Nod.Table.hPath-2,x
stz Nod.Table.hPath-2,x
jmp K.FreeMem
.2 inx
cpx #K.Nod.MAX+2
bne .1
lda #E.INVH
* sec
rts
2020-03-11 06:40:01 +00:00
*/--------------------------------------
* # ChOwn
* ## C
* `short int chown(const char *pathname, short int owner, short int group);`
* ## ASM
* **In:**
* `>PUSHW pathname`
* `>PUSHB owner`
* `>PUSHB group`
* `>SYSCALL chown`
* ## RETURN VALUE
*\--------------------------------------
2020-07-10 13:59:56 +00:00
K.ChOwn jsr PFT.CheckPath2
bcs K.ChOwn.RET4
2020-07-18 14:04:21 +00:00
stz K.MLI.PARAMS+3+S.FIEX.ACL read mode
>MLICALL MLIACL
2020-07-10 13:59:56 +00:00
bcs K.ChOwn.RET4
2020-07-18 14:18:10 +00:00
lda (pStack)
bmi .1
sta K.MLI.PARAMS+3+S.FIEX.ACL.GID
2020-07-28 20:37:26 +00:00
.1 ldy #1
2020-07-18 14:18:10 +00:00
lda (pStack),y
bmi .2
sta K.MLI.PARAMS+3+S.FIEX.ACL.UID
2020-07-10 13:59:56 +00:00
2020-07-18 14:18:10 +00:00
.2 lda #$57 write mode
2020-07-16 14:53:35 +00:00
sta K.MLI.PARAMS+3+S.FIEX.ACL
2020-07-18 14:04:21 +00:00
>MLICALL MLIACL
2020-07-10 13:59:56 +00:00
K.ChOwn.RET4 >RET 4
2020-02-16 20:45:16 +00:00
*--------------------------------------
2020-06-30 14:30:14 +00:00
SHARED.GetPDrv ldy #S.FD.DEV.DRVPTR
lda (pFD),y
sta pDRV
iny
lda (pFD),y
sta pDRV+1
rts
*--------------------------------------
DEV.FIFO .AS "/dev/fifo" STAT,UNISTD
*--------------------------------------
2019-07-27 20:51:39 +00:00
MAN
SAVE USR/SRC/SYS/KERNEL.S.UNISTD
LOAD USR/SRC/SYS/KERNEL.S
ASM