source: mainline/uspace/lib/usbvirt/src/device.c@ 79ae36dd

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 79ae36dd was 79ae36dd, checked in by Martin Decky <martin@…>, 14 years ago

new async framework with integrated exchange tracking

  • strict isolation between low-level IPC and high-level async framework with integrated exchange tracking
    • each IPC connection is represented by an async_sess_t structure
    • each IPC exchange is represented by an async_exch_t structure
    • exchange management is either based on atomic messages (EXCHANGE_ATOMIC), locking (EXCHANGE_SERIALIZE) or connection cloning (EXCHANGE_CLONE)
  • async_obsolete: temporary compatibility layer to keep old async clients working (several pieces of code are currently broken, but only non-essential functionality)
  • IPC_M_PHONE_HANGUP is now method no. 0 (for elegant boolean evaluation)
  • IPC_M_DEBUG_ALL has been renamed to IPC_M_DEBUG
  • IPC_M_PING has been removed (VFS protocol now has VFS_IN_PING)
  • console routines in libc have been rewritten for better abstraction
  • additional use for libc-private header files (FILE structure opaque to the client)
  • various cstyle changes (typos, indentation, missing externs in header files, improved comments, etc.)
  • Property mode set to 100644
File size: 3.3 KB
Line 
1/*
2 * Copyright (c) 2011 Vojtech Horky
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup libusbvirt
30 * @{
31 */
32/** @file
33 * Virtual USB device main routines.
34 */
35#include <errno.h>
36#include <str.h>
37#include <stdio.h>
38#include <assert.h>
39#include <async.h>
40#include <devman.h>
41#include <usbvirt/device.h>
42#include <usbvirt/ipc.h>
43
44#include <usb/debug.h>
45
46/** Current device. */
47static usbvirt_device_t *DEV = NULL;
48
49/** Main IPC call handling from virtual host controller.
50 *
51 * @param iid Caller identification.
52 * @param icall Initial incoming call.
53 */
54static void callback_connection(ipc_callid_t iid, ipc_call_t *icall)
55{
56 assert(DEV != NULL);
57
58 async_answer_0(iid, EOK);
59
60 while (true) {
61 ipc_callid_t callid;
62 ipc_call_t call;
63
64 callid = async_get_call(&call);
65 bool processed = usbvirt_ipc_handle_call(DEV, callid, &call);
66 if (!processed) {
67 if (!IPC_GET_IMETHOD(call)) {
68 async_answer_0(callid, EOK);
69 return;
70 } else
71 async_answer_0(callid, EINVAL);
72 }
73 }
74}
75
76/** Connect the device to the virtual host controller.
77 *
78 * @param dev The virtual device to be (virtually) plugged in.
79 * @param vhc_path Devman path to the virtual host controller.
80 * @return Error code.
81 */
82int usbvirt_device_plug(usbvirt_device_t *dev, const char *vhc_path)
83{
84 if (DEV != NULL)
85 return ELIMIT;
86
87 devman_handle_t handle;
88 int rc = devman_device_get_handle(vhc_path, &handle, 0);
89 if (rc != EOK)
90 return rc;
91
92 async_sess_t *hcd_sess =
93 devman_device_connect(EXCHANGE_SERIALIZE, handle, 0);
94 if (!hcd_sess)
95 return ENOMEM;
96
97 DEV = dev;
98 dev->vhc_sess = hcd_sess;
99
100 async_exch_t *exch = async_exchange_begin(hcd_sess);
101 rc = async_connect_to_me(exch, 0, 0, 0, callback_connection);
102 async_exchange_end(exch);
103
104 if (rc != EOK)
105 DEV = NULL;
106
107 return rc;
108}
109
110/** Disconnect the device from virtual host controller.
111 *
112 * @param dev Device to be disconnected.
113 */
114void usbvirt_device_unplug(usbvirt_device_t *dev)
115{
116 async_hangup(dev->vhc_sess);
117}
118
119/**
120 * @}
121 */
Note: See TracBrowser for help on using the repository browser.