source: mainline/uspace/lib/usbhost/src/batch.c@ c4fb5ecd

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since c4fb5ecd was c4fb5ecd, checked in by Vojtech Horky <vojtechhorky@…>, 14 years ago

Less logging in USB host controller drivers

Many of the debug messages were degraded to debug2 level or
completely removed. Also added formatting string for unified
dump of USB transfer batches.

Warnings in EHCI stub use debug level now.

  • Property mode set to 100644
File size: 5.7 KB
Line 
1/*
2 * Copyright (c) 2011 Jan Vesely
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/** @addtogroup libusbhost
29 * @{
30 */
31/** @file
32 * USB transfer transaction structures (implementation).
33 */
34#include <errno.h>
35#include <str_error.h>
36
37#include <usb/usb.h>
38#include <usb/debug.h>
39#include <usb/host/batch.h>
40
41void usb_transfer_batch_call_in(usb_transfer_batch_t *instance);
42void usb_transfer_batch_call_out(usb_transfer_batch_t *instance);
43
44void usb_transfer_batch_init(
45 usb_transfer_batch_t *instance,
46 endpoint_t *ep,
47 char *buffer,
48 char *data_buffer,
49 size_t buffer_size,
50 char *setup_buffer,
51 size_t setup_size,
52 usbhc_iface_transfer_in_callback_t func_in,
53 usbhc_iface_transfer_out_callback_t func_out,
54 void *arg,
55 ddf_fun_t *fun,
56 void *private_data,
57 void (*private_data_dtor)(void *p_data)
58 )
59{
60 assert(instance);
61 link_initialize(&instance->link);
62 instance->ep = ep;
63 instance->callback_in = func_in;
64 instance->callback_out = func_out;
65 instance->arg = arg;
66 instance->buffer = buffer;
67 instance->data_buffer = data_buffer;
68 instance->buffer_size = buffer_size;
69 instance->setup_buffer = setup_buffer;
70 instance->setup_size = setup_size;
71 instance->fun = fun;
72 instance->private_data = private_data;
73 instance->private_data_dtor = private_data_dtor;
74 instance->transfered_size = 0;
75 instance->next_step = NULL;
76 instance->error = EOK;
77 endpoint_use(instance->ep);
78}
79/*----------------------------------------------------------------------------*/
80/** Helper function, calls callback and correctly destroys batch structure.
81 *
82 * @param[in] instance Batch structure to use.
83 */
84void usb_transfer_batch_call_in_and_dispose(usb_transfer_batch_t *instance)
85{
86 assert(instance);
87 usb_transfer_batch_call_in(instance);
88 usb_transfer_batch_dispose(instance);
89}
90/*----------------------------------------------------------------------------*/
91/** Helper function calls callback and correctly destroys batch structure.
92 *
93 * @param[in] instance Batch structure to use.
94 */
95void usb_transfer_batch_call_out_and_dispose(usb_transfer_batch_t *instance)
96{
97 assert(instance);
98 usb_transfer_batch_call_out(instance);
99 usb_transfer_batch_dispose(instance);
100}
101/*----------------------------------------------------------------------------*/
102/** Mark batch as finished and continue with next step.
103 *
104 * @param[in] instance Batch structure to use.
105 *
106 */
107void usb_transfer_batch_finish(usb_transfer_batch_t *instance)
108{
109 assert(instance);
110 assert(instance->ep);
111 endpoint_release(instance->ep);
112 instance->next_step(instance);
113}
114/*----------------------------------------------------------------------------*/
115/** Prepare data, get error status and call callback in.
116 *
117 * @param[in] instance Batch structure to use.
118 * Copies data from transport buffer, and calls callback with appropriate
119 * parameters.
120 */
121void usb_transfer_batch_call_in(usb_transfer_batch_t *instance)
122{
123 assert(instance);
124 assert(instance->callback_in);
125 assert(instance->ep);
126
127 /* We are data in, we need data */
128 memcpy(instance->buffer, instance->data_buffer, instance->buffer_size);
129
130 usb_log_debug("Batch %p " USB_TRANSFER_BATCH_FMT " completed (%zuB): %s.\n",
131 instance, USB_TRANSFER_BATCH_ARGS(*instance),
132 instance->transfered_size, str_error(instance->error));
133
134 instance->callback_in(instance->fun, instance->error,
135 instance->transfered_size, instance->arg);
136}
137/*----------------------------------------------------------------------------*/
138/** Get error status and call callback out.
139 *
140 * @param[in] instance Batch structure to use.
141 */
142void usb_transfer_batch_call_out(usb_transfer_batch_t *instance)
143{
144 assert(instance);
145 assert(instance->callback_out);
146
147 usb_log_debug("Batch %p " USB_TRANSFER_BATCH_FMT " completed: %s.\n",
148 instance, USB_TRANSFER_BATCH_ARGS(*instance),
149 str_error(instance->error));
150
151 instance->callback_out(instance->fun,
152 instance->error, instance->arg);
153}
154/*----------------------------------------------------------------------------*/
155/** Correctly dispose all used data structures.
156 *
157 * @param[in] instance Batch structure to use.
158 */
159void usb_transfer_batch_dispose(usb_transfer_batch_t *instance)
160{
161 assert(instance);
162 usb_log_debug2("Batch %p " USB_TRANSFER_BATCH_FMT " disposing.\n",
163 instance, USB_TRANSFER_BATCH_ARGS(*instance));
164 if (instance->private_data) {
165 assert(instance->private_data_dtor);
166 instance->private_data_dtor(instance->private_data);
167 }
168 free(instance);
169}
170/**
171 * @}
172 */
Note: See TracBrowser for help on using the repository browser.