Changeset 8fb1bf82 in mainline for uspace/srv/net/netif/lo/lo.c
- Timestamp:
- 2010-11-25T13:42:50Z (14 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 8df8415
- Parents:
- a93d79a (diff), eb667613 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/net/netif/lo/lo.c
ra93d79a r8fb1bf82 28 28 29 29 /** @addtogroup lo 30 * 30 * @{ 31 31 */ 32 32 33 33 /** @file 34 * 34 * Loopback network interface implementation. 35 35 */ 36 36 37 37 #include <async.h> 38 38 #include <errno.h> 39 #include <err.h>40 39 #include <stdio.h> 41 40 #include <str.h> … … 53 52 #include <netif_local.h> 54 53 55 /** Default hardware address. 56 */ 54 /** Default hardware address. */ 57 55 #define DEFAULT_ADDR "\0\0\0\0\0\0" 58 56 59 /** Default address length. 60 */ 57 /** Default address length. */ 61 58 #define DEFAULT_ADDR_LEN (sizeof(DEFAULT_ADDR) / sizeof(char)) 62 59 63 /** Loopback module name. 64 */ 60 /** Loopback module name. */ 65 61 #define NAME "lo" 66 62 67 /** Network interface global data. 68 */ 63 /** Network interface global data. */ 69 64 netif_globals_t netif_globals; 70 65 71 /** Changes the loopback state. 72 * @param[in] device The device structure. 73 * @param[in] state The new device state. 74 * @returns The new state if changed. 75 * @returns EOK otherwise. 76 */ 77 int change_state_message(netif_device_t * device, device_state_t state); 78 79 /** Creates and returns the loopback network interface structure. 80 * @param[in] device_id The new devce identifier. 81 * @param[out] device The device structure. 82 * @returns EOK on success. 83 * @returns EXDEV if one loopback network interface already exists. 84 * @returns ENOMEM if there is not enough memory left. 85 */ 86 int create(device_id_t device_id, netif_device_t * * device); 87 88 int netif_specific_message(ipc_callid_t callid, ipc_call_t * call, ipc_call_t * answer, int * answer_count){ 66 int netif_specific_message(ipc_callid_t callid, ipc_call_t *call, 67 ipc_call_t *answer, int *answer_count) 68 { 89 69 return ENOTSUP; 90 70 } 91 71 92 int netif_get_addr_message(device_id_t device_id, measured_string_ref address){ 93 if(! address){ 72 int netif_get_addr_message(device_id_t device_id, measured_string_t *address) 73 { 74 if (!address) 94 75 return EBADMEM; 95 } 76 96 77 address->value = str_dup(DEFAULT_ADDR); 97 78 address->length = DEFAULT_ADDR_LEN; 98 return EOK; 99 } 100 101 int netif_get_device_stats(device_id_t device_id, device_stats_ref stats){ 102 ERROR_DECLARE; 103 104 netif_device_t * device; 105 106 if(! stats){ 79 80 return EOK; 81 } 82 83 int netif_get_device_stats(device_id_t device_id, device_stats_t *stats) 84 { 85 netif_device_t *device; 86 int rc; 87 88 if (!stats) 107 89 return EBADMEM; 108 } 109 ERROR_PROPAGATE(find_device(device_id, &device)); 110 memcpy(stats, (device_stats_ref) device->specific, sizeof(device_stats_t)); 111 return EOK; 112 } 113 114 int change_state_message(netif_device_t * device, device_state_t state) 90 91 rc = find_device(device_id, &device); 92 if (rc != EOK) 93 return rc; 94 95 memcpy(stats, (device_stats_t *) device->specific, 96 sizeof(device_stats_t)); 97 98 return EOK; 99 } 100 101 /** Changes the loopback state. 102 * 103 * @param[in] device The device structure. 104 * @param[in] state The new device state. 105 * @return The new state if changed. 106 * @return EOK otherwise. 107 */ 108 static int change_state_message(netif_device_t *device, device_state_t state) 115 109 { 116 110 if (device->state != state) { … … 126 120 } 127 121 128 int create(device_id_t device_id, netif_device_t * * device){ 122 /** Creates and returns the loopback network interface structure. 123 * 124 * @param[in] device_id The new devce identifier. 125 * @param[out] device The device structure. 126 * @return EOK on success. 127 * @return EXDEV if one loopback network interface already exists. 128 * @return ENOMEM if there is not enough memory left. 129 */ 130 static int create(device_id_t device_id, netif_device_t **device) 131 { 129 132 int index; 130 133 131 if (netif_device_map_count(&netif_globals.device_map) > 0){134 if (netif_device_map_count(&netif_globals.device_map) > 0) 132 135 return EXDEV; 133 }else{ 134 *device = (netif_device_t *) malloc(sizeof(netif_device_t)); 135 if(!(*device)){ 136 return ENOMEM; 137 } 138 (** device).specific = malloc(sizeof(device_stats_t)); 139 if(! (** device).specific){ 140 free(*device); 141 return ENOMEM; 142 } 143 null_device_stats((device_stats_ref)(** device).specific); 144 (** device).device_id = device_id; 145 (** device).nil_phone = -1; 146 (** device).state = NETIF_STOPPED; 147 index = netif_device_map_add(&netif_globals.device_map, (** device).device_id, * device); 148 if(index < 0){ 149 free(*device); 150 free((** device).specific); 151 *device = NULL; 152 return index; 153 } 154 } 155 return EOK; 156 } 157 158 int netif_initialize(void){ 136 137 *device = (netif_device_t *) malloc(sizeof(netif_device_t)); 138 if (!*device) 139 return ENOMEM; 140 141 (*device)->specific = (device_stats_t *) malloc(sizeof(device_stats_t)); 142 if (!(*device)->specific) { 143 free(*device); 144 return ENOMEM; 145 } 146 147 null_device_stats((device_stats_t *) (*device)->specific); 148 (*device)->device_id = device_id; 149 (*device)->nil_phone = -1; 150 (*device)->state = NETIF_STOPPED; 151 index = netif_device_map_add(&netif_globals.device_map, 152 (*device)->device_id, *device); 153 154 if (index < 0) { 155 free(*device); 156 free((*device)->specific); 157 *device = NULL; 158 return index; 159 } 160 161 return EOK; 162 } 163 164 int netif_initialize(void) 165 { 159 166 ipcarg_t phonehash; 160 167 … … 162 169 } 163 170 164 int netif_probe_message(device_id_t device_id, int irq, uintptr_t io){ 165 ERROR_DECLARE; 166 167 netif_device_t * device; 168 169 // create a new device 170 ERROR_PROPAGATE(create(device_id, &device)); 171 // print the settings 171 int netif_probe_message(device_id_t device_id, int irq, uintptr_t io) 172 { 173 netif_device_t *device; 174 int rc; 175 176 /* Create a new device */ 177 rc = create(device_id, &device); 178 if (rc != EOK) 179 return rc; 180 181 /* Print the settings */ 172 182 printf("%s: Device created (id: %d)\n", NAME, device->device_id); 173 return EOK; 174 } 175 176 int netif_send_message(device_id_t device_id, packet_t packet, services_t sender){ 177 ERROR_DECLARE; 178 179 netif_device_t * 183 184 return EOK; 185 } 186 187 int netif_send_message(device_id_t device_id, packet_t *packet, services_t sender) 188 { 189 netif_device_t *device; 180 190 size_t length; 181 packet_t next;191 packet_t *next; 182 192 int phone; 183 184 ERROR_PROPAGATE(find_device(device_id, &device)); 185 if(device->state != NETIF_ACTIVE){ 193 int rc; 194 195 rc = find_device(device_id, &device); 196 if (rc != EOK) 197 return EOK; 198 199 if (device->state != NETIF_ACTIVE) { 186 200 netif_pq_release(packet_get_id(packet)); 187 201 return EFORWARD; 188 202 } 203 189 204 next = packet; 190 do {191 ++ ((device_stats_ref) device->specific)->send_packets;192 ++ ((device_stats_ref) device->specific)->receive_packets;205 do { 206 ((device_stats_t *) device->specific)->send_packets++; 207 ((device_stats_t *) device->specific)->receive_packets++; 193 208 length = packet_get_data_length(next); 194 ((device_stats_ ref) device->specific)->send_bytes += length;195 ((device_stats_ ref) device->specific)->receive_bytes += length;209 ((device_stats_t *) device->specific)->send_bytes += length; 210 ((device_stats_t *) device->specific)->receive_bytes += length; 196 211 next = pq_next(next); 197 }while(next); 212 } while(next); 213 198 214 phone = device->nil_phone; 199 215 fibril_rwlock_write_unlock(&netif_globals.lock); 200 216 nil_received_msg(phone, device_id, packet, sender); 201 217 fibril_rwlock_write_lock(&netif_globals.lock); 202 return EOK; 203 } 204 205 int netif_start_message(netif_device_t * device){ 218 219 return EOK; 220 } 221 222 int netif_start_message(netif_device_t *device) 223 { 206 224 return change_state_message(device, NETIF_ACTIVE); 207 225 } 208 226 209 int netif_stop_message(netif_device_t * device){ 227 int netif_stop_message(netif_device_t *device) 228 { 210 229 return change_state_message(device, NETIF_STOPPED); 211 230 } … … 213 232 /** Default thread for new connections. 214 233 * 215 * @param[in] iid The initial message identifier. 216 * @param[in] icall The initial message call structure. 217 * 234 * @param[in] iid The initial message identifier. 235 * @param[in] icall The initial message call structure. 218 236 */ 219 237 static void netif_client_connection(ipc_callid_t iid, ipc_call_t *icall) … … 225 243 ipc_answer_0(iid, EOK); 226 244 227 while (true) {245 while (true) { 228 246 ipc_call_t answer; 229 247 int answer_count; … … 240 258 &answer_count); 241 259 242 /* End if said to either by the message or the processing result */ 243 if ((IPC_GET_METHOD(call) == IPC_M_PHONE_HUNGUP) || (res == EHANGUP)) 260 /* 261 * End if told to either by the message or the processing 262 * result. 263 */ 264 if ((IPC_GET_METHOD(call) == IPC_M_PHONE_HUNGUP) || 265 (res == EHANGUP)) 244 266 return; 245 267 … … 251 273 int main(int argc, char *argv[]) 252 274 { 253 ERROR_DECLARE;275 int rc; 254 276 255 277 /* Start the module */ 256 if (ERROR_OCCURRED(netif_module_start(netif_client_connection))) 257 return ERROR_CODE; 258 259 return EOK; 278 rc = netif_module_start(netif_client_connection); 279 return rc; 260 280 } 261 281
Note:
See TracChangeset
for help on using the changeset viewer.