forked from KolibriOS/kolibrios
small updates and fixes in net branch
git-svn-id: svn://kolibrios.org@2308 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
df1f1777ac
commit
63bc53c598
@ -290,20 +290,18 @@ IPv4_input: ; TODO: implement handler for IP options
|
|||||||
; No, it's just a regular IP packet, pass it to the higher protocols
|
; No, it's just a regular IP packet, pass it to the higher protocols
|
||||||
|
|
||||||
.handle_it: ; We reach here if packet hasnt been fragmented, or when it already has been re-constructed
|
.handle_it: ; We reach here if packet hasnt been fragmented, or when it already has been re-constructed
|
||||||
movzx eax, [edx + IPv4_header.VersionAndIHL] ; Calculate Header length by using IHL field
|
|
||||||
and eax, 0x0000000f ;
|
movzx esi, [edx + IPv4_header.VersionAndIHL] ; Calculate Header length by using IHL field
|
||||||
shl eax, 2 ;
|
and esi, 0x0000000f ;
|
||||||
|
shl esi, 2 ;
|
||||||
|
|
||||||
movzx ecx, [edx + IPv4_header.TotalLength] ; Calculate length of encapsulated Packet
|
movzx ecx, [edx + IPv4_header.TotalLength] ; Calculate length of encapsulated Packet
|
||||||
xchg cl , ch ;
|
xchg cl , ch ;
|
||||||
sub ecx, eax ;
|
sub ecx, esi ;
|
||||||
|
|
||||||
add eax, edx
|
lea edi, [edx + IPv4_header.SourceAddress] ; make edi ptr to source and dest IPv4 address
|
||||||
push eax
|
|
||||||
|
|
||||||
mov esi, [edx + IPv4_header.SourceAddress] ; These values might be of interest to the higher protocols
|
|
||||||
mov edi, [edx + IPv4_header.DestinationAddress] ;
|
|
||||||
mov al , [edx + IPv4_header.Protocol]
|
mov al , [edx + IPv4_header.Protocol]
|
||||||
pop edx ; Offset to data (tcp/udp/icmp/.. Packet)
|
add edx, esi ; make edi ptr to data
|
||||||
|
|
||||||
cmp al , IP_PROTO_TCP
|
cmp al , IP_PROTO_TCP
|
||||||
je TCP_input
|
je TCP_input
|
||||||
|
@ -134,8 +134,8 @@ macro ICMP_init {
|
|||||||
; ebx = pointer to device struct
|
; ebx = pointer to device struct
|
||||||
; ecx = ICMP Packet size
|
; ecx = ICMP Packet size
|
||||||
; edx = ptr to ICMP Packet data
|
; edx = ptr to ICMP Packet data
|
||||||
; esi = ipv4 source address
|
; edi = ptr to ipv4 source and dest address
|
||||||
; edi = ipv4 dest address
|
;
|
||||||
; OUT: /
|
; OUT: /
|
||||||
;
|
;
|
||||||
;-----------------------------------------------------------------
|
;-----------------------------------------------------------------
|
||||||
@ -146,7 +146,7 @@ ICMP_input:
|
|||||||
|
|
||||||
; First, check the checksum (altough some implementations ignore it)
|
; First, check the checksum (altough some implementations ignore it)
|
||||||
|
|
||||||
push edx esi ecx
|
push edx ecx
|
||||||
push [edx + ICMP_header.Checksum]
|
push [edx + ICMP_header.Checksum]
|
||||||
mov [edx + ICMP_header.Checksum], 0
|
mov [edx + ICMP_header.Checksum], 0
|
||||||
mov esi, edx
|
mov esi, edx
|
||||||
@ -155,14 +155,14 @@ ICMP_input:
|
|||||||
call checksum_2
|
call checksum_2
|
||||||
pop si
|
pop si
|
||||||
cmp dx, si
|
cmp dx, si
|
||||||
pop ecx esi edx
|
pop ecx edx
|
||||||
jne .checksum_mismatch
|
jne .checksum_mismatch
|
||||||
|
|
||||||
cmp [edx + ICMP_header.Type], ICMP_ECHO ; Is this an echo request?
|
cmp [edx + ICMP_header.Type], ICMP_ECHO ; Is this an echo request?
|
||||||
jne .check_sockets
|
jne .check_sockets
|
||||||
|
|
||||||
; We well re-use the packet sow e can create the response as fast as possible
|
; We well re-use the packet so we can create the response as fast as possible
|
||||||
; Notice: this only works on pure ethernet (however, IP packet options are not a problem this time :)
|
; Notice: this only works on pure ethernet
|
||||||
|
|
||||||
DEBUGF 1,"ICMP_input - echo request\n"
|
DEBUGF 1,"ICMP_input - echo request\n"
|
||||||
mov [edx + ICMP_header.Type], ICMP_ECHOREPLY ; Change Packet type to reply
|
mov [edx + ICMP_header.Type], ICMP_ECHOREPLY ; Change Packet type to reply
|
||||||
@ -226,8 +226,8 @@ ICMP_input:
|
|||||||
|
|
||||||
.check_sockets:
|
.check_sockets:
|
||||||
; Look for an open ICMP socket
|
; Look for an open ICMP socket
|
||||||
; esi = sender ip
|
|
||||||
|
|
||||||
|
mov esi, [edi] ; ipv4 source address
|
||||||
mov ebx, net_sockets
|
mov ebx, net_sockets
|
||||||
.try_more:
|
.try_more:
|
||||||
; mov ax , [edx + ICMP_header.Identifier]
|
; mov ax , [edx + ICMP_header.Identifier]
|
||||||
|
@ -25,9 +25,7 @@ $Revision$
|
|||||||
; ebx = ptr to device struct
|
; ebx = ptr to device struct
|
||||||
; ecx = segment size
|
; ecx = segment size
|
||||||
; edx = ptr to TCP segment
|
; edx = ptr to TCP segment
|
||||||
;
|
; edi = ptr to ipv4 source address, followed by ipv4 dest address
|
||||||
; esi = ipv4 source address
|
|
||||||
; edi = ipv4 dest address
|
|
||||||
;
|
;
|
||||||
; OUT: /
|
; OUT: /
|
||||||
;
|
;
|
||||||
@ -54,10 +52,8 @@ TCP_input:
|
|||||||
push eax ecx edx
|
push eax ecx edx
|
||||||
pushw [edx + TCP_header.Checksum]
|
pushw [edx + TCP_header.Checksum]
|
||||||
mov [edx + TCP_header.Checksum], 0
|
mov [edx + TCP_header.Checksum], 0
|
||||||
push esi edi
|
|
||||||
mov esi, edx
|
mov esi, edx
|
||||||
TCP_checksum (esp), (esp+4)
|
TCP_checksum (edi), (edi+4)
|
||||||
pop esi edi ; yes, swap them (we dont need dest addr)
|
|
||||||
pop cx ; previous checksum
|
pop cx ; previous checksum
|
||||||
cmp cx, dx
|
cmp cx, dx
|
||||||
pop edx ecx esi
|
pop edx ecx esi
|
||||||
@ -65,7 +61,7 @@ TCP_input:
|
|||||||
|
|
||||||
DEBUGF 1,"Checksum is correct\n"
|
DEBUGF 1,"Checksum is correct\n"
|
||||||
|
|
||||||
sub ecx, esi ; update packet size
|
sub ecx, esi ; substract TCP header size from total segment size
|
||||||
jb .drop_not_locked
|
jb .drop_not_locked
|
||||||
DEBUGF 1,"we got %u bytes of data\n", ecx
|
DEBUGF 1,"we got %u bytes of data\n", ecx
|
||||||
|
|
||||||
@ -129,7 +125,7 @@ TCP_input:
|
|||||||
jne .socket_loop
|
jne .socket_loop
|
||||||
|
|
||||||
mov eax, [ebx + IP_SOCKET.RemoteIP]
|
mov eax, [ebx + IP_SOCKET.RemoteIP]
|
||||||
cmp eax, edi ; edi is source ip from packet
|
cmp eax, [edi] ; Ipv4 source addres
|
||||||
je @f
|
je @f
|
||||||
test eax, eax
|
test eax, eax
|
||||||
jnz .socket_loop
|
jnz .socket_loop
|
||||||
@ -189,7 +185,7 @@ TCP_input:
|
|||||||
test eax, eax
|
test eax, eax
|
||||||
jz .drop
|
jz .drop
|
||||||
|
|
||||||
push [edx - sizeof.IPv4_header + IPv4_header.DestinationAddress] ;;; FIXME
|
push dword [edi + 4] ; Ipv4 destination addres
|
||||||
pop [eax + IP_SOCKET.LocalIP]
|
pop [eax + IP_SOCKET.LocalIP]
|
||||||
|
|
||||||
push [edx + TCP_header.DestinationPort]
|
push [edx + TCP_header.DestinationPort]
|
||||||
@ -213,7 +209,7 @@ TCP_input:
|
|||||||
;--------------------
|
;--------------------
|
||||||
; Process TCP options
|
; Process TCP options
|
||||||
|
|
||||||
cmp esi, TCP_header.DataOffset ; esi is headersize
|
cmp esi, TCP_header.DataOffset ; Does header contain any options?
|
||||||
je .no_options
|
je .no_options
|
||||||
|
|
||||||
DEBUGF 1,"Segment has options\n"
|
DEBUGF 1,"Segment has options\n"
|
||||||
@ -221,26 +217,26 @@ TCP_input:
|
|||||||
cmp [ebx + TCP_SOCKET.t_state], TCPS_LISTEN ; no options when in listen state
|
cmp [ebx + TCP_SOCKET.t_state], TCPS_LISTEN ; no options when in listen state
|
||||||
jz .not_uni_xfer ; also no header prediction
|
jz .not_uni_xfer ; also no header prediction
|
||||||
|
|
||||||
lea edi, [edx + sizeof.TCP_header]
|
|
||||||
lea eax, [edx + esi]
|
lea eax, [edx + esi]
|
||||||
|
lea esi, [edx + sizeof.TCP_header]
|
||||||
|
|
||||||
.opt_loop:
|
.opt_loop:
|
||||||
cmp edi, eax
|
cmp esi, eax ; are we scanning outside of header?
|
||||||
jae .no_options
|
jae .no_options
|
||||||
|
|
||||||
cmp byte [edi], TCP_OPT_EOL ; end of option list?
|
cmp byte [esi], TCP_OPT_EOL ; end of option list?
|
||||||
jz .no_options
|
jz .no_options
|
||||||
|
|
||||||
cmp byte [edi], TCP_OPT_NOP ; nop ?
|
cmp byte [esi], TCP_OPT_NOP ; nop ?
|
||||||
jz .opt_nop
|
jz .opt_nop
|
||||||
|
|
||||||
cmp byte [edi], TCP_OPT_MAXSEG
|
cmp byte [esi], TCP_OPT_MAXSEG
|
||||||
je .opt_maxseg
|
je .opt_maxseg
|
||||||
|
|
||||||
cmp byte [edi], TCP_OPT_WINDOW
|
cmp byte [esi], TCP_OPT_WINDOW
|
||||||
je .opt_window
|
je .opt_window
|
||||||
|
|
||||||
cmp byte [edi], TCP_OPT_TIMESTAMP
|
cmp byte [esi], TCP_OPT_TIMESTAMP
|
||||||
je .opt_timestamp
|
je .opt_timestamp
|
||||||
|
|
||||||
jmp .no_options ; If we reach here, some unknown options were received, skip them all!
|
jmp .no_options ; If we reach here, some unknown options were received, skip them all!
|
||||||
@ -250,13 +246,13 @@ TCP_input:
|
|||||||
jmp .opt_loop
|
jmp .opt_loop
|
||||||
|
|
||||||
.opt_maxseg:
|
.opt_maxseg:
|
||||||
cmp byte [edi+1], 4
|
cmp byte [esi+1], 4
|
||||||
jne .no_options ; error occured, ignore all options!
|
jne .no_options ; error occured, ignore all options!
|
||||||
|
|
||||||
test [edx + TCP_header.Flags], TH_SYN
|
test [edx + TCP_header.Flags], TH_SYN
|
||||||
jz @f
|
jz @f
|
||||||
|
|
||||||
movzx eax, word[edi+2]
|
movzx eax, word[esi+2]
|
||||||
rol ax, 8
|
rol ax, 8
|
||||||
DEBUGF 1,"Maxseg: %u\n", ax
|
DEBUGF 1,"Maxseg: %u\n", ax
|
||||||
|
|
||||||
@ -268,7 +264,7 @@ TCP_input:
|
|||||||
|
|
||||||
|
|
||||||
.opt_window:
|
.opt_window:
|
||||||
cmp byte [edi+1], 3
|
cmp byte [esi+1], 3
|
||||||
jne .no_options
|
jne .no_options
|
||||||
|
|
||||||
test [edx + TCP_header.Flags], TH_SYN
|
test [edx + TCP_header.Flags], TH_SYN
|
||||||
@ -283,14 +279,14 @@ TCP_input:
|
|||||||
|
|
||||||
|
|
||||||
.opt_timestamp:
|
.opt_timestamp:
|
||||||
cmp byte [edi+1], 10
|
cmp byte [esi+1], 10
|
||||||
jne .no_options
|
jne .no_options
|
||||||
|
|
||||||
DEBUGF 1,"Got timestamp option\n"
|
DEBUGF 1,"Got timestamp option\n"
|
||||||
|
|
||||||
;;;;;
|
;;;;;
|
||||||
|
|
||||||
add edi, 10
|
add esi, 10
|
||||||
jmp .opt_loop
|
jmp .opt_loop
|
||||||
|
|
||||||
.no_options:
|
.no_options:
|
||||||
@ -416,6 +412,9 @@ TCP_input:
|
|||||||
|
|
||||||
add [ebx + TCP_SOCKET.RCV_NXT], ecx ; Update sequence number with number of bytes we have copied
|
add [ebx + TCP_SOCKET.RCV_NXT], ecx ; Update sequence number with number of bytes we have copied
|
||||||
|
|
||||||
|
movzx esi, [edx + TCP_header.DataOffset]
|
||||||
|
and esi, 0xf0
|
||||||
|
shr esi, 2
|
||||||
add esi, edx
|
add esi, edx
|
||||||
lea eax, [ebx + STREAM_SOCKET.rcv]
|
lea eax, [ebx + STREAM_SOCKET.rcv]
|
||||||
call SOCKET_ring_write ; Add the data to the socket buffer
|
call SOCKET_ring_write ; Add the data to the socket buffer
|
||||||
@ -480,7 +479,7 @@ align 4
|
|||||||
|
|
||||||
;;; TODO: check if it's a broadcast or multicast, and drop if so
|
;;; TODO: check if it's a broadcast or multicast, and drop if so
|
||||||
|
|
||||||
push [edx - sizeof.IPv4_header + IPv4_header.SourceAddress] ;;; FIXME
|
push dword [edi + 4] ; Ipv4 destination addres
|
||||||
pop [ebx + IP_SOCKET.RemoteIP]
|
pop [ebx + IP_SOCKET.RemoteIP]
|
||||||
|
|
||||||
push [edx + TCP_header.SourcePort]
|
push [edx + TCP_header.SourcePort]
|
||||||
@ -1054,7 +1053,7 @@ align 4
|
|||||||
@@:
|
@@:
|
||||||
|
|
||||||
mov edi, [edx + TCP_header.AckNumber]
|
mov edi, [edx + TCP_header.AckNumber]
|
||||||
sub edi, [ebx + TCP_SOCKET.SND_UNA] ; now we got the number of acked bytes in esi
|
sub edi, [ebx + TCP_SOCKET.SND_UNA] ; now we got the number of acked bytes in edi
|
||||||
|
|
||||||
;;; TODO: update stats
|
;;; TODO: update stats
|
||||||
|
|
||||||
@ -1353,11 +1352,10 @@ align 4
|
|||||||
|
|
||||||
;; TODO: check if data is in sequence !
|
;; TODO: check if data is in sequence !
|
||||||
|
|
||||||
movzx eax, [edx + TCP_header.DataOffset] ;;; todo: remember this in.. edi ?
|
movzx esi, [edx + TCP_header.DataOffset]
|
||||||
and eax, 0xf0
|
and esi, 0xf0
|
||||||
shr al, 2
|
shr esi, 2
|
||||||
|
add esi, edx
|
||||||
lea esi, [edx + eax]
|
|
||||||
|
|
||||||
or [ebx + TCP_SOCKET.t_flags], TF_DELACK
|
or [ebx + TCP_SOCKET.t_flags], TF_DELACK
|
||||||
add [ebx + TCP_SOCKET.RCV_NXT], ecx
|
add [ebx + TCP_SOCKET.RCV_NXT], ecx
|
||||||
|
@ -311,7 +311,9 @@ TCP_respond_socket:
|
|||||||
;-------------------------
|
;-------------------------
|
||||||
; TCP_respond.segment:
|
; TCP_respond.segment:
|
||||||
;
|
;
|
||||||
; IN: edx = segment ptr (a previously received segment)
|
; IN: ebx = ptr to driver
|
||||||
|
; edx = segment ptr (a previously received segment)
|
||||||
|
; edi = ptr to dest and src IPv4 addresses
|
||||||
; cl = flags
|
; cl = flags
|
||||||
|
|
||||||
align 4
|
align 4
|
||||||
@ -322,14 +324,14 @@ TCP_respond_segment:
|
|||||||
;---------------------
|
;---------------------
|
||||||
; Create the IP packet
|
; Create the IP packet
|
||||||
|
|
||||||
push cx edx
|
push cx edx ebx
|
||||||
mov ebx, [edx - sizeof.IPv4_header + IPv4_header.SourceAddress] ;;;; FIXME: and what if ip packet had options?!
|
mov ebx, [edi + 4]
|
||||||
mov eax, [edx - sizeof.IPv4_header + IPv4_header.DestinationAddress] ;;;
|
mov eax, [edi]
|
||||||
mov ecx, sizeof.TCP_header
|
mov ecx, sizeof.TCP_header
|
||||||
mov di , IP_PROTO_TCP shl 8 + 128
|
mov di , IP_PROTO_TCP shl 8 + 128
|
||||||
call IPv4_output
|
call IPv4_output
|
||||||
jz .error
|
jz .error
|
||||||
pop esi cx
|
pop ebx esi cx
|
||||||
|
|
||||||
push edx eax
|
push edx eax
|
||||||
|
|
||||||
|
@ -108,9 +108,7 @@ macro UDP_checksum IP1, IP2 { ; esi = ptr to udp packet, ecx = packet size, des
|
|||||||
; ebx = ptr to device struct
|
; ebx = ptr to device struct
|
||||||
; ecx = UDP Packet size
|
; ecx = UDP Packet size
|
||||||
; edx = ptr to UDP header
|
; edx = ptr to UDP header
|
||||||
;
|
; edi = ptr to ipv4 source and dest address
|
||||||
; esi = ipv4 source address
|
|
||||||
; edi = ipv4 dest address
|
|
||||||
;
|
;
|
||||||
; OUT: /
|
; OUT: /
|
||||||
;
|
;
|
||||||
@ -129,7 +127,7 @@ UDP_input:
|
|||||||
push edi
|
push edi
|
||||||
push esi
|
push esi
|
||||||
mov esi, edx
|
mov esi, edx
|
||||||
UDP_checksum (esp), (esp+4)
|
UDP_checksum (edi), (edi+4)
|
||||||
pop edi
|
pop edi
|
||||||
pop esi ; we dont need it, but it is smaller then add esp, 4
|
pop esi ; we dont need it, but it is smaller then add esp, 4
|
||||||
pop edx
|
pop edx
|
||||||
@ -163,7 +161,8 @@ UDP_input:
|
|||||||
|
|
||||||
cmp [eax + IP_SOCKET.RemoteIP], 0xffffffff
|
cmp [eax + IP_SOCKET.RemoteIP], 0xffffffff
|
||||||
je @f
|
je @f
|
||||||
cmp [eax + IP_SOCKET.RemoteIP], edi ; edi is the packets source address
|
mov edi, [edi + 4] ; ipv4 source address
|
||||||
|
cmp [eax + IP_SOCKET.RemoteIP], edi
|
||||||
jne .try_more
|
jne .try_more
|
||||||
@@:
|
@@:
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user