Rev 4075 | Rev 4192 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 4075 | Rev 4163 | ||
---|---|---|---|
Line 53... | Line 53... | ||
53 | 53 | ||
54 | #define NAME "lo - loopback interface" |
54 | #define NAME "lo - loopback interface" |
55 | 55 | ||
56 | netif_globals_t netif_globals; |
56 | netif_globals_t netif_globals; |
57 | 57 | ||
- | 58 | static struct lo_globals{ |
|
- | 59 | measured_string_ref addr; |
|
- | 60 | int mtu; |
|
- | 61 | } lo_globals; |
|
- | 62 | ||
58 | int change_state_message( device_id_t device_id, device_state_t state ); |
63 | int change_state_message( device_id_t device_id, device_state_t state ); |
59 | int create( device_id_t device_id, device_ref * device ); |
64 | int create( device_id_t device_id, device_ref * device ); |
60 | int initialize( void ); |
65 | int initialize( void ); |
61 | void netif_print_name( void ); |
66 | void netif_print_name( void ); |
62 | int probe_auto_message( void ); |
67 | int probe_auto_message( void ); |
63 | int probe_message( device_id_t device_id, int irq, int io ); |
68 | int probe_message( device_id_t device_id, int irq, int io ); |
64 | int send_message( device_id_t device_id, packet_t packet ); |
69 | int send_message( device_id_t device_id, packet_t packet ); |
65 | int start_message( device_id_t device_id ); |
70 | int start_message( device_id_t device_id ); |
66 | int stop_message( device_id_t device_id ); |
71 | int stop_message( device_id_t device_id ); |
- | 72 | measured_string_ref get_addr_message( device_id_t device_id ); |
|
- | 73 | ||
- | 74 | measured_string_ref get_addr_message( device_id_t device_id ){ |
|
- | 75 | return lo_globals.addr; |
|
- | 76 | } |
|
67 | 77 | ||
68 | int change_state_message( device_id_t device_id, device_state_t state ){ |
78 | int change_state_message( device_id_t device_id, device_state_t state ){ |
69 | ERROR_DECLARE; |
79 | ERROR_DECLARE; |
70 | 80 | ||
71 | device_ref device; |
81 | device_ref device; |
72 | 82 | ||
73 | ERROR_PROPAGATE( find_device( device_id, & device )); |
83 | ERROR_PROPAGATE( find_device( device_id, & device )); |
74 | if( device->state != state ){ |
84 | if( device->state != state ){ |
75 | device->state = state; |
85 | device->state = state; |
76 | nil_message( device, NET_NIL_DEVICE_STATE, device->state, NULL ); |
86 | nil_message( device, NET_NIL_DEVICE_STATE, device->state, NULL ); |
- | 87 | printf( "\nState changed to %s", ( state == NETIF_ACTIVE ) ? "ACTIVE" : "STOPPED" ); |
|
77 | } |
88 | } |
78 | return EOK; |
89 | return EOK; |
79 | } |
90 | } |
80 | 91 | ||
81 | int create( device_id_t device_id, device_ref * device ){ |
92 | int create( device_id_t device_id, device_ref * device ){ |
Line 89... | Line 100... | ||
89 | ( ** device ).device_id = device_id; |
100 | ( ** device ).device_id = device_id; |
90 | ( ** device ).nil_phone = -1; |
101 | ( ** device ).nil_phone = -1; |
91 | ( ** device ).specific = NULL; |
102 | ( ** device ).specific = NULL; |
92 | null_device_stats( &(( ** device ).stats )); |
103 | null_device_stats( &(( ** device ).stats )); |
93 | ( ** device ).state = NETIF_STOPPED; |
104 | ( ** device ).state = NETIF_STOPPED; |
94 | ( ** device ).flags = NULL; |
- | |
95 | ( ** device ).mtu = DEFAULT_MTU; |
- | |
96 | if( ERROR_OCCURRED( device_map_add( & netif_globals.device_map, ( ** device ).device_id, * device ))){ |
105 | if( ERROR_OCCURRED( device_map_add( & netif_globals.device_map, ( ** device ).device_id, * device ))){ |
97 | free( * device ); |
106 | free( * device ); |
98 | * device = NULL; |
107 | * device = NULL; |
99 | return ERROR_CODE; |
108 | return ERROR_CODE; |
100 | } |
109 | } |
Line 103... | Line 112... | ||
103 | } |
112 | } |
104 | 113 | ||
105 | int initialize( void ){ |
114 | int initialize( void ){ |
106 | ipcarg_t phonehash; |
115 | ipcarg_t phonehash; |
107 | 116 | ||
- | 117 | lo_globals.addr = measured_string_create_bulk( "\0\0\0\0\0\0", 0 ); |
|
- | 118 | if( ! lo_globals.addr ) return ENOMEM; |
|
108 | return REGISTER_ME( SERVICE_LO, & phonehash ); |
119 | return REGISTER_ME( SERVICE_LO, & phonehash ); |
109 | } |
120 | } |
110 | 121 | ||
111 | void netif_print_name( void ){ |
122 | void netif_print_name( void ){ |
112 | printf( NAME ); |
123 | printf( NAME ); |
Line 143... | Line 154... | ||
143 | async_wait_for( message, NULL ); |
154 | async_wait_for( message, NULL ); |
144 | return ERROR_CODE; |
155 | return ERROR_CODE; |
145 | } |
156 | } |
146 | // MTU is the first one |
157 | // MTU is the first one |
147 | if( settings && ( settings[ 0 ].value )){ |
158 | if( settings && ( settings[ 0 ].value )){ |
148 | device->mtu = strtoul( settings[ 0 ].value, NULL, 0 ); |
159 | lo_globals.mtu = strtoul( settings[ 0 ].value, NULL, 0 ); |
149 | }else{ |
160 | }else{ |
150 | device->mtu = DEFAULT_MTU; |
161 | lo_globals.mtu = DEFAULT_MTU; |
151 | } |
162 | } |
152 | // print the settings |
- | |
153 | printf("\n -MTU =\t%d", device->mtu ); |
- | |
154 | free( settings ); |
163 | free( settings ); |
155 | free( data ); |
164 | free( data ); |
156 | // end request |
165 | // end request |
157 | async_wait_for( message, NULL ); |
166 | async_wait_for( message, NULL ); |
- | 167 | // print the settings |
|
- | 168 | printf("\nNew device registered:\n\tid\t= %d\n\tMTU\t= %d", device->device_id, lo_globals.mtu ); |
|
158 | return EOK; |
169 | return EOK; |
159 | } |
170 | } |
160 | 171 | ||
161 | int send_message( device_id_t device_id, packet_t packet ){ |
172 | int send_message( device_id_t device_id, packet_t packet ){ |
162 | ERROR_DECLARE; |
173 | ERROR_DECLARE; |