u_f.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /*
  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. #ifndef __U_F_H__
  16. #define __U_F_H__
  17. #include <linux/usb/gadget.h>
  18. /* Variable Length Array Macros **********************************************/
  19. #define vla_group(groupname) size_t groupname##__next = 0
  20. #define vla_group_size(groupname) groupname##__next
  21. #define vla_item(groupname, type, name, n) \
  22. size_t groupname##_##name##__offset = ({ \
  23. size_t align_mask = __alignof__(type) - 1; \
  24. size_t offset = (groupname##__next + align_mask) & ~align_mask;\
  25. size_t size = (n) * sizeof(type); \
  26. groupname##__next = offset + size; \
  27. offset; \
  28. })
  29. #define vla_item_with_sz(groupname, type, name, n) \
  30. size_t groupname##_##name##__sz = (n) * sizeof(type); \
  31. size_t groupname##_##name##__offset = ({ \
  32. size_t align_mask = __alignof__(type) - 1; \
  33. size_t offset = (groupname##__next + align_mask) & ~align_mask;\
  34. size_t size = groupname##_##name##__sz; \
  35. groupname##__next = offset + size; \
  36. offset; \
  37. })
  38. #define vla_ptr(ptr, groupname, name) \
  39. ((void *) ((char *)ptr + groupname##_##name##__offset))
  40. struct usb_ep;
  41. struct usb_request;
  42. /**
  43. * alloc_ep_req - returns a usb_request allocated by the gadget driver and
  44. * allocates the request's buffer.
  45. *
  46. * @ep: the endpoint to allocate a usb_request
  47. * @len: usb_requests's buffer suggested size
  48. * @default_len: used if @len is not provided, ie, is 0
  49. *
  50. * In case @ep direction is OUT, the @len will be aligned to ep's
  51. * wMaxPacketSize. In order to avoid memory leaks or drops, *always* use
  52. * usb_requests's length (req->length) to refer to the allocated buffer size.
  53. * Requests allocated via alloc_ep_req() *must* be freed by free_ep_req().
  54. */
  55. struct usb_request *alloc_ep_req(struct usb_ep *ep, size_t len, int default_len);
  56. /* Frees a usb_request previously allocated by alloc_ep_req() */
  57. static inline void free_ep_req(struct usb_ep *ep, struct usb_request *req)
  58. {
  59. kfree(req->buf);
  60. usb_ep_free_request(ep, req);
  61. }
  62. #endif /* __U_F_H__ */