Lines Matching refs:urbs
127 up(&unode->dev->urbs.limit_sem);
146 urb->transfer_buffer_length = udl->urbs.size; /* reset to actual */
148 spin_lock_irqsave(&udl->urbs.lock, flags);
149 list_add_tail(&unode->entry, &udl->urbs.list);
150 udl->urbs.available++;
151 spin_unlock_irqrestore(&udl->urbs.lock, flags);
162 up(&udl->urbs.limit_sem);
168 int count = udl->urbs.count;
173 DRM_DEBUG("Waiting for completes and freeing all render urbs\n");
177 down(&udl->urbs.limit_sem);
179 spin_lock_irq(&udl->urbs.lock);
181 node = udl->urbs.list.next; /* have reserved one with sem */
184 spin_unlock_irq(&udl->urbs.lock);
190 usb_free_coherent(urb->dev, udl->urbs.size,
195 udl->urbs.count = 0;
206 spin_lock_init(&udl->urbs.lock);
209 udl->urbs.size = size;
210 INIT_LIST_HEAD(&udl->urbs.list);
212 sema_init(&udl->urbs.limit_sem, 0);
213 udl->urbs.count = 0;
214 udl->urbs.available = 0;
216 while (udl->urbs.count * size < wanted_size) {
250 list_add_tail(&unode->entry, &udl->urbs.list);
252 up(&udl->urbs.limit_sem);
253 udl->urbs.count++;
254 udl->urbs.available++;
257 DRM_DEBUG("allocated %d %d byte urbs\n", udl->urbs.count, (int) size);
259 return udl->urbs.count;
271 ret = down_timeout(&udl->urbs.limit_sem, GET_URB_TIMEOUT);
274 ret, udl->urbs.available);
278 spin_lock_irq(&udl->urbs.lock);
280 BUG_ON(list_empty(&udl->urbs.list)); /* reserved one with limit_sem */
281 entry = udl->urbs.list.next;
283 udl->urbs.available--;
285 spin_unlock_irq(&udl->urbs.lock);
299 BUG_ON(len > udl->urbs.size);
347 if (udl->urbs.count)