blob: 69a1d10df04f7cd66f19f8e479358f8b7e486d60 [file] [log] [blame]
Andrzej Pietrasiewicz1efd54e2013-11-07 08:41:26 +01001/*
2 * u_f.h
3 *
4 * Utility definitions for USB functions
5 *
6 * Copyright (c) 2013 Samsung Electronics Co., Ltd.
7 * http://www.samsung.com
8 *
9 * Author: Andrzej Pietrasiewicz <andrzej.p@samsung.com>
10 *
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License version 2 as
13 * published by the Free Software Foundation.
14 */
15
16#ifndef __U_F_H__
17#define __U_F_H__
18
Felipe F. Tonello079fe5a2015-11-10 17:52:05 +000019#include <linux/usb/gadget.h>
20
Andrzej Pietrasiewicz74d48462014-05-08 14:06:21 +020021/* Variable Length Array Macros **********************************************/
22#define vla_group(groupname) size_t groupname##__next = 0
23#define vla_group_size(groupname) groupname##__next
24
25#define vla_item(groupname, type, name, n) \
26 size_t groupname##_##name##__offset = ({ \
27 size_t align_mask = __alignof__(type) - 1; \
28 size_t offset = (groupname##__next + align_mask) & ~align_mask;\
29 size_t size = (n) * sizeof(type); \
30 groupname##__next = offset + size; \
31 offset; \
32 })
33
34#define vla_item_with_sz(groupname, type, name, n) \
35 size_t groupname##_##name##__sz = (n) * sizeof(type); \
36 size_t groupname##_##name##__offset = ({ \
37 size_t align_mask = __alignof__(type) - 1; \
38 size_t offset = (groupname##__next + align_mask) & ~align_mask;\
39 size_t size = groupname##_##name##__sz; \
40 groupname##__next = offset + size; \
41 offset; \
42 })
43
44#define vla_ptr(ptr, groupname, name) \
45 ((void *) ((char *)ptr + groupname##_##name##__offset))
46
Andrzej Pietrasiewicz1efd54e2013-11-07 08:41:26 +010047struct usb_ep;
48struct usb_request;
49
Felipe F. Tonelloe0466152016-08-08 21:30:06 +010050/**
51 * alloc_ep_req - returns a usb_request allocated by the gadget driver and
52 * allocates the request's buffer.
53 *
54 * @ep: the endpoint to allocate a usb_request
55 * @len: usb_requests's buffer suggested size
56 * @default_len: used if @len is not provided, ie, is 0
57 *
58 * In case @ep direction is OUT, the @len will be aligned to ep's
59 * wMaxPacketSize. In order to avoid memory leaks or drops, *always* use
60 * usb_requests's length (req->length) to refer to the allocated buffer size.
61 * Requests allocated via alloc_ep_req() *must* be freed by free_ep_req().
62 */
Felipe F. Tonello69bb9972016-08-08 21:30:05 +010063struct usb_request *alloc_ep_req(struct usb_ep *ep, size_t len, int default_len);
Felipe F. Tonelloe0466152016-08-08 21:30:06 +010064
65/* Frees a usb_request previously allocated by alloc_ep_req() */
Felipe F. Tonello079fe5a2015-11-10 17:52:05 +000066static inline void free_ep_req(struct usb_ep *ep, struct usb_request *req)
67{
68 kfree(req->buf);
69 usb_ep_free_request(ep, req);
70}
Andrzej Pietrasiewicz1efd54e2013-11-07 08:41:26 +010071
72#endif /* __U_F_H__ */