Changes in uspace/srv/net/nil/nildummy/nildummy.c [849ed54:14f1db0] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/net/nil/nildummy/nildummy.c
r849ed54 r14f1db0 28 28 29 29 /** @addtogroup nildummy 30 * 30 * @{ 31 31 */ 32 32 33 33 /** @file 34 * 35 * 34 * Dummy network interface layer module implementation. 35 * @see nildummy.h 36 36 */ 37 37 … … 41 41 #include <stdio.h> 42 42 #include <str.h> 43 44 43 #include <ipc/ipc.h> 45 44 #include <ipc/services.h> … … 54 53 #include <adt/measured_strings.h> 55 54 #include <packet/packet.h> 56 #include <nil_module.h> 55 #include <packet_remote.h> 56 #include <nil_local.h> 57 57 58 58 #include "nildummy.h" 59 59 60 60 /** The module name. 61 */ 62 #define NAME "Dummy nil protocol" 61 * 62 */ 63 #define NAME "nildummy" 63 64 64 65 /** Default maximum transmission unit. 65 */ 66 #define NET_DEFAULT_MTU 1500 66 * 67 */ 68 #define NET_DEFAULT_MTU 1500 67 69 68 70 /** Network interface layer module global data. 69 */ 70 nildummy_globals_t nildummy_globals; 71 72 /** @name Message processing functions 73 */ 74 /*@{*/ 75 76 /** Processes IPC messages from the registered device driver modules in an infinite loop. 77 * @param[in] iid The message identifier. 78 * @param[in,out] icall The message parameters. 79 */ 80 void nildummy_receiver(ipc_callid_t iid, ipc_call_t * icall); 81 82 /** Registers new device or updates the MTU of an existing one. 83 * Determines the device local hardware address. 84 * @param[in] device_id The new device identifier. 85 * @param[in] service The device driver service. 86 * @param[in] mtu The device maximum transmission unit. 87 * @returns EOK on success. 88 * @returns EEXIST if the device with the different service exists. 89 * @returns ENOMEM if there is not enough memory left. 90 * @returns Other error codes as defined for the netif_bind_service() function. 91 * @returns Other error codes as defined for the netif_get_addr_req() function. 92 */ 93 int nildummy_device_message(device_id_t device_id, services_t service, size_t mtu); 94 95 /** Returns the device packet dimensions for sending. 96 * @param[in] device_id The device identifier. 97 * @param[out] addr_len The minimum reserved address length. 98 * @param[out] prefix The minimum reserved prefix size. 99 * @param[out] content The maximum content size. 100 * @param[out] suffix The minimum reserved suffix size. 101 * @returns EOK on success. 102 * @returns EBADMEM if either one of the parameters is NULL. 103 * @returns ENOENT if there is no such device. 104 */ 105 int nildummy_packet_space_message(device_id_t device_id, size_t * addr_len, size_t * prefix, size_t * content, size_t * suffix); 106 107 /** Registers receiving module service. 108 * Passes received packets for this service. 109 * @param[in] service The module service. 110 * @param[in] phone The service phone. 111 * @returns EOK on success. 112 * @returns ENOENT if the service is not known. 113 * @returns ENOMEM if there is not enough memory left. 114 */ 115 int nildummy_register_message(services_t service, int phone); 116 117 /** Sends the packet queue. 118 * @param[in] device_id The device identifier. 119 * @param[in] packet The packet queue. 120 * @param[in] sender The sending module service. 121 * @returns EOK on success. 122 * @returns ENOENT if there no such device. 123 * @returns EINVAL if the service parameter is not known. 124 */ 125 int nildummy_send_message(device_id_t device_id, packet_t packet, services_t sender); 126 127 /** Returns the device hardware address. 128 * @param[in] device_id The device identifier. 129 * @param[out] address The device hardware address. 130 * @returns EOK on success. 131 * @returns EBADMEM if the address parameter is NULL. 132 * @returns ENOENT if there no such device. 133 */ 134 int nildummy_addr_message(device_id_t device_id, measured_string_ref * address); 135 136 /*@}*/ 137 138 DEVICE_MAP_IMPLEMENT(nildummy_devices, nildummy_device_t) 139 140 int nil_device_state_msg(int nil_phone, device_id_t device_id, int state){ 71 * 72 */ 73 nildummy_globals_t nildummy_globals; 74 75 DEVICE_MAP_IMPLEMENT(nildummy_devices, nildummy_device_t); 76 77 int nil_device_state_msg_local(int nil_phone, device_id_t device_id, int state) 78 { 141 79 fibril_rwlock_read_lock(&nildummy_globals.protos_lock); 142 if(nildummy_globals.proto.phone){ 143 il_device_state_msg(nildummy_globals.proto.phone, device_id, state, nildummy_globals.proto.service); 144 } 80 81 if (nildummy_globals.proto.phone) 82 il_device_state_msg(nildummy_globals.proto.phone, device_id, state, 83 nildummy_globals.proto.service); 84 145 85 fibril_rwlock_read_unlock(&nildummy_globals.protos_lock); 146 return EOK; 147 } 148 149 int nil_initialize(int net_phone){ 86 87 return EOK; 88 } 89 90 int nil_initialize(int net_phone) 91 { 150 92 ERROR_DECLARE; 151 93 152 94 fibril_rwlock_initialize(&nildummy_globals.devices_lock); 153 95 fibril_rwlock_initialize(&nildummy_globals.protos_lock); 154 96 fibril_rwlock_write_lock(&nildummy_globals.devices_lock); 155 97 fibril_rwlock_write_lock(&nildummy_globals.protos_lock); 98 156 99 nildummy_globals.net_phone = net_phone; 157 100 nildummy_globals.proto.phone = 0; 158 101 ERROR_PROPAGATE(nildummy_devices_initialize(&nildummy_globals.devices)); 102 159 103 fibril_rwlock_write_unlock(&nildummy_globals.protos_lock); 160 104 fibril_rwlock_write_unlock(&nildummy_globals.devices_lock); 161 return EOK; 162 } 163 164 int nildummy_device_message(device_id_t device_id, services_t service, size_t mtu){ 105 106 return EOK; 107 } 108 109 /** Process IPC messages from the registered device driver modules in an infinite loop. 110 * 111 * @param[in] iid The message identifier. 112 * @param[in,out] icall The message parameters. 113 * 114 */ 115 static void nildummy_receiver(ipc_callid_t iid, ipc_call_t * icall){ 116 ERROR_DECLARE; 117 118 packet_t packet; 119 120 while(true){ 121 switch(IPC_GET_METHOD(*icall)){ 122 case NET_NIL_DEVICE_STATE: 123 ERROR_CODE = nil_device_state_msg_local(0, IPC_GET_DEVICE(icall), IPC_GET_STATE(icall)); 124 ipc_answer_0(iid, (ipcarg_t) ERROR_CODE); 125 break; 126 case NET_NIL_RECEIVED: 127 if(! ERROR_OCCURRED(packet_translate_remote(nildummy_globals.net_phone, &packet, IPC_GET_PACKET(icall)))){ 128 ERROR_CODE = nil_received_msg_local(0, IPC_GET_DEVICE(icall), packet, 0); 129 } 130 ipc_answer_0(iid, (ipcarg_t) ERROR_CODE); 131 break; 132 default: 133 ipc_answer_0(iid, (ipcarg_t) ENOTSUP); 134 } 135 iid = async_get_call(icall); 136 } 137 } 138 139 /** Register new device or updates the MTU of an existing one. 140 * 141 * Determine the device local hardware address. 142 * 143 * @param[in] device_id The new device identifier. 144 * @param[in] service The device driver service. 145 * @param[in] mtu The device maximum transmission unit. 146 * 147 * @returns EOK on success. 148 * @returns EEXIST if the device with the different service exists. 149 * @returns ENOMEM if there is not enough memory left. 150 * @returns Other error codes as defined for the netif_bind_service() function. 151 * @returns Other error codes as defined for the netif_get_addr_req() function. 152 * 153 */ 154 static int nildummy_device_message(device_id_t device_id, services_t service, 155 size_t mtu) 156 { 165 157 ERROR_DECLARE; 166 158 … … 228 220 return index; 229 221 } 230 printf("New device registered:\n\tid\t= %d\n\tservice\t= %d\n\tMTU\t= %d\n", device->device_id, device->service, device->mtu); 222 printf("%s: Device registered (id: %d, service: %d, mtu: %d)\n", 223 NAME, device->device_id, device->service, device->mtu); 231 224 } 232 225 fibril_rwlock_write_unlock(&nildummy_globals.devices_lock); … … 234 227 } 235 228 236 int nildummy_addr_message(device_id_t device_id, measured_string_ref * address){ 229 /** Return the device hardware address. 230 * 231 * @param[in] device_id The device identifier. 232 * @param[out] address The device hardware address. 233 * 234 * @return EOK on success. 235 * @return EBADMEM if the address parameter is NULL. 236 * @return ENOENT if there no such device. 237 * 238 */ 239 static int nildummy_addr_message(device_id_t device_id, 240 measured_string_ref *address) 241 { 237 242 nildummy_device_ref device; 238 243 … … 251 256 } 252 257 253 int nildummy_packet_space_message(device_id_t device_id, size_t * addr_len, size_t * prefix, size_t * content, size_t * suffix){ 258 /** Return the device packet dimensions for sending. 259 * 260 * @param[in] device_id The device identifier. 261 * @param[out] addr_len The minimum reserved address length. 262 * @param[out] prefix The minimum reserved prefix size. 263 * @param[out] content The maximum content size. 264 * @param[out] suffix The minimum reserved suffix size. 265 * 266 * @return EOK on success. 267 * @return EBADMEM if either one of the parameters is NULL. 268 * @return ENOENT if there is no such device. 269 * 270 */ 271 static int nildummy_packet_space_message(device_id_t device_id, 272 size_t *addr_len, size_t *prefix, size_t *content, size_t *suffix) 273 { 254 274 nildummy_device_ref device; 255 275 … … 271 291 } 272 292 273 int nil_received_msg (int nil_phone, device_id_t device_id, packet_t packet, services_t target){293 int nil_received_msg_local(int nil_phone, device_id_t device_id, packet_t packet, services_t target){ 274 294 packet_t next; 275 295 … … 286 306 } 287 307 288 int nildummy_register_message(services_t service, int phone){ 308 /** Register receiving module service. 309 * 310 * Pass received packets for this service. 311 * 312 * @param[in] service The module service. 313 * @param[in] phone The service phone. 314 * 315 * @return EOK on success. 316 * @return ENOENT if the service is not known. 317 * @return ENOMEM if there is not enough memory left. 318 * 319 */ 320 static int nildummy_register_message(services_t service, int phone) 321 { 289 322 fibril_rwlock_write_lock(&nildummy_globals.protos_lock); 290 323 nildummy_globals.proto.service = service; 291 324 nildummy_globals.proto.phone = phone; 292 printf("New protocol registered:\n\tservice\t= %d\n\tphone\t= %d\n", nildummy_globals.proto.service, nildummy_globals.proto.phone); 325 326 printf("%s: Protocol registered (service: %d, phone: %d)\n", 327 NAME, nildummy_globals.proto.service, nildummy_globals.proto.phone); 328 293 329 fibril_rwlock_write_unlock(&nildummy_globals.protos_lock); 294 330 return EOK; 295 331 } 296 332 297 int nildummy_send_message(device_id_t device_id, packet_t packet, services_t sender){ 333 /** Send the packet queue. 334 * 335 * @param[in] device_id The device identifier. 336 * @param[in] packet The packet queue. 337 * @param[in] sender The sending module service. 338 * 339 * @return EOK on success. 340 * @return ENOENT if there no such device. 341 * @return EINVAL if the service parameter is not known. 342 * 343 */ 344 static int nildummy_send_message(device_id_t device_id, packet_t packet, 345 services_t sender) 346 { 298 347 nildummy_device_ref device; 299 348 … … 312 361 } 313 362 314 int nil_message(ipc_callid_t callid, ipc_call_t * call, ipc_call_t * answer, int * answer_count){ 363 int nil_message_standalone(const char *name, ipc_callid_t callid, ipc_call_t *call, 364 ipc_call_t *answer, int *answer_count) 365 { 315 366 ERROR_DECLARE; 316 367 317 368 measured_string_ref address; 318 369 packet_t packet; … … 321 372 size_t suffix; 322 373 size_t content; 323 324 // printf("message %d - %d\n", IPC_GET_METHOD(*call), NET_NIL_FIRST); 374 325 375 *answer_count = 0; 326 switch (IPC_GET_METHOD(*call)){376 switch (IPC_GET_METHOD(*call)) { 327 377 case IPC_M_PHONE_HUNGUP: 328 378 return EOK; 329 379 case NET_NIL_DEVICE: 330 return nildummy_device_message(IPC_GET_DEVICE(call), IPC_GET_SERVICE(call), IPC_GET_MTU(call)); 380 return nildummy_device_message(IPC_GET_DEVICE(call), 381 IPC_GET_SERVICE(call), IPC_GET_MTU(call)); 331 382 case NET_NIL_SEND: 332 ERROR_PROPAGATE(packet_translate(nildummy_globals.net_phone, &packet, IPC_GET_PACKET(call))); 333 return nildummy_send_message(IPC_GET_DEVICE(call), packet, IPC_GET_SERVICE(call)); 383 ERROR_PROPAGATE(packet_translate_remote(nildummy_globals.net_phone, 384 &packet, IPC_GET_PACKET(call))); 385 return nildummy_send_message(IPC_GET_DEVICE(call), packet, 386 IPC_GET_SERVICE(call)); 334 387 case NET_NIL_PACKET_SPACE: 335 ERROR_PROPAGATE(nildummy_packet_space_message(IPC_GET_DEVICE(call), &addrlen, &prefix, &content, &suffix)); 388 ERROR_PROPAGATE(nildummy_packet_space_message(IPC_GET_DEVICE(call), 389 &addrlen, &prefix, &content, &suffix)); 336 390 IPC_SET_ADDR(answer, addrlen); 337 391 IPC_SET_PREFIX(answer, prefix); … … 341 395 return EOK; 342 396 case NET_NIL_ADDR: 343 ERROR_PROPAGATE(nildummy_addr_message(IPC_GET_DEVICE(call), &address)); 397 ERROR_PROPAGATE(nildummy_addr_message(IPC_GET_DEVICE(call), 398 &address)); 399 return measured_strings_reply(address, 1); 400 case NET_NIL_BROADCAST_ADDR: 401 ERROR_PROPAGATE(nildummy_addr_message(IPC_GET_DEVICE(call), 402 &address)); 344 403 return measured_strings_reply(address, 1); 345 404 case IPC_M_CONNECT_TO_ME: 346 return nildummy_register_message(NIL_GET_PROTO(call), IPC_GET_PHONE(call)); 347 } 405 return nildummy_register_message(NIL_GET_PROTO(call), 406 IPC_GET_PHONE(call)); 407 } 408 348 409 return ENOTSUP; 349 410 } 350 411 351 void nildummy_receiver(ipc_callid_t iid, ipc_call_t * icall){ 352 ERROR_DECLARE; 353 354 packet_t packet; 355 356 while(true){ 357 // printf("message %d - %d\n", IPC_GET_METHOD(*icall), NET_NIL_FIRST); 358 switch(IPC_GET_METHOD(*icall)){ 359 case NET_NIL_DEVICE_STATE: 360 ERROR_CODE = nil_device_state_msg(0, IPC_GET_DEVICE(icall), IPC_GET_STATE(icall)); 361 ipc_answer_0(iid, (ipcarg_t) ERROR_CODE); 362 break; 363 case NET_NIL_RECEIVED: 364 if(! ERROR_OCCURRED(packet_translate(nildummy_globals.net_phone, &packet, IPC_GET_PACKET(icall)))){ 365 ERROR_CODE = nil_received_msg(0, IPC_GET_DEVICE(icall), packet, 0); 366 } 367 ipc_answer_0(iid, (ipcarg_t) ERROR_CODE); 368 break; 369 default: 370 ipc_answer_0(iid, (ipcarg_t) ENOTSUP); 371 } 372 iid = async_get_call(icall); 373 } 374 } 375 376 #ifdef CONFIG_NETWORKING_modular 377 378 #include <nil_standalone.h> 412 #ifndef CONFIG_NETIF_NIL_BUNDLE 379 413 380 414 /** Default thread for new connections. 381 415 * 382 * @param[in] iidThe initial message identifier.383 * 384 * 385 */ 386 static void nil_client_connection(ipc_callid_t iid, ipc_call_t * 416 * @param[in] iid The initial message identifier. 417 * @param[in] icall The initial message call structure. 418 * 419 */ 420 static void nil_client_connection(ipc_callid_t iid, ipc_call_t *icall) 387 421 { 388 422 /* … … 404 438 405 439 /* Process the message */ 406 int res = nil_module_message(callid, &call, &answer, &answer_count); 440 int res = nil_module_message_standalone(NAME, callid, &call, &answer, 441 &answer_count); 407 442 408 443 /* End if said to either by the message or the processing result */ … … 415 450 } 416 451 417 /** Starts the module.418 *419 * @param argc The count of the command line arguments. Ignored parameter.420 * @param argv The command line parameters. Ignored parameter.421 *422 * @returns EOK on success.423 * @returns Other error codes as defined for each specific module start function.424 *425 */426 452 int main(int argc, char *argv[]) 427 453 { 428 454 ERROR_DECLARE; 429 455 430 /* Print the module label */431 printf("Task %d - %s\n", task_get_id(), NAME);432 433 456 /* Start the module */ 434 if (ERROR_OCCURRED(nil_module_start(nil_client_connection))) { 435 printf(" - ERROR %i\n", ERROR_CODE); 457 if (ERROR_OCCURRED(nil_module_start_standalone(nil_client_connection))) 436 458 return ERROR_CODE; 437 } 438 439 return EOK; 440 } 441 442 #endif /* CONFIG_NETWORKING_modular */ 459 460 return EOK; 461 } 462 463 #endif /* CONFIG_NETIF_NIL_BUNDLE */ 443 464 444 465 /** @}
Note:
See TracChangeset
for help on using the changeset viewer.