Rev 4704 | Rev 4708 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
| Rev 4704 | Rev 4707 | ||
|---|---|---|---|
| Line 52... | Line 52... | ||
| 52 | #include "../tl_messages.h" |
52 | #include "../tl_messages.h" |
| 53 | 53 | ||
| 54 | #include "tcp.h" |
54 | #include "tcp.h" |
| 55 | #include "tcp_module.h" |
55 | #include "tcp_module.h" |
| 56 | 56 | ||
| - | 57 | /** Free ports pool start. |
|
| - | 58 | */ |
|
| - | 59 | #define TCP_FREE_PORTS_START 1025 |
|
| - | 60 | ||
| - | 61 | /** Free ports pool end. |
|
| - | 62 | */ |
|
| - | 63 | #define TCP_FREE_PORTS_END 65535 |
|
| - | 64 | ||
| - | 65 | /** TCP global data. |
|
| - | 66 | */ |
|
| 57 | tcp_globals_t tcp_globals; |
67 | tcp_globals_t tcp_globals; |
| 58 | 68 | ||
| 59 | int tcp_received_msg( device_id_t device_id, packet_t packet, services_t receiver ); |
69 | int tcp_received_msg( device_id_t device_id, packet_t packet, services_t receiver, services_t error ); |
| 60 | 70 | ||
| 61 | /** Initializes the module. |
71 | /** Initializes the module. |
| 62 | */ |
72 | */ |
| 63 | int tcp_initialize( async_client_conn_t client_connection ){ |
73 | int tcp_initialize( async_client_conn_t client_connection ){ |
| 64 | // ERROR_DECLARE; |
74 | ERROR_DECLARE; |
| 65 | - | ||
| 66 | // ipcarg_t arg1, arg2; |
- | |
| 67 | // packet_t packet; |
- | |
| 68 | 75 | ||
| - | 76 | fibril_rwlock_initialize( & tcp_globals.lock ); |
|
| 69 | /* printf( "TCP - testing to send to IP:\n" ); |
77 | fibril_rwlock_write_lock( & tcp_globals.lock ); |
| 70 | ERROR_PROPAGATE( ip_echo( tcp_globals.ip_phone, 12, 34, 0, 0, 0, & arg1, & arg2, NULL, NULL, NULL )); |
78 | tcp_globals.icmp_phone = icmp_connect_module( SERVICE_ICMP ); |
| 71 | if(( arg1 != 12 ) || ( arg2 != 34 )) return EINVAL; |
79 | if( tcp_globals.icmp_phone < 0 ){ |
| 72 | printf( "OK\n" ); |
80 | return tcp_globals.icmp_phone; |
| 73 | */ |
81 | } |
| 74 | tcp_globals.ip_phone = ip_bind_service( SERVICE_IP, IPPROTO_TCP, SERVICE_TCP, client_connection, tcp_received_msg ); |
82 | tcp_globals.ip_phone = ip_bind_service( SERVICE_IP, IPPROTO_TCP, SERVICE_TCP, client_connection, tcp_received_msg ); |
| 75 | - | ||
| 76 | /* printf( "TCP - testing to send packet to IP:\n" ); |
- | |
| 77 | packet = packet_get_4( tcp_globals.net_phone, 6, 20, 30, 20 ); |
83 | if( tcp_globals.ip_phone < 0 ){ |
| 78 | if( ! packet ) return ENOMEM; |
84 | return tcp_globals.ip_phone; |
| - | 85 | } |
|
| 79 | packet_copy_data( packet, "Hi, this is TCP", 16 ); |
86 | ERROR_PROPAGATE( socket_ports_initialize( & tcp_globals.sockets )); |
| 80 | ip_send_msg( tcp_globals.ip_phone, -1, packet, SERVICE_TCP ); |
87 | tcp_globals.last_used_port = TCP_FREE_PORTS_START - 1; |
| 81 | printf( "OK\n" ); |
88 | fibril_rwlock_write_unlock( & tcp_globals.lock ); |
| 82 | */ return EOK; |
89 | return EOK; |
| 83 | } |
90 | } |
| 84 | 91 | ||
| 85 | int tcp_received_msg( device_id_t device_id, packet_t packet, services_t receiver ){ |
92 | int tcp_received_msg( device_id_t device_id, packet_t packet, services_t receiver, services_t error ){ |
| 86 | // TODO received |
93 | // TODO received |
| 87 | // TODO remove debug dump: |
94 | // TODO remove debug dump: |
| 88 | uint8_t * data; |
95 | uint8_t * data; |
| 89 | data = packet_get_data( packet ); |
96 | data = packet_get_data( packet ); |
| 90 | printf( "Receiving packet:\n\tid\t= %d\n\tlength\t= %d\n\tdata\t= %.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX\n\t\t%.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX\n", packet_get_id( packet ), packet_get_data_length( packet ), data[ 0 ], data[ 1 ], data[ 2 ], data[ 3 ], data[ 4 ], data[ 5 ], data[ 6 ], data[ 7 ], data[ 8 ], data[ 9 ], data[ 10 ], data[ 11 ], data[ 12 ], data[ 13 ], data[ 14 ], data[ 15 ], data[ 16 ], data[ 17 ], data[ 18 ], data[ 19 ], data[ 20 ], data[ 21 ], data[ 22 ], data[ 23 ], data[ 24 ], data[ 25 ], data[ 26 ], data[ 27 ], data[ 28 ], data[ 29 ], data[ 30 ], data[ 31 ], data[ 32 ], data[ 33 ], data[ 34 ], data[ 35 ], data[ 36 ], data[ 37 ], data[ 38 ], data[ 39 ], data[ 40 ], data[ 41 ], data[ 42 ], data[ 43 ], data[ 44 ], data[ 45 ], data[ 46 ], data[ 47 ], data[ 48 ], data[ 49 ], data[ 50 ], data[ 51 ], data[ 52 ], data[ 53 ], data[ 54 ], data[ 55 ], data[ 56 ], data[ 57 ], data[ 58 ], data[ 59 ] ); |
97 | printf( "Receiving packet:\n\tid\t= %d\n\tlength\t= %d\n\tdata\t= %.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX\n\t\t%.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX:%.2hhX %.2hhX %.2hhX %.2hhX\n", packet_get_id( packet ), packet_get_data_length( packet ), data[ 0 ], data[ 1 ], data[ 2 ], data[ 3 ], data[ 4 ], data[ 5 ], data[ 6 ], data[ 7 ], data[ 8 ], data[ 9 ], data[ 10 ], data[ 11 ], data[ 12 ], data[ 13 ], data[ 14 ], data[ 15 ], data[ 16 ], data[ 17 ], data[ 18 ], data[ 19 ], data[ 20 ], data[ 21 ], data[ 22 ], data[ 23 ], data[ 24 ], data[ 25 ], data[ 26 ], data[ 27 ], data[ 28 ], data[ 29 ], data[ 30 ], data[ 31 ], data[ 32 ], data[ 33 ], data[ 34 ], data[ 35 ], data[ 36 ], data[ 37 ], data[ 38 ], data[ 39 ], data[ 40 ], data[ 41 ], data[ 42 ], data[ 43 ], data[ 44 ], data[ 45 ], data[ 46 ], data[ 47 ], data[ 48 ], data[ 49 ], data[ 50 ], data[ 51 ], data[ 52 ], data[ 53 ], data[ 54 ], data[ 55 ], data[ 56 ], data[ 57 ], data[ 58 ], data[ 59 ] ); |
| Line 102... | Line 109... | ||
| 102 | switch( IPC_GET_METHOD( * call )){ |
109 | switch( IPC_GET_METHOD( * call )){ |
| 103 | case IPC_M_PHONE_HUNGUP: |
110 | case IPC_M_PHONE_HUNGUP: |
| 104 | return EOK; |
111 | return EOK; |
| 105 | case NET_TL_RECEIVED: |
112 | case NET_TL_RECEIVED: |
| 106 | ERROR_PROPAGATE( packet_translate( tcp_globals.net_phone, & packet, IPC_GET_PACKET( call ))); |
113 | ERROR_PROPAGATE( packet_translate( tcp_globals.net_phone, & packet, IPC_GET_PACKET( call ))); |
| 107 | return tcp_received_msg( IPC_GET_DEVICE( call ), packet, 0 ); |
114 | return tcp_received_msg( IPC_GET_DEVICE( call ), packet, SERVICE_TCP, IPC_GET_ERROR( call )); |
| 108 | } |
115 | } |
| 109 | return ENOTSUP; |
116 | return ENOTSUP; |
| 110 | } |
117 | } |
| 111 | 118 | ||
| 112 | /** @} |
119 | /** @} |