Changeset 8b1e15ac in mainline for uspace/lib
- Timestamp:
- 2011-02-11T22:26:36Z (15 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 68414f4a
- Parents:
- 1b367b4
- Location:
- uspace/lib
- Files:
-
- 10 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/c/generic/devman.c
r1b367b4 r8b1e15ac 158 158 } 159 159 160 int devman_child_device_register(const char *name, match_id_list_t *match_ids, 161 devman_handle_t parent_handle, devman_handle_t *handle) 160 /** Add function to a device. 161 * 162 * Request devman to add a new function to the specified device owned by 163 * this driver task. 164 * 165 * @param name Name of the new function 166 * @param ftype Function type, fun_inner or fun_exposed 167 * @param match_ids Match IDs (should be empty for fun_exposed) 168 * @param devh Devman handle of the device 169 * @param funh Place to store handle of the new function 170 * 171 * @return EOK on success or negative error code. 172 */ 173 int devman_add_function(const char *name, fun_type_t ftype, 174 match_id_list_t *match_ids, devman_handle_t devh, devman_handle_t *funh) 162 175 { 163 176 int phone = devman_get_phone(DEVMAN_DRIVER, IPC_FLAG_BLOCKING); 177 int fun_handle; 164 178 165 179 if (phone < 0) … … 168 182 async_serialize_start(); 169 183 170 int match_count = list_count(&match_ids->ids); 171 ipc_call_t answer; 172 aid_t req = async_send_2(phone, DEVMAN_ADD_CHILD_DEVICE, parent_handle, match_count, 173 &answer); 184 int match_count = list_count(&match_ids->ids); 185 ipc_call_t answer; 186 187 aid_t req = async_send_3(phone, DEVMAN_ADD_FUNCTION, (sysarg_t) ftype, 188 devh, match_count, &answer); 174 189 175 190 sysarg_t retval = async_data_write_start(phone, name, str_size(name)); … … 186 201 async_serialize_end(); 187 202 188 if (retval != EOK) { 189 if (handle != NULL) 190 *handle = -1; 191 192 return retval; 193 } 194 195 if (handle != NULL) 196 *handle = (int) IPC_GET_ARG1(answer); 197 203 if (retval == EOK) 204 fun_handle = (int) IPC_GET_ARG1(answer); 205 else 206 fun_handle = -1; 207 208 *funh = fun_handle; 209 198 210 return retval; 199 211 } -
uspace/lib/c/include/devman.h
r1b367b4 r8b1e15ac 45 45 46 46 extern int devman_driver_register(const char *, async_client_conn_t); 47 extern int devman_ child_device_register(const char *, match_id_list_t *,47 extern int devman_add_function(const char *, fun_type_t, match_id_list_t *, 48 48 devman_handle_t, devman_handle_t *); 49 49 -
uspace/lib/c/include/ipc/devman.h
r1b367b4 r8b1e15ac 42 42 43 43 typedef sysarg_t devman_handle_t; 44 45 typedef enum { 46 /** Invalid value for debugging purposes */ 47 fun_invalid = 0, 48 /** Function to which child devices attach */ 49 fun_inner, 50 /** Fuction exported to external clients (leaf function) */ 51 fun_exposed 52 } fun_type_t; 44 53 45 54 /** Ids of device models used for device-to-driver matching. … … 127 136 typedef enum { 128 137 DEVMAN_DRIVER_REGISTER = IPC_FIRST_USER_METHOD, 129 DEVMAN_ADD_ CHILD_DEVICE,138 DEVMAN_ADD_FUNCTION, 130 139 DEVMAN_ADD_MATCH_ID, 131 140 DEVMAN_ADD_DEVICE_TO_CLASS -
uspace/lib/drv/generic/driver.c
r1b367b4 r8b1e15ac 59 59 60 60 /** Devices */ 61 LIST_INITIALIZE( devices);62 FIBRIL_MUTEX_INITIALIZE( devices_mutex);61 LIST_INITIALIZE(functions); 62 FIBRIL_MUTEX_INITIALIZE(functions_mutex); 63 63 64 64 /** Interrupts */ … … 209 209 } 210 210 211 static void add_to_devices_list(device_t *dev) 212 { 213 fibril_mutex_lock(&devices_mutex); 214 list_append(&dev->link, &devices); 215 fibril_mutex_unlock(&devices_mutex); 216 } 217 218 static void remove_from_devices_list(device_t *dev) 219 { 220 fibril_mutex_lock(&devices_mutex); 221 list_remove(&dev->link); 222 fibril_mutex_unlock(&devices_mutex); 223 } 224 225 static device_t *driver_get_device(link_t *devices, devman_handle_t handle) 226 { 227 device_t *dev = NULL; 228 229 fibril_mutex_lock(&devices_mutex); 230 link_t *link = devices->next; 231 232 while (link != devices) { 233 dev = list_get_instance(link, device_t, link); 234 if (dev->handle == handle) { 235 fibril_mutex_unlock(&devices_mutex); 236 return dev; 211 static void add_to_functions_list(function_t *fun) 212 { 213 fibril_mutex_lock(&functions_mutex); 214 list_append(&fun->link, &functions); 215 fibril_mutex_unlock(&functions_mutex); 216 } 217 218 static void remove_from_functions_list(function_t *fun) 219 { 220 fibril_mutex_lock(&functions_mutex); 221 list_remove(&fun->link); 222 fibril_mutex_unlock(&functions_mutex); 223 } 224 225 static function_t *driver_get_function(link_t *functions, devman_handle_t handle) 226 { 227 function_t *fun = NULL; 228 printf("driver_get_function handle=%" PRIun "\n", handle); 229 230 fibril_mutex_lock(&functions_mutex); 231 link_t *link = functions->next; 232 233 while (link != functions) { 234 fun = list_get_instance(link, function_t, link); 235 printf(" - fun handle %" PRIun "\n", fun->handle); 236 if (fun->handle == handle) { 237 fibril_mutex_unlock(&functions_mutex); 238 return fun; 237 239 } 240 238 241 link = link->next; 239 242 } 240 243 241 fibril_mutex_unlock(& devices_mutex);244 fibril_mutex_unlock(&functions_mutex); 242 245 243 246 return NULL; … … 250 253 251 254 devman_handle_t dev_handle = IPC_GET_ARG1(*icall); 252 devman_handle_t parent_ dev_handle = IPC_GET_ARG2(*icall);255 devman_handle_t parent_fun_handle = IPC_GET_ARG2(*icall); 253 256 254 257 device_t *dev = create_device(); 255 258 dev->handle = dev_handle; 256 259 257 260 async_data_write_accept((void **) &dev_name, true, 0, 0, 0, 0); 258 261 dev->name = dev_name; 259 260 add_to_devices_list(dev); 261 dev->parent = driver_get_device(&devices, parent_dev_handle); 262 263 /* 264 * Currently not used, parent fun handle is stored in context 265 * of the connection to the parent device driver. 266 */ 267 (void) parent_fun_handle; 262 268 263 269 res = driver->driver_ops->add_device(dev); … … 268 274 printf("%s: failed to add a new device with handle = %" PRIun ".\n", 269 275 driver->name, dev_handle); 270 remove_from_devices_list(dev);271 276 delete_device(dev); 272 277 } … … 311 316 */ 312 317 devman_handle_t handle = IPC_GET_ARG2(*icall); 313 device_t *dev = driver_get_device(&devices, handle);314 315 if ( dev== NULL) {316 printf("%s: driver_connection_gen error - no devicewith handle"318 function_t *fun = driver_get_function(&functions, handle); 319 320 if (fun == NULL) { 321 printf("%s: driver_connection_gen error - no function with handle" 317 322 " %" PRIun " was found.\n", driver->name, handle); 318 323 async_answer_0(iid, ENOENT); … … 327 332 328 333 int ret = EOK; 329 /* open the device*/330 if ( dev->ops != NULL && dev->ops->open != NULL)331 ret = (* dev->ops->open)(dev);334 /* Open device function */ 335 if (fun->ops != NULL && fun->ops->open != NULL) 336 ret = (*fun->ops->open)(fun); 332 337 333 338 async_answer_0(iid, ret); … … 344 349 switch (method) { 345 350 case IPC_M_PHONE_HUNGUP: 346 /* close the device*/347 if ( dev->ops != NULL && dev->ops->close != NULL)348 (* dev->ops->close)(dev);351 /* Close device function */ 352 if (fun->ops != NULL && fun->ops->close != NULL) 353 (*fun->ops->close)(fun); 349 354 async_answer_0(callid, EOK); 350 355 return; … … 356 361 if (!is_valid_iface_idx(iface_idx)) { 357 362 remote_handler_t *default_handler = 358 device_get_default_handler(dev);363 function_get_default_handler(fun); 359 364 if (default_handler != NULL) { 360 (*default_handler)( dev, callid, &call);365 (*default_handler)(fun, callid, &call); 361 366 break; 362 367 } 368 363 369 /* 364 * This is not device's interface and the370 * Function has no such interface and 365 371 * default handler is not provided. 366 372 */ … … 372 378 } 373 379 374 /* calling one of the device's interfaces */380 /* calling one of the function's interfaces */ 375 381 376 382 /* Get the interface ops structure. */ 377 void *ops = device_get_ops(dev, iface_idx);383 void *ops = function_get_ops(fun, iface_idx); 378 384 if (ops == NULL) { 379 385 printf("%s: driver_connection_gen error - ", 380 386 driver->name); 381 printf(" devicewith handle %" PRIun " has no interface "387 printf("Function with handle %" PRIun " has no interface " 382 388 "with id %d.\n", handle, iface_idx); 383 389 async_answer_0(callid, ENOTSUP); … … 408 414 * receive parameters from the remote client and it will 409 415 * pass it to the corresponding local interface method 410 * associated with the deviceby its driver.416 * associated with the function by its driver. 411 417 */ 412 (*iface_method_ptr)( dev, ops, callid, &call);418 (*iface_method_ptr)(fun, ops, callid, &call); 413 419 break; 414 420 } … … 425 431 driver_connection_gen(iid, icall, false); 426 432 } 427 428 433 429 434 /** Function for handling connections to device driver. */ … … 456 461 device_t *create_device(void) 457 462 { 458 device_t *dev = malloc(sizeof(device_t));459 460 if (dev != NULL) {461 memset(dev, 0, sizeof(device_t));462 init_match_ids(&dev->match_ids);463 } 464 463 device_t *dev; 464 465 dev = malloc(sizeof(device_t)); 466 if (dev == NULL) 467 return NULL; 468 469 memset(dev, 0, sizeof(device_t)); 465 470 return dev; 466 471 } 467 472 473 /** Create new function structure. 474 * 475 * @return The device structure. 476 */ 477 function_t *create_function(void) 478 { 479 function_t *fun; 480 481 fun = malloc(sizeof(function_t)); 482 if (fun == NULL) 483 return NULL; 484 485 memset(fun, 0, sizeof(device_t)); 486 487 init_match_ids(&fun->match_ids); 488 link_initialize(&fun->link); 489 490 return fun; 491 } 492 468 493 /** Delete device structure. 469 494 * … … 472 497 void delete_device(device_t *dev) 473 498 { 474 clean_match_ids(&dev->match_ids);475 if (dev->name != NULL)476 free(dev->name);477 499 free(dev); 478 500 } 479 501 480 void *device_get_ops(device_t *dev, dev_inferface_idx_t idx) 502 /** Delete device structure. 503 * 504 * @param dev The device structure. 505 */ 506 void delete_function(function_t *fun) 507 { 508 clean_match_ids(&fun->match_ids); 509 if (fun->name != NULL) 510 free(fun->name); 511 free(fun); 512 } 513 514 void *function_get_ops(function_t *fun, dev_inferface_idx_t idx) 481 515 { 482 516 assert(is_valid_iface_idx(idx)); 483 if ( dev->ops == NULL)517 if (fun->ops == NULL) 484 518 return NULL; 485 return dev->ops->interfaces[idx];486 } 487 488 int child_device_register(device_t *child, device_t *parent)489 { 490 assert( child->name != NULL);519 return fun->ops->interfaces[idx]; 520 } 521 522 int register_function(function_t *fun, device_t *dev) 523 { 524 assert(fun->name != NULL); 491 525 492 526 int res; 493 527 494 add_to_devices_list(child); 495 res = devman_child_device_register(child->name, &child->match_ids, 496 parent->handle, &child->handle); 528 fun->dev = dev; 529 530 add_to_functions_list(fun); 531 res = devman_add_function(fun->name, fun->ftype, &fun->match_ids, 532 dev->handle, &fun->handle); 497 533 if (res != EOK) { 498 remove_from_ devices_list(child);534 remove_from_functions_list(fun); 499 535 return res; 500 536 } … … 511 547 * @return Error code. 512 548 */ 513 int child_device_register_wrapper(device_t *parent, const char *child_name,514 const char * child_match_id, int child_match_score)515 { 516 device_t *child= NULL;517 match_id_t *m atch_id = NULL;549 int register_function_wrapper(device_t *dev, const char *fun_name, 550 const char *match_id, int match_score) 551 { 552 function_t *fun = NULL; 553 match_id_t *m_id = NULL; 518 554 int rc; 519 555 520 child = create_device();521 if ( child== NULL) {556 fun = create_function(); 557 if (fun == NULL) { 522 558 rc = ENOMEM; 523 559 goto failure; 524 560 } 525 561 526 child->name = child_name; 527 528 match_id = create_match_id(); 529 if (match_id == NULL) { 562 fun->dev = dev; 563 fun->name = fun_name; 564 fun->ftype = fun_inner; 565 566 m_id = create_match_id(); 567 if (m_id == NULL) { 530 568 rc = ENOMEM; 531 569 goto failure; 532 570 } 533 571 534 m atch_id->id = child_match_id;535 m atch_id->score = child_match_score;536 add_match_id(& child->match_ids, match_id);537 538 rc = child_device_register(child, parent);572 m_id->id = match_id; 573 m_id->score = match_score; 574 add_match_id(&fun->match_ids, m_id); 575 576 rc = register_function(fun, dev); 539 577 if (rc != EOK) 540 578 goto failure; … … 543 581 544 582 failure: 545 if (m atch_id != NULL) {546 m atch_id->id = NULL;547 delete_match_id(m atch_id);548 } 549 550 if ( child!= NULL) {551 child->name = NULL;552 delete_ device(child);583 if (m_id != NULL) { 584 m_id->id = NULL; 585 delete_match_id(m_id); 586 } 587 588 if (fun != NULL) { 589 fun->name = NULL; 590 delete_function(fun); 553 591 } 554 592 … … 557 595 558 596 /** Get default handler for client requests */ 559 remote_handler_t * device_get_default_handler(device_t *dev)560 { 561 if ( dev->ops == NULL)597 remote_handler_t *function_get_default_handler(function_t *fun) 598 { 599 if (fun->ops == NULL) 562 600 return NULL; 563 return dev->ops->default_handler;564 } 565 566 int add_ device_to_class(device_t *dev, const char *class_name)567 { 568 return devman_add_device_to_class( dev->handle, class_name);601 return fun->ops->default_handler; 602 } 603 604 int add_function_to_class(function_t *fun, const char *class_name) 605 { 606 return devman_add_device_to_class(fun->handle, class_name); 569 607 } 570 608 -
uspace/lib/drv/generic/remote_char_dev.c
r1b367b4 r8b1e15ac 41 41 #define MAX_CHAR_RW_COUNT 256 42 42 43 static void remote_char_read( device_t *, void *, ipc_callid_t, ipc_call_t *);44 static void remote_char_write( device_t *, void *, ipc_callid_t, ipc_call_t *);43 static void remote_char_read(function_t *, void *, ipc_callid_t, ipc_call_t *); 44 static void remote_char_write(function_t *, void *, ipc_callid_t, ipc_call_t *); 45 45 46 46 /** Remote character interface operations. */ … … 67 67 * local interface to the remote client. 68 68 * 69 * @param dev The devicefrom which the data are read.69 * @param fun The function from which the data are read. 70 70 * @param ops The local ops structure. 71 71 */ 72 72 static void 73 remote_char_read( device_t *dev, void *ops, ipc_callid_t callid,73 remote_char_read(function_t *fun, void *ops, ipc_callid_t callid, 74 74 ipc_call_t *call) 75 75 { … … 94 94 95 95 char buf[MAX_CHAR_RW_COUNT]; 96 int ret = (*char_dev_ops->read)( dev, buf, len);96 int ret = (*char_dev_ops->read)(fun, buf, len); 97 97 98 98 if (ret < 0) { … … 114 114 * local interface to the remote client. 115 115 * 116 * @param dev The deviceto which the data are written.116 * @param fun The function to which the data are written. 117 117 * @param ops The local ops structure. 118 118 */ 119 119 static void 120 remote_char_write( device_t *dev, void *ops, ipc_callid_t callid,120 remote_char_write(function_t *fun, void *ops, ipc_callid_t callid, 121 121 ipc_call_t *call) 122 122 { … … 144 144 async_data_write_finalize(cid, buf, len); 145 145 146 int ret = (*char_dev_ops->write)( dev, buf, len);146 int ret = (*char_dev_ops->write)(fun, buf, len); 147 147 if (ret < 0) { 148 148 /* Some error occured. */ -
uspace/lib/drv/generic/remote_hw_res.c
r1b367b4 r8b1e15ac 39 39 #include "driver.h" 40 40 41 static void remote_hw_res_get_resource_list( device_t *, void *, ipc_callid_t,41 static void remote_hw_res_get_resource_list(function_t *, void *, ipc_callid_t, 42 42 ipc_call_t *); 43 static void remote_hw_res_enable_interrupt( device_t *, void *, ipc_callid_t,43 static void remote_hw_res_enable_interrupt(function_t *, void *, ipc_callid_t, 44 44 ipc_call_t *); 45 45 … … 55 55 }; 56 56 57 static void remote_hw_res_enable_interrupt( device_t *dev, void *ops,57 static void remote_hw_res_enable_interrupt(function_t *fun, void *ops, 58 58 ipc_callid_t callid, ipc_call_t *call) 59 59 { … … 62 62 if (hw_res_ops->enable_interrupt == NULL) 63 63 async_answer_0(callid, ENOTSUP); 64 else if (hw_res_ops->enable_interrupt( dev))64 else if (hw_res_ops->enable_interrupt(fun)) 65 65 async_answer_0(callid, EOK); 66 66 else … … 68 68 } 69 69 70 static void remote_hw_res_get_resource_list( device_t *dev, void *ops,70 static void remote_hw_res_get_resource_list(function_t *fun, void *ops, 71 71 ipc_callid_t callid, ipc_call_t *call) 72 72 { … … 78 78 } 79 79 80 hw_resource_list_t *hw_resources = hw_res_ops->get_resource_list( dev);80 hw_resource_list_t *hw_resources = hw_res_ops->get_resource_list(fun); 81 81 if (hw_resources == NULL){ 82 82 async_answer_0(callid, ENOENT); -
uspace/lib/drv/include/dev_iface.h
r1b367b4 r8b1e15ac 43 43 */ 44 44 45 struct device;45 struct function; 46 46 47 47 /* … … 49 49 * devices driver. 50 50 */ 51 typedef void remote_iface_func_t(struct device*, void *, ipc_callid_t,51 typedef void remote_iface_func_t(struct function *, void *, ipc_callid_t, 52 52 ipc_call_t *); 53 53 typedef remote_iface_func_t *remote_iface_func_ptr_t; 54 typedef void remote_handler_t(struct device*, ipc_callid_t, ipc_call_t *);54 typedef void remote_handler_t(struct function *, ipc_callid_t, ipc_call_t *); 55 55 56 56 typedef struct { -
uspace/lib/drv/include/driver.h
r1b367b4 r8b1e15ac 52 52 typedef struct device device_t; 53 53 54 struct function; 55 typedef struct function function_t; 56 54 57 /* 55 58 * Device class … … 62 65 * device. 63 66 */ 64 int (*open)( device_t *);67 int (*open)(function_t *); 65 68 66 69 /** … … 68 71 * the device. 69 72 */ 70 void (*close)( device_t *);73 void (*close)(function_t *); 71 74 72 75 /** The table of standard interfaces implemented by the device. */ … … 100 103 int parent_phone; 101 104 102 /** Parent device if handled by this driver, NULL otherwise */103 device_t *parent;104 105 /** Device name */ 105 106 const char *name; 106 /** List of device ids for device-to-driver matching */ 107 match_id_list_t match_ids; 107 108 108 /** Driver-specific data associated with this device */ 109 109 void *driver_data; 110 /** The implementation of operations provided by this device */ 110 111 /** Link in the list of devices handled by the driver */ 112 link_t link; 113 }; 114 115 /** Function structure */ 116 struct function { 117 /** Function indentifier (asigned by device manager) */ 118 devman_handle_t handle; 119 120 /** Device which this function belogs to */ 121 device_t *dev; 122 123 /** Function type */ 124 fun_type_t ftype; 125 /** Function name */ 126 const char *name; 127 /** List of device ids for driver matching */ 128 match_id_list_t match_ids; 129 /** Driver-specific data associated with this function */ 130 void *driver_data; 131 /** Implementation of operations provided by this function */ 111 132 device_ops_t *ops; 112 133 113 /** Link in the list of devices handled by the driver */134 /** Link in the list of functions handled by the driver */ 114 135 link_t link; 115 136 }; … … 142 163 extern device_t *create_device(void); 143 164 extern void delete_device(device_t *); 144 extern void *device_get_ops(device_t *, dev_inferface_idx_t); 145 146 extern int child_device_register(device_t *, device_t *); 147 extern int child_device_register_wrapper(device_t *, const char *, const char *, 165 extern function_t *create_function(void); 166 extern void delete_function(function_t *); 167 extern void *function_get_ops(function_t *, dev_inferface_idx_t); 168 169 extern int register_function(function_t *, device_t *); 170 extern int register_function_wrapper(device_t *, const char *, const char *, 148 171 int); 149 172 … … 184 207 extern int unregister_interrupt_handler(device_t *, int); 185 208 186 extern remote_handler_t * device_get_default_handler(device_t *);187 extern int add_ device_to_class(device_t *, const char *);209 extern remote_handler_t *function_get_default_handler(function_t *); 210 extern int add_function_to_class(function_t *fun, const char *class_name); 188 211 189 212 #endif -
uspace/lib/drv/include/ops/char_dev.h
r1b367b4 r8b1e15ac 39 39 40 40 typedef struct { 41 int (*read)( device_t *, char *, size_t);42 int (*write)( device_t *, char *, size_t);41 int (*read)(function_t *, char *, size_t); 42 int (*write)(function_t *, char *, size_t); 43 43 } char_dev_ops_t; 44 44 -
uspace/lib/drv/include/ops/hw_res.h
r1b367b4 r8b1e15ac 42 42 43 43 typedef struct { 44 hw_resource_list_t *(*get_resource_list)( device_t *);45 bool (*enable_interrupt)( device_t *);44 hw_resource_list_t *(*get_resource_list)(function_t *); 45 bool (*enable_interrupt)(function_t *); 46 46 } hw_res_ops_t; 47 47
Note:
See TracChangeset
for help on using the changeset viewer.