A2osX/SBIN/HTTPD.S.txt

279 lines
5.6 KiB
Plaintext
Raw Normal View History

NEW
2019-05-02 09:52:32 +00:00
AUTO 3,1
.LIST OFF
.OP 65C02
.OR $2000
2018-07-23 15:28:42 +00:00
.TF SBIN/HTTPD
*--------------------------------------
2018-07-23 15:28:42 +00:00
.INB INC/MACROS.I
.INB INC/A2OSX.I
2019-03-02 22:18:21 +00:00
.INB INC/ETH.I
2018-07-23 15:28:42 +00:00
.INB INC/LIBTCPIP.I
2019-03-02 22:18:21 +00:00
.INB INC/NET.HTTP.I
*--------------------------------------
TIMEOUT.MAX .EQ 30 30 sec.
CONN.MAX .EQ 16
*--------------------------------------
2019-10-24 05:55:42 +00:00
.DUMMY
.OR ZPBIN
ZS.START
ZPIPCfgPtr .BS 2
ZPSktPtr .BS 2
ZPMsgPtr .BS 2
ZS.END .ED
*--------------------------------------
* File Header (16 Bytes)
*--------------------------------------
CS.START cld
jmp (.1,x)
.DA #$61 6502,Level 1 (65c02)
.DA #1 BIN Layout Version 1
2019-03-02 20:47:58 +00:00
.DA #S.PS.F.EVENT
.DA #0
.DA CS.END-CS.START CS
.DA DS.END-DS.START DS
.DA #64 SS
2019-10-24 05:55:42 +00:00
.DA #ZS.END-ZS.START Zero Page Size
.DA 0
*--------------------------------------
* Relocation Table
2019-10-03 06:25:27 +00:00
*--------------------------------------
.1 .DA CS.INIT
.DA CS.RUN
.DA CS.DOEVENT
.DA CS.QUIT
L.LIBTCPIP .DA LIBTCPIP
2019-03-02 22:18:21 +00:00
L.SA.Local .DA SA.Local
L.MSG.TCPWAIT .DA MSG.TCPWAIT
L.MSG.INITOK .DA MSG.INITOK
L.MSG.TCPIPERR .DA MSG.TCPIPERR
L.MSG.SKTERR .DA MSG.SKTERR
L.MSG.ABORT .DA MSG.ABORT
L.MSG.INCOMING .DA MSG.INCOMING
L.HTTP.200OK .DA HTTP.200OK
2019-10-03 06:25:27 +00:00
.DA 0
*--------------------------------------
CS.INIT >LDYA L.LIBTCPIP
2018-07-19 15:33:55 +00:00
>SYSCALL LoadLib
2019-03-04 07:14:31 +00:00
bcs .9
sta hLIBTCPIP
2019-03-04 07:14:31 +00:00
.9 rts
*--------------------------------------
2019-10-24 05:55:42 +00:00
CS.RUN >LDYA L.MSG.TCPWAIT
2019-03-04 07:14:31 +00:00
>SYSCALL puts
2019-10-24 05:55:42 +00:00
>DEBUG
jsr Init.Timeout
2019-03-04 07:14:31 +00:00
.1 >SLEEP
>LIBCALL hLIBTCPIP,LIBTCPIP.GETCFG is TCPIP loaded ?
bcs .99
2019-10-24 05:55:42 +00:00
>STYA ZPIPCfgPtr
lda (ZPIPCfgPtr) Configured ?
bmi CS.RUN.INIT
2019-10-24 05:55:42 +00:00
jsr Wait.Timeout
2019-03-04 07:14:31 +00:00
bcs .99
2019-10-24 05:55:42 +00:00
2019-03-04 07:14:31 +00:00
ldy #S.PS.hStdIn
lda (pPs),y
>SYSCALL feof
bcs CS.RUN.RTS I/O err
tay
2019-05-02 09:52:32 +00:00
bne .1
2019-03-04 07:14:31 +00:00
>SYSCALL GetChar
2019-03-04 07:14:31 +00:00
bcs CS.RUN.RTS
cmp #$03
bne .1
2019-10-24 05:55:42 +00:00
>LDYA L.MSG.ABORT
2019-05-05 17:15:37 +00:00
>SYSCALL puts
2019-03-04 07:14:31 +00:00
lda #3
2019-10-24 05:55:42 +00:00
sec
rts
2019-10-24 05:55:42 +00:00
.99 >LDYA L.MSG.TCPIPERR
2019-03-04 07:14:31 +00:00
>SYSCALL puts
2018-10-21 20:54:07 +00:00
lda #E.SYN
sec
CS.RUN.RTS rts
2019-10-24 05:55:42 +00:00
CS.RUN.INIT ldx #3
ldy #S.IPCFG.IP+3
2019-10-24 05:55:42 +00:00
.1 lda (ZPIPCfgPtr),y
2019-03-02 22:18:21 +00:00
sta SA.LOCAL+S.SOCKADDR.ADDR,x
dey
dex
bpl .1
2019-10-24 05:55:42 +00:00
>DEBUG
2019-03-02 22:18:21 +00:00
>PUSHBI 0 no protocol
2019-10-24 05:55:42 +00:00
lda #S.SOCKET.T.SEQPACKET
2019-03-02 22:18:21 +00:00
>LIBCALL hLIBTCPIP,LIBTCPIP.Socket
bcs CS.RUN.ERR
2018-09-17 15:42:38 +00:00
>STA.G hSrvSocket
2019-03-02 22:18:21 +00:00
pha
>PUSHW L.SA.LOCAL
pla
>LIBCALL hLIBTCPIP,LIBTCPIP.Bind
bcs CS.RUN.ERR
>LDA.G hSrvSocket
>LIBCALL hLIBTCPIP,LIBTCPIP.Listen
bcs CS.RUN.ERR
2019-10-24 05:55:42 +00:00
>LDYA L.MSG.INITOK
2019-05-05 17:15:37 +00:00
>SYSCALL puts
CS.RUN.LOOP >SLEEP
jsr CS.RUN.SERVER
bcs CS.RUN.ERR
bra CS.RUN.LOOP
2019-10-24 05:55:42 +00:00
.9 >LDYA L.MSG.SKTERR
2019-05-05 17:15:37 +00:00
>SYSCALL puts
2018-10-21 20:54:07 +00:00
lda #E.SYN
sec
2019-03-02 22:18:21 +00:00
CS.RUN.ERR rts
*--------------------------------------
2019-03-02 22:18:21 +00:00
CS.RUN.SERVER >LDA.G hSrvSocket
>LIBCALL hLIBTCPIP,LIBTCPIP.accept
bcs .8
2019-03-02 22:18:21 +00:00
>STA.G hClntSocket
>SYSCALL GetMemPtr
>STYA ZPSktPtr
ldx #3
2019-03-02 22:18:21 +00:00
ldy #S.SOCKET.REM.ADDR+3
2019-10-24 05:55:42 +00:00
.3 >PUSHB (ZPSktPtr),y
dey
dex
bpl .3
2019-10-24 05:55:42 +00:00
2019-03-02 22:18:21 +00:00
>PUSHB.G hClntSocket
>PUSHBI 5
>LDYA L.MSG.INCOMING
2018-06-21 15:12:10 +00:00
>SYSCALL printf
2019-03-02 22:18:21 +00:00
2019-03-04 07:14:31 +00:00
jsr CS.RUN.CLIENT
.8 clc
.9 rts
*--------------------------------------
2019-03-07 20:40:06 +00:00
CS.RUN.CLIENT
2019-03-04 07:14:31 +00:00
.1 >SLEEP
2019-10-24 05:55:42 +00:00
>LIBCALL hLIBTCPIP,LIBTCPIP.Recv
2019-03-07 20:40:06 +00:00
bcc .2
2019-10-24 05:55:42 +00:00
tay
2019-03-07 20:40:06 +00:00
beq .1
2019-10-24 05:55:42 +00:00
bra .8
.2 pha
>SYSCALL getmemptr
>STYA ZPMsgPtr
2019-03-07 20:40:06 +00:00
2019-10-24 05:55:42 +00:00
>PUSHW ZPMsgPtr
2019-03-04 07:14:31 +00:00
ldy #S.PS.hStdOut
lda (pPS),y
2019-03-07 20:40:06 +00:00
2019-03-04 07:14:31 +00:00
>SYSCALL fwrite
2019-10-24 05:55:42 +00:00
pla
>SYSCALL freemem
2019-03-04 07:14:31 +00:00
.7 >PUSHWI HTTP.200OK.len
>PUSHW L.HTTP.200OK
2019-03-02 22:18:21 +00:00
>LDA.G hClntSocket
2019-10-24 05:55:42 +00:00
>LIBCALL hLIBTCPIP,LIBTCPIP.Send
2019-03-04 07:14:31 +00:00
.8 >LDA.G hClntSocket
>LIBCALL hLIBTCPIP,LIBTCPIP.Shutdown
clc
rts
*--------------------------------------
2019-03-04 07:14:31 +00:00
CS.DOEVENT lda (pEvent)
bpl .9 is it a TIMER event?
>LDA.G TimeOut
beq .9
dec
sta (pData),y
.9 sec do not discard TIMER event
rts
*--------------------------------------
CS.QUIT ldy #hSrvSocket
lda (pData),y
2019-03-04 07:14:31 +00:00
beq .3
2019-10-24 05:55:42 +00:00
2019-03-02 22:18:21 +00:00
>LIBCALL hLIBTCPIP,LIBTCPIP.Shutdown
2019-10-24 05:55:42 +00:00
.3 lda hLIBTCPIP
2018-11-12 09:22:06 +00:00
beq .8
2019-10-24 05:55:42 +00:00
2018-07-20 14:10:10 +00:00
>SYSCALL UnloadLib
2019-10-24 05:55:42 +00:00
2018-11-12 09:22:06 +00:00
.8 clc
rts
*--------------------------------------
Init.Timeout ldy #TimeOut
lda #TIMEOUT.MAX
sta (pData),y
rts
*--------------------------------------
Wait.TimeOut sec
ldy #TimeOut
lda (pData),y
beq .9
clc
.9 rts
*--------------------------------------
CS.END
*--------------------------------------
hLIBTCPIP .BS 1
2019-03-04 07:14:31 +00:00
LIBTCPIP .AZ "libtcpip"
MSG.TCPWAIT .AZ "HTTPD:Waiting for TCP/IP initializing..."
MSG.INITOK .AZ "HTTPD:Init Ok, Listening."
MSG.TCPIPERR .AZ "HTTPD:TCP/IP Not initialized properly."
MSG.SKTERR .AZ "HTTPD:Listen Error."
MSG.ABORT .AZ "HTTPD:User Aborted."
MSG.INCOMING .AZ "HTTPD:Incoming Connection [SKT=%h] From : %d.%d.%d.%d\r\n"
*--------------------------------------
2019-03-04 07:14:31 +00:00
HTTP.200OK .AS "HTTP/1.1 200 OK"
.DA #C.CR,#C.LF
.AS "Server: A2osX-HTTPD 0.92"
.DA #C.CR,#C.LF
.AS "Content-Type: text/html"
.DA #C.CR,#C.LF
.AS "Content-Length: 34"
.DA #C.CR,#C.LF
.AS "Connection: Close"
.DA #C.CR,#C.LF
.DA #C.CR,#C.LF
.AS "<HTML><BODY>Hello!</BODY></HTML>"
.DA #C.CR,#C.LF
2019-03-02 22:18:21 +00:00
HTTP.200OK.len .EQ *-HTTP.200OK
*--------------------------------------
2019-03-02 22:18:21 +00:00
SA.LOCAL .DA #AF.INET S.SOCKADDR.AF
.BS 1
2019-03-02 22:18:21 +00:00
.BS 4 S.SOCKADDR.ADDR
.DA TCP.PORT.HTTP
*--------------------------------------
.DUMMY
.OR 0
DS.START
hSrvSocket .BS 1
2019-03-02 22:18:21 +00:00
hClntSocket .BS 1
TimeOut .BS 1
DS.END
.ED
*--------------------------------------
MAN
2018-11-17 17:17:13 +00:00
SAVE USR/SRC/SBIN/HTTPD.S
ASM