Changes in uspace/srv/devman/main.c [124c061:1f383dde] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/srv/devman/main.c
r124c061 r1f383dde 281 281 * handle. 282 282 */ 283 devmap_device_register_with_iface(devmap_pathname, 284 &cli->devmap_handle, DEVMAN_CONNECT_FROM_DEVMAP); 283 devmap_device_register(devmap_pathname, &cli->devmap_handle); 285 284 286 285 /* … … 478 477 } 479 478 480 printf(NAME ": devman_forward: forward connection to device %s to "481 "driver %s.\n", dev->pathname, driver->name);479 // printf(NAME ": devman_forward: forward connection to device %s to " 480 // "driver %s.\n", dev->pathname, driver->name); 482 481 ipc_forward_fast(iid, driver->phone, method, dev->handle, 0, IPC_FF_NONE); 483 482 } … … 487 486 static void devman_connection_devmapper(ipc_callid_t iid, ipc_call_t *icall) 488 487 { 489 devmap_handle_t devmap_handle = IPC_GET_ ARG2(*icall);488 devmap_handle_t devmap_handle = IPC_GET_IMETHOD(*icall); 490 489 node_t *dev; 491 490 … … 504 503 } 505 504 505 printf(NAME ": devman_connection_devmapper: forward connection to " 506 "device %s to driver %s.\n", dev->pathname, dev->drv->name); 506 507 ipc_forward_fast(iid, dev->drv->phone, DRIVER_CLIENT, dev->handle, 0, 507 508 IPC_FF_NONE); 508 printf(NAME ": devman_connection_devmapper: forwarded connection to "509 "device %s to driver %s.\n", dev->pathname, dev->drv->name);510 509 } 511 510 … … 513 512 static void devman_connection(ipc_callid_t iid, ipc_call_t *icall) 514 513 { 514 /* 515 * Silly hack to enable the device manager to register as a driver by 516 * the device mapper. If the ipc method is not IPC_M_CONNECT_ME_TO, this 517 * is not the forwarded connection from naming service, so it must be a 518 * connection from the devmapper which thinks this is a devmapper-style 519 * driver. So pretend this is a devmapper-style driver. (This does not 520 * work for device with handle == IPC_M_CONNECT_ME_TO, because devmapper 521 * passes device handle to the driver as an ipc method.) 522 */ 523 if (IPC_GET_IMETHOD(*icall) != IPC_M_CONNECT_ME_TO) 524 devman_connection_devmapper(iid, icall); 525 526 /* 527 * ipc method is IPC_M_CONNECT_ME_TO, so this is forwarded connection 528 * from naming service by which we registered as device manager, so be 529 * device manager. 530 */ 531 515 532 /* Select interface. */ 516 533 switch ((sysarg_t) (IPC_GET_ARG1(*icall))) { … … 525 542 devman_forward(iid, icall, false); 526 543 break; 527 case DEVMAN_CONNECT_FROM_DEVMAP:528 /* Someone connected through devmap node. */529 devman_connection_devmapper(iid, icall);530 break;531 544 case DEVMAN_CONNECT_TO_PARENTS_DEVICE: 532 545 /* Connect client to selected device. */ … … 586 599 587 600 /* Register device manager at naming service. */ 588 if (ipc_connect_to_me(PHONE_NS, SERVICE_DEVMAN, 0, 0, NULL, NULL) != 0) 601 sysarg_t phonead; 602 if (ipc_connect_to_me(PHONE_NS, SERVICE_DEVMAN, 0, 0, &phonead) != 0) 589 603 return -1; 590 604
Note:
See TracChangeset
for help on using the changeset viewer.