blob: 98610e4595de65e26aab9e8c8becfd06000d3908 [file] [log] [blame]
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001/*
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002 * f_fs.c -- user mode file system API for USB composite function controllers
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02003 *
4 * Copyright (C) 2010 Samsung Electronics
Michal Nazarewicz54b83602012-01-13 15:05:16 +01005 * Author: Michal Nazarewicz <mina86@mina86.com>
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02006 *
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01007 * Based on inode.c (GadgetFS) which was:
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02008 * Copyright (C) 2003-2004 David Brownell
9 * Copyright (C) 2003 Agilent Technologies
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 as published by
13 * the Free Software Foundation; either version 2 of the License, or
14 * (at your option) any later version.
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020015 */
16
17
18/* #define DEBUG */
19/* #define VERBOSE_DEBUG */
20
21#include <linux/blkdev.h>
Randy Dunlapb0608692010-05-10 10:51:36 -070022#include <linux/pagemap.h>
Paul Gortmakerf940fcd2011-05-27 09:56:31 -040023#include <linux/export.h>
Koen Beel560f1182012-05-30 20:43:37 +020024#include <linux/hid.h>
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +010025#include <linux/module.h>
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020026#include <asm/unaligned.h>
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020027
28#include <linux/usb/composite.h>
29#include <linux/usb/functionfs.h>
30
Robert Baldyga2e4c7552014-02-10 10:42:44 +010031#include <linux/aio.h>
32#include <linux/mmu_context.h>
Robert Baldyga23de91e2014-02-10 10:42:43 +010033#include <linux/poll.h>
Robert Baldyga5e33f6f2015-01-23 13:41:01 +010034#include <linux/eventfd.h>
Robert Baldyga23de91e2014-02-10 10:42:43 +010035
Andrzej Pietrasiewicze72c39c2013-12-03 15:15:31 +010036#include "u_fs.h"
Andrzej Pietrasiewicz74d48462014-05-08 14:06:21 +020037#include "u_f.h"
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +020038#include "u_os_desc.h"
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +010039#include "configfs.h"
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020040
41#define FUNCTIONFS_MAGIC 0xa647361 /* Chosen by a honest dice roll ;) */
42
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020043/* Reference counter handling */
44static void ffs_data_get(struct ffs_data *ffs);
45static void ffs_data_put(struct ffs_data *ffs);
46/* Creates new ffs_data object. */
47static struct ffs_data *__must_check ffs_data_new(void) __attribute__((malloc));
48
49/* Opened counter handling. */
50static void ffs_data_opened(struct ffs_data *ffs);
51static void ffs_data_closed(struct ffs_data *ffs);
52
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +010053/* Called with ffs->mutex held; take over ownership of data. */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020054static int __must_check
55__ffs_data_got_descs(struct ffs_data *ffs, char *data, size_t len);
56static int __must_check
57__ffs_data_got_strings(struct ffs_data *ffs, char *data, size_t len);
58
59
60/* The function structure ***************************************************/
61
62struct ffs_ep;
63
64struct ffs_function {
65 struct usb_configuration *conf;
66 struct usb_gadget *gadget;
67 struct ffs_data *ffs;
68
69 struct ffs_ep *eps;
70 u8 eps_revmap[16];
71 short *interfaces_nums;
72
73 struct usb_function function;
74};
75
76
77static struct ffs_function *ffs_func_from_usb(struct usb_function *f)
78{
79 return container_of(f, struct ffs_function, function);
80}
81
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020082
Michal Nazarewicza7ecf052014-02-10 10:42:41 +010083static inline enum ffs_setup_state
84ffs_setup_state_clear_cancelled(struct ffs_data *ffs)
85{
86 return (enum ffs_setup_state)
87 cmpxchg(&ffs->setup_state, FFS_SETUP_CANCELLED, FFS_NO_SETUP);
88}
89
90
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020091static void ffs_func_eps_disable(struct ffs_function *func);
92static int __must_check ffs_func_eps_enable(struct ffs_function *func);
93
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020094static int ffs_func_bind(struct usb_configuration *,
95 struct usb_function *);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +020096static int ffs_func_set_alt(struct usb_function *, unsigned, unsigned);
97static void ffs_func_disable(struct usb_function *);
98static int ffs_func_setup(struct usb_function *,
99 const struct usb_ctrlrequest *);
100static void ffs_func_suspend(struct usb_function *);
101static void ffs_func_resume(struct usb_function *);
102
103
104static int ffs_func_revmap_ep(struct ffs_function *func, u8 num);
105static int ffs_func_revmap_intf(struct ffs_function *func, u8 intf);
106
107
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200108/* The endpoints structures *************************************************/
109
110struct ffs_ep {
111 struct usb_ep *ep; /* P: ffs->eps_lock */
112 struct usb_request *req; /* P: epfile->mutex */
113
Manu Gautam8d4e8972014-02-28 16:50:22 +0530114 /* [0]: full speed, [1]: high speed, [2]: super speed */
115 struct usb_endpoint_descriptor *descs[3];
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200116
117 u8 num;
118
119 int status; /* P: epfile->mutex */
120};
121
122struct ffs_epfile {
123 /* Protects ep->ep and ep->req. */
124 struct mutex mutex;
125 wait_queue_head_t wait;
126
127 struct ffs_data *ffs;
128 struct ffs_ep *ep; /* P: ffs->eps_lock */
129
130 struct dentry *dentry;
131
132 char name[5];
133
134 unsigned char in; /* P: ffs->eps_lock */
135 unsigned char isoc; /* P: ffs->eps_lock */
136
137 unsigned char _pad;
138};
139
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100140/* ffs_io_data structure ***************************************************/
141
142struct ffs_io_data {
143 bool aio;
144 bool read;
145
146 struct kiocb *kiocb;
Al Viroc993c392015-01-31 23:23:35 -0500147 struct iov_iter data;
148 const void *to_free;
149 char *buf;
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100150
151 struct mm_struct *mm;
152 struct work_struct work;
153
154 struct usb_ep *ep;
155 struct usb_request *req;
Robert Baldyga5e33f6f2015-01-23 13:41:01 +0100156
157 struct ffs_data *ffs;
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100158};
159
Robert Baldyga6d5c1c72014-08-25 11:16:27 +0200160struct ffs_desc_helper {
161 struct ffs_data *ffs;
162 unsigned interfaces_count;
163 unsigned eps_count;
164};
165
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200166static int __must_check ffs_epfiles_create(struct ffs_data *ffs);
167static void ffs_epfiles_destroy(struct ffs_epfile *epfiles, unsigned count);
168
Al Viro1bb27ca2014-09-03 13:32:19 -0400169static struct dentry *
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200170ffs_sb_create_file(struct super_block *sb, const char *name, void *data,
Al Viro1bb27ca2014-09-03 13:32:19 -0400171 const struct file_operations *fops);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200172
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +0100173/* Devices management *******************************************************/
174
175DEFINE_MUTEX(ffs_lock);
Felipe Balbi0700faa2014-04-01 13:19:32 -0500176EXPORT_SYMBOL_GPL(ffs_lock);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +0100177
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +0100178static struct ffs_dev *_ffs_find_dev(const char *name);
179static struct ffs_dev *_ffs_alloc_dev(void);
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +0100180static int _ffs_name_dev(struct ffs_dev *dev, const char *name);
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +0100181static void _ffs_free_dev(struct ffs_dev *dev);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +0100182static void *ffs_acquire_dev(const char *dev_name);
183static void ffs_release_dev(struct ffs_data *ffs_data);
184static int ffs_ready(struct ffs_data *ffs);
185static void ffs_closed(struct ffs_data *ffs);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200186
187/* Misc helper functions ****************************************************/
188
189static int ffs_mutex_lock(struct mutex *mutex, unsigned nonblock)
190 __attribute__((warn_unused_result, nonnull));
Al Viro260ef312012-09-26 21:43:45 -0400191static char *ffs_prepare_buffer(const char __user *buf, size_t len)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200192 __attribute__((warn_unused_result, nonnull));
193
194
195/* Control file aka ep0 *****************************************************/
196
197static void ffs_ep0_complete(struct usb_ep *ep, struct usb_request *req)
198{
199 struct ffs_data *ffs = req->context;
200
201 complete_all(&ffs->ep0req_completion);
202}
203
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200204static int __ffs_ep0_queue_wait(struct ffs_data *ffs, char *data, size_t len)
205{
206 struct usb_request *req = ffs->ep0req;
207 int ret;
208
209 req->zero = len < le16_to_cpu(ffs->ev.setup.wLength);
210
211 spin_unlock_irq(&ffs->ev.waitq.lock);
212
213 req->buf = data;
214 req->length = len;
215
Marek Szyprowskice1fd352011-01-28 13:55:36 +0100216 /*
217 * UDC layer requires to provide a buffer even for ZLP, but should
218 * not use it at all. Let's provide some poisoned pointer to catch
219 * possible bug in the driver.
220 */
221 if (req->buf == NULL)
222 req->buf = (void *)0xDEADBABE;
223
Wolfram Sang16735d02013-11-14 14:32:02 -0800224 reinit_completion(&ffs->ep0req_completion);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200225
226 ret = usb_ep_queue(ffs->gadget->ep0, req, GFP_ATOMIC);
227 if (unlikely(ret < 0))
228 return ret;
229
230 ret = wait_for_completion_interruptible(&ffs->ep0req_completion);
231 if (unlikely(ret)) {
232 usb_ep_dequeue(ffs->gadget->ep0, req);
233 return -EINTR;
234 }
235
236 ffs->setup_state = FFS_NO_SETUP;
Robert Baldyga0a7b1f82014-02-10 10:42:42 +0100237 return req->status ? req->status : req->actual;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200238}
239
240static int __ffs_ep0_stall(struct ffs_data *ffs)
241{
242 if (ffs->ev.can_stall) {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +0100243 pr_vdebug("ep0 stall\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200244 usb_ep_set_halt(ffs->gadget->ep0);
245 ffs->setup_state = FFS_NO_SETUP;
246 return -EL2HLT;
247 } else {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +0100248 pr_debug("bogus ep0 stall!\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200249 return -ESRCH;
250 }
251}
252
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200253static ssize_t ffs_ep0_write(struct file *file, const char __user *buf,
254 size_t len, loff_t *ptr)
255{
256 struct ffs_data *ffs = file->private_data;
257 ssize_t ret;
258 char *data;
259
260 ENTER();
261
262 /* Fast check if setup was canceled */
Michal Nazarewicza7ecf052014-02-10 10:42:41 +0100263 if (ffs_setup_state_clear_cancelled(ffs) == FFS_SETUP_CANCELLED)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200264 return -EIDRM;
265
266 /* Acquire mutex */
267 ret = ffs_mutex_lock(&ffs->mutex, file->f_flags & O_NONBLOCK);
268 if (unlikely(ret < 0))
269 return ret;
270
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200271 /* Check state */
272 switch (ffs->state) {
273 case FFS_READ_DESCRIPTORS:
274 case FFS_READ_STRINGS:
275 /* Copy data */
276 if (unlikely(len < 16)) {
277 ret = -EINVAL;
278 break;
279 }
280
281 data = ffs_prepare_buffer(buf, len);
Tobias Klauser537baab2010-12-09 15:52:39 +0100282 if (IS_ERR(data)) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200283 ret = PTR_ERR(data);
284 break;
285 }
286
287 /* Handle data */
288 if (ffs->state == FFS_READ_DESCRIPTORS) {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +0100289 pr_info("read descriptors\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200290 ret = __ffs_data_got_descs(ffs, data, len);
291 if (unlikely(ret < 0))
292 break;
293
294 ffs->state = FFS_READ_STRINGS;
295 ret = len;
296 } else {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +0100297 pr_info("read strings\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200298 ret = __ffs_data_got_strings(ffs, data, len);
299 if (unlikely(ret < 0))
300 break;
301
302 ret = ffs_epfiles_create(ffs);
303 if (unlikely(ret)) {
304 ffs->state = FFS_CLOSING;
305 break;
306 }
307
308 ffs->state = FFS_ACTIVE;
309 mutex_unlock(&ffs->mutex);
310
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +0100311 ret = ffs_ready(ffs);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200312 if (unlikely(ret < 0)) {
313 ffs->state = FFS_CLOSING;
314 return ret;
315 }
316
317 set_bit(FFS_FL_CALL_CLOSED_CALLBACK, &ffs->flags);
318 return len;
319 }
320 break;
321
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200322 case FFS_ACTIVE:
323 data = NULL;
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +0100324 /*
325 * We're called from user space, we can use _irq
326 * rather then _irqsave
327 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200328 spin_lock_irq(&ffs->ev.waitq.lock);
Michal Nazarewicza7ecf052014-02-10 10:42:41 +0100329 switch (ffs_setup_state_clear_cancelled(ffs)) {
Michal Nazarewicze46318a2014-02-10 10:42:40 +0100330 case FFS_SETUP_CANCELLED:
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200331 ret = -EIDRM;
332 goto done_spin;
333
334 case FFS_NO_SETUP:
335 ret = -ESRCH;
336 goto done_spin;
337
338 case FFS_SETUP_PENDING:
339 break;
340 }
341
342 /* FFS_SETUP_PENDING */
343 if (!(ffs->ev.setup.bRequestType & USB_DIR_IN)) {
344 spin_unlock_irq(&ffs->ev.waitq.lock);
345 ret = __ffs_ep0_stall(ffs);
346 break;
347 }
348
349 /* FFS_SETUP_PENDING and not stall */
350 len = min(len, (size_t)le16_to_cpu(ffs->ev.setup.wLength));
351
352 spin_unlock_irq(&ffs->ev.waitq.lock);
353
354 data = ffs_prepare_buffer(buf, len);
Tobias Klauser537baab2010-12-09 15:52:39 +0100355 if (IS_ERR(data)) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200356 ret = PTR_ERR(data);
357 break;
358 }
359
360 spin_lock_irq(&ffs->ev.waitq.lock);
361
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +0100362 /*
363 * We are guaranteed to be still in FFS_ACTIVE state
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200364 * but the state of setup could have changed from
Michal Nazarewicze46318a2014-02-10 10:42:40 +0100365 * FFS_SETUP_PENDING to FFS_SETUP_CANCELLED so we need
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200366 * to check for that. If that happened we copied data
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +0100367 * from user space in vain but it's unlikely.
368 *
369 * For sure we are not in FFS_NO_SETUP since this is
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200370 * the only place FFS_SETUP_PENDING -> FFS_NO_SETUP
371 * transition can be performed and it's protected by
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +0100372 * mutex.
373 */
Michal Nazarewicza7ecf052014-02-10 10:42:41 +0100374 if (ffs_setup_state_clear_cancelled(ffs) ==
375 FFS_SETUP_CANCELLED) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200376 ret = -EIDRM;
377done_spin:
378 spin_unlock_irq(&ffs->ev.waitq.lock);
379 } else {
380 /* unlocks spinlock */
381 ret = __ffs_ep0_queue_wait(ffs, data, len);
382 }
383 kfree(data);
384 break;
385
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200386 default:
387 ret = -EBADFD;
388 break;
389 }
390
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200391 mutex_unlock(&ffs->mutex);
392 return ret;
393}
394
Michal Nazarewicz67913bb2014-09-10 17:50:24 +0200395/* Called with ffs->ev.waitq.lock and ffs->mutex held, both released on exit. */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200396static ssize_t __ffs_ep0_read_events(struct ffs_data *ffs, char __user *buf,
397 size_t n)
398{
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +0100399 /*
Michal Nazarewicz67913bb2014-09-10 17:50:24 +0200400 * n cannot be bigger than ffs->ev.count, which cannot be bigger than
401 * size of ffs->ev.types array (which is four) so that's how much space
402 * we reserve.
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +0100403 */
Michal Nazarewicz67913bb2014-09-10 17:50:24 +0200404 struct usb_functionfs_event events[ARRAY_SIZE(ffs->ev.types)];
405 const size_t size = n * sizeof *events;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200406 unsigned i = 0;
407
Michal Nazarewicz67913bb2014-09-10 17:50:24 +0200408 memset(events, 0, size);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200409
410 do {
411 events[i].type = ffs->ev.types[i];
412 if (events[i].type == FUNCTIONFS_SETUP) {
413 events[i].u.setup = ffs->ev.setup;
414 ffs->setup_state = FFS_SETUP_PENDING;
415 }
416 } while (++i < n);
417
Michal Nazarewicz67913bb2014-09-10 17:50:24 +0200418 ffs->ev.count -= n;
419 if (ffs->ev.count)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200420 memmove(ffs->ev.types, ffs->ev.types + n,
421 ffs->ev.count * sizeof *ffs->ev.types);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200422
423 spin_unlock_irq(&ffs->ev.waitq.lock);
424 mutex_unlock(&ffs->mutex);
425
Michal Nazarewicz67913bb2014-09-10 17:50:24 +0200426 return unlikely(__copy_to_user(buf, events, size)) ? -EFAULT : size;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200427}
428
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200429static ssize_t ffs_ep0_read(struct file *file, char __user *buf,
430 size_t len, loff_t *ptr)
431{
432 struct ffs_data *ffs = file->private_data;
433 char *data = NULL;
434 size_t n;
435 int ret;
436
437 ENTER();
438
439 /* Fast check if setup was canceled */
Michal Nazarewicza7ecf052014-02-10 10:42:41 +0100440 if (ffs_setup_state_clear_cancelled(ffs) == FFS_SETUP_CANCELLED)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200441 return -EIDRM;
442
443 /* Acquire mutex */
444 ret = ffs_mutex_lock(&ffs->mutex, file->f_flags & O_NONBLOCK);
445 if (unlikely(ret < 0))
446 return ret;
447
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200448 /* Check state */
449 if (ffs->state != FFS_ACTIVE) {
450 ret = -EBADFD;
451 goto done_mutex;
452 }
453
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +0100454 /*
455 * We're called from user space, we can use _irq rather then
456 * _irqsave
457 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200458 spin_lock_irq(&ffs->ev.waitq.lock);
459
Michal Nazarewicza7ecf052014-02-10 10:42:41 +0100460 switch (ffs_setup_state_clear_cancelled(ffs)) {
Michal Nazarewicze46318a2014-02-10 10:42:40 +0100461 case FFS_SETUP_CANCELLED:
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200462 ret = -EIDRM;
463 break;
464
465 case FFS_NO_SETUP:
466 n = len / sizeof(struct usb_functionfs_event);
467 if (unlikely(!n)) {
468 ret = -EINVAL;
469 break;
470 }
471
472 if ((file->f_flags & O_NONBLOCK) && !ffs->ev.count) {
473 ret = -EAGAIN;
474 break;
475 }
476
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +0100477 if (wait_event_interruptible_exclusive_locked_irq(ffs->ev.waitq,
478 ffs->ev.count)) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200479 ret = -EINTR;
480 break;
481 }
482
483 return __ffs_ep0_read_events(ffs, buf,
484 min(n, (size_t)ffs->ev.count));
485
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200486 case FFS_SETUP_PENDING:
487 if (ffs->ev.setup.bRequestType & USB_DIR_IN) {
488 spin_unlock_irq(&ffs->ev.waitq.lock);
489 ret = __ffs_ep0_stall(ffs);
490 goto done_mutex;
491 }
492
493 len = min(len, (size_t)le16_to_cpu(ffs->ev.setup.wLength));
494
495 spin_unlock_irq(&ffs->ev.waitq.lock);
496
497 if (likely(len)) {
498 data = kmalloc(len, GFP_KERNEL);
499 if (unlikely(!data)) {
500 ret = -ENOMEM;
501 goto done_mutex;
502 }
503 }
504
505 spin_lock_irq(&ffs->ev.waitq.lock);
506
507 /* See ffs_ep0_write() */
Michal Nazarewicza7ecf052014-02-10 10:42:41 +0100508 if (ffs_setup_state_clear_cancelled(ffs) ==
509 FFS_SETUP_CANCELLED) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200510 ret = -EIDRM;
511 break;
512 }
513
514 /* unlocks spinlock */
515 ret = __ffs_ep0_queue_wait(ffs, data, len);
516 if (likely(ret > 0) && unlikely(__copy_to_user(buf, data, len)))
517 ret = -EFAULT;
518 goto done_mutex;
519
520 default:
521 ret = -EBADFD;
522 break;
523 }
524
525 spin_unlock_irq(&ffs->ev.waitq.lock);
526done_mutex:
527 mutex_unlock(&ffs->mutex);
528 kfree(data);
529 return ret;
530}
531
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200532static int ffs_ep0_open(struct inode *inode, struct file *file)
533{
534 struct ffs_data *ffs = inode->i_private;
535
536 ENTER();
537
538 if (unlikely(ffs->state == FFS_CLOSING))
539 return -EBUSY;
540
541 file->private_data = ffs;
542 ffs_data_opened(ffs);
543
544 return 0;
545}
546
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200547static int ffs_ep0_release(struct inode *inode, struct file *file)
548{
549 struct ffs_data *ffs = file->private_data;
550
551 ENTER();
552
553 ffs_data_closed(ffs);
554
555 return 0;
556}
557
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200558static long ffs_ep0_ioctl(struct file *file, unsigned code, unsigned long value)
559{
560 struct ffs_data *ffs = file->private_data;
561 struct usb_gadget *gadget = ffs->gadget;
562 long ret;
563
564 ENTER();
565
566 if (code == FUNCTIONFS_INTERFACE_REVMAP) {
567 struct ffs_function *func = ffs->func;
568 ret = func ? ffs_func_revmap_intf(func, value) : -ENODEV;
Andrzej Pietrasiewicz92b0abf2012-03-28 09:30:50 +0200569 } else if (gadget && gadget->ops->ioctl) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200570 ret = gadget->ops->ioctl(gadget, code, value);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200571 } else {
572 ret = -ENOTTY;
573 }
574
575 return ret;
576}
577
Robert Baldyga23de91e2014-02-10 10:42:43 +0100578static unsigned int ffs_ep0_poll(struct file *file, poll_table *wait)
579{
580 struct ffs_data *ffs = file->private_data;
581 unsigned int mask = POLLWRNORM;
582 int ret;
583
584 poll_wait(file, &ffs->ev.waitq, wait);
585
586 ret = ffs_mutex_lock(&ffs->mutex, file->f_flags & O_NONBLOCK);
587 if (unlikely(ret < 0))
588 return mask;
589
590 switch (ffs->state) {
591 case FFS_READ_DESCRIPTORS:
592 case FFS_READ_STRINGS:
593 mask |= POLLOUT;
594 break;
595
596 case FFS_ACTIVE:
597 switch (ffs->setup_state) {
598 case FFS_NO_SETUP:
599 if (ffs->ev.count)
600 mask |= POLLIN;
601 break;
602
603 case FFS_SETUP_PENDING:
604 case FFS_SETUP_CANCELLED:
605 mask |= (POLLIN | POLLOUT);
606 break;
607 }
608 case FFS_CLOSING:
609 break;
Robert Baldyga18d6b32f2014-12-18 09:55:10 +0100610 case FFS_DEACTIVATED:
611 break;
Robert Baldyga23de91e2014-02-10 10:42:43 +0100612 }
613
614 mutex_unlock(&ffs->mutex);
615
616 return mask;
617}
618
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200619static const struct file_operations ffs_ep0_operations = {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200620 .llseek = no_llseek,
621
622 .open = ffs_ep0_open,
623 .write = ffs_ep0_write,
624 .read = ffs_ep0_read,
625 .release = ffs_ep0_release,
626 .unlocked_ioctl = ffs_ep0_ioctl,
Robert Baldyga23de91e2014-02-10 10:42:43 +0100627 .poll = ffs_ep0_poll,
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200628};
629
630
631/* "Normal" endpoints operations ********************************************/
632
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200633static void ffs_epfile_io_complete(struct usb_ep *_ep, struct usb_request *req)
634{
635 ENTER();
636 if (likely(req->context)) {
637 struct ffs_ep *ep = _ep->driver_data;
638 ep->status = req->status ? req->status : req->actual;
639 complete(req->context);
640 }
641}
642
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100643static void ffs_user_copy_worker(struct work_struct *work)
644{
645 struct ffs_io_data *io_data = container_of(work, struct ffs_io_data,
646 work);
647 int ret = io_data->req->status ? io_data->req->status :
648 io_data->req->actual;
649
650 if (io_data->read && ret > 0) {
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100651 use_mm(io_data->mm);
Al Viroc993c392015-01-31 23:23:35 -0500652 ret = copy_to_iter(io_data->buf, ret, &io_data->data);
653 if (iov_iter_count(&io_data->data))
654 ret = -EFAULT;
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100655 unuse_mm(io_data->mm);
656 }
657
658 aio_complete(io_data->kiocb, ret, ret);
659
Robert Baldyga5e33f6f2015-01-23 13:41:01 +0100660 if (io_data->ffs->ffs_eventfd && !io_data->kiocb->ki_eventfd)
661 eventfd_signal(io_data->ffs->ffs_eventfd, 1);
662
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100663 usb_ep_free_request(io_data->ep, io_data->req);
664
665 io_data->kiocb->private = NULL;
666 if (io_data->read)
Al Viroc993c392015-01-31 23:23:35 -0500667 kfree(io_data->to_free);
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100668 kfree(io_data->buf);
669 kfree(io_data);
670}
671
672static void ffs_epfile_async_io_complete(struct usb_ep *_ep,
673 struct usb_request *req)
674{
675 struct ffs_io_data *io_data = req->context;
676
677 ENTER();
678
679 INIT_WORK(&io_data->work, ffs_user_copy_worker);
680 schedule_work(&io_data->work);
681}
682
683static ssize_t ffs_epfile_io(struct file *file, struct ffs_io_data *io_data)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200684{
685 struct ffs_epfile *epfile = file->private_data;
686 struct ffs_ep *ep;
687 char *data = NULL;
David Cohenc0d31b32014-10-13 11:15:54 -0700688 ssize_t ret, data_len = -EINVAL;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200689 int halt;
690
Michal Nazarewicz7fa68032013-12-09 15:55:36 -0800691 /* Are we still active? */
692 if (WARN_ON(epfile->ffs->state != FFS_ACTIVE)) {
693 ret = -ENODEV;
694 goto error;
695 }
696
697 /* Wait for endpoint to be enabled */
698 ep = epfile->ep;
699 if (!ep) {
700 if (file->f_flags & O_NONBLOCK) {
701 ret = -EAGAIN;
702 goto error;
703 }
704
705 ret = wait_event_interruptible(epfile->wait, (ep = epfile->ep));
706 if (ret) {
707 ret = -EINTR;
708 goto error;
709 }
710 }
711
712 /* Do we halt? */
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100713 halt = (!io_data->read == !epfile->in);
Michal Nazarewicz7fa68032013-12-09 15:55:36 -0800714 if (halt && epfile->isoc) {
715 ret = -EINVAL;
716 goto error;
717 }
718
719 /* Allocate & copy */
720 if (!halt) {
Michal Nazarewicz219580e2013-12-09 15:55:37 -0800721 /*
Andrzej Pietrasiewiczf0f42202014-01-20 08:33:50 +0100722 * if we _do_ wait above, the epfile->ffs->gadget might be NULL
723 * before the waiting completes, so do not assign to 'gadget' earlier
724 */
725 struct usb_gadget *gadget = epfile->ffs->gadget;
Al Viroc993c392015-01-31 23:23:35 -0500726 size_t copied;
Andrzej Pietrasiewiczf0f42202014-01-20 08:33:50 +0100727
Chao Bi97839ca2014-04-14 11:19:53 +0800728 spin_lock_irq(&epfile->ffs->eps_lock);
729 /* In the meantime, endpoint got disabled or changed. */
730 if (epfile->ep != ep) {
731 spin_unlock_irq(&epfile->ffs->eps_lock);
732 return -ESHUTDOWN;
733 }
Al Viroc993c392015-01-31 23:23:35 -0500734 data_len = iov_iter_count(&io_data->data);
Andrzej Pietrasiewiczf0f42202014-01-20 08:33:50 +0100735 /*
Michal Nazarewicz219580e2013-12-09 15:55:37 -0800736 * Controller may require buffer size to be aligned to
737 * maxpacketsize of an out endpoint.
738 */
Al Viroc993c392015-01-31 23:23:35 -0500739 if (io_data->read)
740 data_len = usb_ep_align_maybe(gadget, ep->ep, data_len);
Chao Bi97839ca2014-04-14 11:19:53 +0800741 spin_unlock_irq(&epfile->ffs->eps_lock);
Michal Nazarewicz219580e2013-12-09 15:55:37 -0800742
743 data = kmalloc(data_len, GFP_KERNEL);
Michal Nazarewicz7fa68032013-12-09 15:55:36 -0800744 if (unlikely(!data))
745 return -ENOMEM;
Al Viroc993c392015-01-31 23:23:35 -0500746 if (!io_data->read) {
747 copied = copy_from_iter(data, data_len, &io_data->data);
748 if (copied != data_len) {
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100749 ret = -EFAULT;
750 goto error;
751 }
Michal Nazarewicz7fa68032013-12-09 15:55:36 -0800752 }
753 }
754
755 /* We will be using request */
756 ret = ffs_mutex_lock(&epfile->mutex, file->f_flags & O_NONBLOCK);
757 if (unlikely(ret))
758 goto error;
759
760 spin_lock_irq(&epfile->ffs->eps_lock);
761
762 if (epfile->ep != ep) {
763 /* In the meantime, endpoint got disabled or changed. */
764 ret = -ESHUTDOWN;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200765 spin_unlock_irq(&epfile->ffs->eps_lock);
Michal Nazarewicz7fa68032013-12-09 15:55:36 -0800766 } else if (halt) {
767 /* Halt */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200768 if (likely(epfile->ep == ep) && !WARN_ON(!ep->ep))
769 usb_ep_set_halt(ep->ep);
770 spin_unlock_irq(&epfile->ffs->eps_lock);
771 ret = -EBADMSG;
772 } else {
773 /* Fire the request */
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100774 struct usb_request *req;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200775
David Cohenc0d31b32014-10-13 11:15:54 -0700776 /*
777 * Sanity Check: even though data_len can't be used
778 * uninitialized at the time I write this comment, some
779 * compilers complain about this situation.
780 * In order to keep the code clean from warnings, data_len is
781 * being initialized to -EINVAL during its declaration, which
782 * means we can't rely on compiler anymore to warn no future
783 * changes won't result in data_len being used uninitialized.
784 * For such reason, we're adding this redundant sanity check
785 * here.
786 */
787 if (unlikely(data_len == -EINVAL)) {
788 WARN(1, "%s: data_len == -EINVAL\n", __func__);
789 ret = -EINVAL;
790 goto error_lock;
791 }
792
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100793 if (io_data->aio) {
794 req = usb_ep_alloc_request(ep->ep, GFP_KERNEL);
795 if (unlikely(!req))
Robert Baldyga48968f82014-03-10 09:33:37 +0100796 goto error_lock;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200797
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100798 req->buf = data;
David Cohenc0d31b32014-10-13 11:15:54 -0700799 req->length = data_len;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200800
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100801 io_data->buf = data;
802 io_data->ep = ep->ep;
803 io_data->req = req;
Robert Baldyga5e33f6f2015-01-23 13:41:01 +0100804 io_data->ffs = epfile->ffs;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200805
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100806 req->context = io_data;
807 req->complete = ffs_epfile_async_io_complete;
808
809 ret = usb_ep_queue(ep->ep, req, GFP_ATOMIC);
810 if (unlikely(ret)) {
811 usb_ep_free_request(ep->ep, req);
Robert Baldyga48968f82014-03-10 09:33:37 +0100812 goto error_lock;
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100813 }
814 ret = -EIOCBQUEUED;
815
816 spin_unlock_irq(&epfile->ffs->eps_lock);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200817 } else {
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100818 DECLARE_COMPLETION_ONSTACK(done);
819
820 req = ep->req;
821 req->buf = data;
David Cohenc0d31b32014-10-13 11:15:54 -0700822 req->length = data_len;
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100823
824 req->context = &done;
825 req->complete = ffs_epfile_io_complete;
826
827 ret = usb_ep_queue(ep->ep, req, GFP_ATOMIC);
828
829 spin_unlock_irq(&epfile->ffs->eps_lock);
830
831 if (unlikely(ret < 0)) {
832 /* nop */
833 } else if (unlikely(
834 wait_for_completion_interruptible(&done))) {
835 ret = -EINTR;
836 usb_ep_dequeue(ep->ep, req);
837 } else {
Chuansheng Liucfe919b2014-03-04 15:34:57 +0800838 /*
839 * XXX We may end up silently droping data
840 * here. Since data_len (i.e. req->length) may
841 * be bigger than len (after being rounded up
842 * to maxpacketsize), we may end up with more
843 * data then user space has space for.
844 */
845 ret = ep->status;
846 if (io_data->read && ret > 0) {
Al Viroc993c392015-01-31 23:23:35 -0500847 ret = copy_to_iter(data, ret, &io_data->data);
848 if (unlikely(iov_iter_count(&io_data->data)))
Chuansheng Liucfe919b2014-03-04 15:34:57 +0800849 ret = -EFAULT;
850 }
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100851 }
852 kfree(data);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200853 }
854 }
855
856 mutex_unlock(&epfile->mutex);
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100857 return ret;
Robert Baldyga48968f82014-03-10 09:33:37 +0100858
859error_lock:
860 spin_unlock_irq(&epfile->ffs->eps_lock);
861 mutex_unlock(&epfile->mutex);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200862error:
863 kfree(data);
864 return ret;
865}
866
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200867static ssize_t
868ffs_epfile_write(struct file *file, const char __user *buf, size_t len,
869 loff_t *ptr)
870{
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100871 struct ffs_io_data io_data;
Al Viroc993c392015-01-31 23:23:35 -0500872 struct iovec iov = {.iov_base = buf, .iov_len = len};
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100873
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200874 ENTER();
875
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100876 io_data.aio = false;
877 io_data.read = false;
Al Viroc993c392015-01-31 23:23:35 -0500878 iov_iter_init(&io_data.data, WRITE, &iov, 1, len);
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100879
880 return ffs_epfile_io(file, &io_data);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200881}
882
883static ssize_t
884ffs_epfile_read(struct file *file, char __user *buf, size_t len, loff_t *ptr)
885{
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100886 struct ffs_io_data io_data;
Al Viroc993c392015-01-31 23:23:35 -0500887 struct iovec iov = {.iov_base = buf, .iov_len = len};
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100888
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200889 ENTER();
890
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100891 io_data.aio = false;
892 io_data.read = true;
Al Viroc993c392015-01-31 23:23:35 -0500893 io_data.to_free = NULL;
894 iov_iter_init(&io_data.data, READ, &iov, 1, len);
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100895
896 return ffs_epfile_io(file, &io_data);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +0200897}
898
899static int
900ffs_epfile_open(struct inode *inode, struct file *file)
901{
902 struct ffs_epfile *epfile = inode->i_private;
903
904 ENTER();
905
906 if (WARN_ON(epfile->ffs->state != FFS_ACTIVE))
907 return -ENODEV;
908
909 file->private_data = epfile;
910 ffs_data_opened(epfile->ffs);
911
912 return 0;
913}
914
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100915static int ffs_aio_cancel(struct kiocb *kiocb)
916{
917 struct ffs_io_data *io_data = kiocb->private;
918 struct ffs_epfile *epfile = kiocb->ki_filp->private_data;
919 int value;
920
921 ENTER();
922
923 spin_lock_irq(&epfile->ffs->eps_lock);
924
925 if (likely(io_data && io_data->ep && io_data->req))
926 value = usb_ep_dequeue(io_data->ep, io_data->req);
927 else
928 value = -EINVAL;
929
930 spin_unlock_irq(&epfile->ffs->eps_lock);
931
932 return value;
933}
934
935static ssize_t ffs_epfile_aio_write(struct kiocb *kiocb,
936 const struct iovec *iovec,
937 unsigned long nr_segs, loff_t loff)
938{
939 struct ffs_io_data *io_data;
Al Virode2080d2015-01-31 23:42:34 -0500940 ssize_t res;
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100941
942 ENTER();
943
944 io_data = kmalloc(sizeof(*io_data), GFP_KERNEL);
945 if (unlikely(!io_data))
946 return -ENOMEM;
947
948 io_data->aio = true;
949 io_data->read = false;
950 io_data->kiocb = kiocb;
Al Viroc993c392015-01-31 23:23:35 -0500951 iov_iter_init(&io_data->data, WRITE, iovec, nr_segs, kiocb->ki_nbytes);
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100952 io_data->mm = current->mm;
953
954 kiocb->private = io_data;
955
956 kiocb_set_cancel_fn(kiocb, ffs_aio_cancel);
957
Al Virode2080d2015-01-31 23:42:34 -0500958 res = ffs_epfile_io(kiocb->ki_filp, io_data);
959 if (res != -EIOCBQUEUED)
960 kfree(io_data);
961 return res;
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100962}
963
964static ssize_t ffs_epfile_aio_read(struct kiocb *kiocb,
965 const struct iovec *iovec,
966 unsigned long nr_segs, loff_t loff)
967{
968 struct ffs_io_data *io_data;
969 struct iovec *iovec_copy;
Al Virode2080d2015-01-31 23:42:34 -0500970 ssize_t res;
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100971
972 ENTER();
973
974 iovec_copy = kmalloc_array(nr_segs, sizeof(*iovec_copy), GFP_KERNEL);
975 if (unlikely(!iovec_copy))
976 return -ENOMEM;
977
978 memcpy(iovec_copy, iovec, sizeof(struct iovec)*nr_segs);
979
980 io_data = kmalloc(sizeof(*io_data), GFP_KERNEL);
981 if (unlikely(!io_data)) {
982 kfree(iovec_copy);
983 return -ENOMEM;
984 }
985
986 io_data->aio = true;
987 io_data->read = true;
988 io_data->kiocb = kiocb;
Al Viroc993c392015-01-31 23:23:35 -0500989 io_data->to_free = iovec_copy;
990 iov_iter_init(&io_data->data, READ, iovec_copy, nr_segs, kiocb->ki_nbytes);
Robert Baldyga2e4c7552014-02-10 10:42:44 +0100991 io_data->mm = current->mm;
992
993 kiocb->private = io_data;
994
995 kiocb_set_cancel_fn(kiocb, ffs_aio_cancel);
996
Al Virode2080d2015-01-31 23:42:34 -0500997 res = ffs_epfile_io(kiocb->ki_filp, io_data);
998 if (res != -EIOCBQUEUED) {
Al Viroc993c392015-01-31 23:23:35 -0500999 kfree(io_data->to_free);
Al Virode2080d2015-01-31 23:42:34 -05001000 kfree(io_data);
Al Virode2080d2015-01-31 23:42:34 -05001001 }
1002 return res;
Robert Baldyga2e4c7552014-02-10 10:42:44 +01001003}
1004
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001005static int
1006ffs_epfile_release(struct inode *inode, struct file *file)
1007{
1008 struct ffs_epfile *epfile = inode->i_private;
1009
1010 ENTER();
1011
1012 ffs_data_closed(epfile->ffs);
1013
1014 return 0;
1015}
1016
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001017static long ffs_epfile_ioctl(struct file *file, unsigned code,
1018 unsigned long value)
1019{
1020 struct ffs_epfile *epfile = file->private_data;
1021 int ret;
1022
1023 ENTER();
1024
1025 if (WARN_ON(epfile->ffs->state != FFS_ACTIVE))
1026 return -ENODEV;
1027
1028 spin_lock_irq(&epfile->ffs->eps_lock);
1029 if (likely(epfile->ep)) {
1030 switch (code) {
1031 case FUNCTIONFS_FIFO_STATUS:
1032 ret = usb_ep_fifo_status(epfile->ep->ep);
1033 break;
1034 case FUNCTIONFS_FIFO_FLUSH:
1035 usb_ep_fifo_flush(epfile->ep->ep);
1036 ret = 0;
1037 break;
1038 case FUNCTIONFS_CLEAR_HALT:
1039 ret = usb_ep_clear_halt(epfile->ep->ep);
1040 break;
1041 case FUNCTIONFS_ENDPOINT_REVMAP:
1042 ret = epfile->ep->num;
1043 break;
Robert Baldygac559a352014-09-09 08:23:16 +02001044 case FUNCTIONFS_ENDPOINT_DESC:
1045 {
1046 int desc_idx;
1047 struct usb_endpoint_descriptor *desc;
1048
1049 switch (epfile->ffs->gadget->speed) {
1050 case USB_SPEED_SUPER:
1051 desc_idx = 2;
1052 break;
1053 case USB_SPEED_HIGH:
1054 desc_idx = 1;
1055 break;
1056 default:
1057 desc_idx = 0;
1058 }
1059 desc = epfile->ep->descs[desc_idx];
1060
1061 spin_unlock_irq(&epfile->ffs->eps_lock);
1062 ret = copy_to_user((void *)value, desc, sizeof(*desc));
1063 if (ret)
1064 ret = -EFAULT;
1065 return ret;
1066 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001067 default:
1068 ret = -ENOTTY;
1069 }
1070 } else {
1071 ret = -ENODEV;
1072 }
1073 spin_unlock_irq(&epfile->ffs->eps_lock);
1074
1075 return ret;
1076}
1077
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001078static const struct file_operations ffs_epfile_operations = {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001079 .llseek = no_llseek,
1080
1081 .open = ffs_epfile_open,
1082 .write = ffs_epfile_write,
1083 .read = ffs_epfile_read,
Robert Baldyga2e4c7552014-02-10 10:42:44 +01001084 .aio_write = ffs_epfile_aio_write,
1085 .aio_read = ffs_epfile_aio_read,
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001086 .release = ffs_epfile_release,
1087 .unlocked_ioctl = ffs_epfile_ioctl,
1088};
1089
1090
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001091/* File system and super block operations ***********************************/
1092
1093/*
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01001094 * Mounting the file system creates a controller file, used first for
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001095 * function configuration then later for event monitoring.
1096 */
1097
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001098static struct inode *__must_check
1099ffs_sb_make_inode(struct super_block *sb, void *data,
1100 const struct file_operations *fops,
1101 const struct inode_operations *iops,
1102 struct ffs_file_perms *perms)
1103{
1104 struct inode *inode;
1105
1106 ENTER();
1107
1108 inode = new_inode(sb);
1109
1110 if (likely(inode)) {
1111 struct timespec current_time = CURRENT_TIME;
1112
Al Viro12ba8d12010-10-27 04:19:36 +01001113 inode->i_ino = get_next_ino();
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001114 inode->i_mode = perms->mode;
1115 inode->i_uid = perms->uid;
1116 inode->i_gid = perms->gid;
1117 inode->i_atime = current_time;
1118 inode->i_mtime = current_time;
1119 inode->i_ctime = current_time;
1120 inode->i_private = data;
1121 if (fops)
1122 inode->i_fop = fops;
1123 if (iops)
1124 inode->i_op = iops;
1125 }
1126
1127 return inode;
1128}
1129
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001130/* Create "regular" file */
Al Viro1bb27ca2014-09-03 13:32:19 -04001131static struct dentry *ffs_sb_create_file(struct super_block *sb,
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001132 const char *name, void *data,
Al Viro1bb27ca2014-09-03 13:32:19 -04001133 const struct file_operations *fops)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001134{
1135 struct ffs_data *ffs = sb->s_fs_info;
1136 struct dentry *dentry;
1137 struct inode *inode;
1138
1139 ENTER();
1140
1141 dentry = d_alloc_name(sb->s_root, name);
1142 if (unlikely(!dentry))
1143 return NULL;
1144
1145 inode = ffs_sb_make_inode(sb, data, fops, NULL, &ffs->file_perms);
1146 if (unlikely(!inode)) {
1147 dput(dentry);
1148 return NULL;
1149 }
1150
1151 d_add(dentry, inode);
Al Viro1bb27ca2014-09-03 13:32:19 -04001152 return dentry;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001153}
1154
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001155/* Super block */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001156static const struct super_operations ffs_sb_operations = {
1157 .statfs = simple_statfs,
1158 .drop_inode = generic_delete_inode,
1159};
1160
1161struct ffs_sb_fill_data {
1162 struct ffs_file_perms perms;
1163 umode_t root_mode;
1164 const char *dev_name;
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01001165 bool no_disconnect;
Al Viro2606b282013-09-20 17:14:21 +01001166 struct ffs_data *ffs_data;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001167};
1168
1169static int ffs_sb_fill(struct super_block *sb, void *_data, int silent)
1170{
1171 struct ffs_sb_fill_data *data = _data;
1172 struct inode *inode;
Al Viro2606b282013-09-20 17:14:21 +01001173 struct ffs_data *ffs = data->ffs_data;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001174
1175 ENTER();
1176
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001177 ffs->sb = sb;
Al Viro2606b282013-09-20 17:14:21 +01001178 data->ffs_data = NULL;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001179 sb->s_fs_info = ffs;
1180 sb->s_blocksize = PAGE_CACHE_SIZE;
1181 sb->s_blocksize_bits = PAGE_CACHE_SHIFT;
1182 sb->s_magic = FUNCTIONFS_MAGIC;
1183 sb->s_op = &ffs_sb_operations;
1184 sb->s_time_gran = 1;
1185
1186 /* Root inode */
1187 data->perms.mode = data->root_mode;
1188 inode = ffs_sb_make_inode(sb, NULL,
1189 &simple_dir_operations,
1190 &simple_dir_inode_operations,
1191 &data->perms);
Al Viro48fde702012-01-08 22:15:13 -05001192 sb->s_root = d_make_root(inode);
1193 if (unlikely(!sb->s_root))
Al Viro2606b282013-09-20 17:14:21 +01001194 return -ENOMEM;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001195
1196 /* EP0 file */
1197 if (unlikely(!ffs_sb_create_file(sb, "ep0", ffs,
Al Viro1bb27ca2014-09-03 13:32:19 -04001198 &ffs_ep0_operations)))
Al Viro2606b282013-09-20 17:14:21 +01001199 return -ENOMEM;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001200
1201 return 0;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001202}
1203
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001204static int ffs_fs_parse_opts(struct ffs_sb_fill_data *data, char *opts)
1205{
1206 ENTER();
1207
1208 if (!opts || !*opts)
1209 return 0;
1210
1211 for (;;) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001212 unsigned long value;
Michal Nazarewiczafd2e182013-01-09 10:17:47 +01001213 char *eq, *comma;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001214
1215 /* Option limit */
1216 comma = strchr(opts, ',');
1217 if (comma)
1218 *comma = 0;
1219
1220 /* Value limit */
1221 eq = strchr(opts, '=');
1222 if (unlikely(!eq)) {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001223 pr_err("'=' missing in %s\n", opts);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001224 return -EINVAL;
1225 }
1226 *eq = 0;
1227
1228 /* Parse value */
Michal Nazarewiczafd2e182013-01-09 10:17:47 +01001229 if (kstrtoul(eq + 1, 0, &value)) {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001230 pr_err("%s: invalid value: %s\n", opts, eq + 1);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001231 return -EINVAL;
1232 }
1233
1234 /* Interpret option */
1235 switch (eq - opts) {
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01001236 case 13:
1237 if (!memcmp(opts, "no_disconnect", 13))
1238 data->no_disconnect = !!value;
1239 else
1240 goto invalid;
1241 break;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001242 case 5:
1243 if (!memcmp(opts, "rmode", 5))
1244 data->root_mode = (value & 0555) | S_IFDIR;
1245 else if (!memcmp(opts, "fmode", 5))
1246 data->perms.mode = (value & 0666) | S_IFREG;
1247 else
1248 goto invalid;
1249 break;
1250
1251 case 4:
1252 if (!memcmp(opts, "mode", 4)) {
1253 data->root_mode = (value & 0555) | S_IFDIR;
1254 data->perms.mode = (value & 0666) | S_IFREG;
1255 } else {
1256 goto invalid;
1257 }
1258 break;
1259
1260 case 3:
Eric W. Biedermanb9b73f72012-06-14 01:19:23 -07001261 if (!memcmp(opts, "uid", 3)) {
1262 data->perms.uid = make_kuid(current_user_ns(), value);
1263 if (!uid_valid(data->perms.uid)) {
1264 pr_err("%s: unmapped value: %lu\n", opts, value);
1265 return -EINVAL;
1266 }
Benoit Gobyb8100752013-01-08 19:57:09 -08001267 } else if (!memcmp(opts, "gid", 3)) {
Eric W. Biedermanb9b73f72012-06-14 01:19:23 -07001268 data->perms.gid = make_kgid(current_user_ns(), value);
1269 if (!gid_valid(data->perms.gid)) {
1270 pr_err("%s: unmapped value: %lu\n", opts, value);
1271 return -EINVAL;
1272 }
Benoit Gobyb8100752013-01-08 19:57:09 -08001273 } else {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001274 goto invalid;
Benoit Gobyb8100752013-01-08 19:57:09 -08001275 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001276 break;
1277
1278 default:
1279invalid:
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001280 pr_err("%s: invalid option\n", opts);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001281 return -EINVAL;
1282 }
1283
1284 /* Next iteration */
1285 if (!comma)
1286 break;
1287 opts = comma + 1;
1288 }
1289
1290 return 0;
1291}
1292
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001293/* "mount -t functionfs dev_name /dev/function" ends up here */
1294
Al Virofc14f2f2010-07-25 01:48:30 +04001295static struct dentry *
1296ffs_fs_mount(struct file_system_type *t, int flags,
1297 const char *dev_name, void *opts)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001298{
1299 struct ffs_sb_fill_data data = {
1300 .perms = {
1301 .mode = S_IFREG | 0600,
Eric W. Biedermanb9b73f72012-06-14 01:19:23 -07001302 .uid = GLOBAL_ROOT_UID,
1303 .gid = GLOBAL_ROOT_GID,
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001304 },
1305 .root_mode = S_IFDIR | 0500,
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01001306 .no_disconnect = false,
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001307 };
Andrzej Pietrasiewicz581791f2012-05-14 15:51:52 +02001308 struct dentry *rv;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001309 int ret;
Andrzej Pietrasiewicz581791f2012-05-14 15:51:52 +02001310 void *ffs_dev;
Al Viro2606b282013-09-20 17:14:21 +01001311 struct ffs_data *ffs;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001312
1313 ENTER();
1314
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001315 ret = ffs_fs_parse_opts(&data, opts);
1316 if (unlikely(ret < 0))
Al Virofc14f2f2010-07-25 01:48:30 +04001317 return ERR_PTR(ret);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001318
Al Viro2606b282013-09-20 17:14:21 +01001319 ffs = ffs_data_new();
1320 if (unlikely(!ffs))
1321 return ERR_PTR(-ENOMEM);
1322 ffs->file_perms = data.perms;
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01001323 ffs->no_disconnect = data.no_disconnect;
Al Viro2606b282013-09-20 17:14:21 +01001324
1325 ffs->dev_name = kstrdup(dev_name, GFP_KERNEL);
1326 if (unlikely(!ffs->dev_name)) {
1327 ffs_data_put(ffs);
1328 return ERR_PTR(-ENOMEM);
1329 }
1330
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01001331 ffs_dev = ffs_acquire_dev(dev_name);
Al Viro2606b282013-09-20 17:14:21 +01001332 if (IS_ERR(ffs_dev)) {
1333 ffs_data_put(ffs);
1334 return ERR_CAST(ffs_dev);
1335 }
1336 ffs->private_data = ffs_dev;
1337 data.ffs_data = ffs;
Andrzej Pietrasiewicz581791f2012-05-14 15:51:52 +02001338
Andrzej Pietrasiewicz581791f2012-05-14 15:51:52 +02001339 rv = mount_nodev(t, flags, &data, ffs_sb_fill);
Al Viro2606b282013-09-20 17:14:21 +01001340 if (IS_ERR(rv) && data.ffs_data) {
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01001341 ffs_release_dev(data.ffs_data);
Al Viro2606b282013-09-20 17:14:21 +01001342 ffs_data_put(data.ffs_data);
1343 }
Andrzej Pietrasiewicz581791f2012-05-14 15:51:52 +02001344 return rv;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001345}
1346
1347static void
1348ffs_fs_kill_sb(struct super_block *sb)
1349{
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001350 ENTER();
1351
1352 kill_litter_super(sb);
Andrzej Pietrasiewicz581791f2012-05-14 15:51:52 +02001353 if (sb->s_fs_info) {
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01001354 ffs_release_dev(sb->s_fs_info);
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01001355 ffs_data_closed(sb->s_fs_info);
Al Viro5b5f9562012-01-08 15:38:27 -05001356 ffs_data_put(sb->s_fs_info);
Andrzej Pietrasiewicz581791f2012-05-14 15:51:52 +02001357 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001358}
1359
1360static struct file_system_type ffs_fs_type = {
1361 .owner = THIS_MODULE,
1362 .name = "functionfs",
Al Virofc14f2f2010-07-25 01:48:30 +04001363 .mount = ffs_fs_mount,
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001364 .kill_sb = ffs_fs_kill_sb,
1365};
Eric W. Biederman7f78e032013-03-02 19:39:14 -08001366MODULE_ALIAS_FS("functionfs");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001367
1368
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001369/* Driver's main init/cleanup functions *************************************/
1370
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001371static int functionfs_init(void)
1372{
1373 int ret;
1374
1375 ENTER();
1376
1377 ret = register_filesystem(&ffs_fs_type);
1378 if (likely(!ret))
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001379 pr_info("file system registered\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001380 else
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001381 pr_err("failed registering file system (%d)\n", ret);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001382
1383 return ret;
1384}
1385
1386static void functionfs_cleanup(void)
1387{
1388 ENTER();
1389
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001390 pr_info("unloading\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001391 unregister_filesystem(&ffs_fs_type);
1392}
1393
1394
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001395/* ffs_data and ffs_function construction and destruction code **************/
1396
1397static void ffs_data_clear(struct ffs_data *ffs);
1398static void ffs_data_reset(struct ffs_data *ffs);
1399
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001400static void ffs_data_get(struct ffs_data *ffs)
1401{
1402 ENTER();
1403
1404 atomic_inc(&ffs->ref);
1405}
1406
1407static void ffs_data_opened(struct ffs_data *ffs)
1408{
1409 ENTER();
1410
1411 atomic_inc(&ffs->ref);
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01001412 if (atomic_add_return(1, &ffs->opened) == 1 &&
1413 ffs->state == FFS_DEACTIVATED) {
1414 ffs->state = FFS_CLOSING;
1415 ffs_data_reset(ffs);
1416 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001417}
1418
1419static void ffs_data_put(struct ffs_data *ffs)
1420{
1421 ENTER();
1422
1423 if (unlikely(atomic_dec_and_test(&ffs->ref))) {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001424 pr_info("%s(): freeing\n", __func__);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001425 ffs_data_clear(ffs);
Andi Kleen647d5582012-03-16 12:01:02 -07001426 BUG_ON(waitqueue_active(&ffs->ev.waitq) ||
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001427 waitqueue_active(&ffs->ep0req_completion.wait));
Andrzej Pietrasiewicz581791f2012-05-14 15:51:52 +02001428 kfree(ffs->dev_name);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001429 kfree(ffs);
1430 }
1431}
1432
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001433static void ffs_data_closed(struct ffs_data *ffs)
1434{
1435 ENTER();
1436
1437 if (atomic_dec_and_test(&ffs->opened)) {
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01001438 if (ffs->no_disconnect) {
1439 ffs->state = FFS_DEACTIVATED;
1440 if (ffs->epfiles) {
1441 ffs_epfiles_destroy(ffs->epfiles,
1442 ffs->eps_count);
1443 ffs->epfiles = NULL;
1444 }
1445 if (ffs->setup_state == FFS_SETUP_PENDING)
1446 __ffs_ep0_stall(ffs);
1447 } else {
1448 ffs->state = FFS_CLOSING;
1449 ffs_data_reset(ffs);
1450 }
1451 }
1452 if (atomic_read(&ffs->opened) < 0) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001453 ffs->state = FFS_CLOSING;
1454 ffs_data_reset(ffs);
1455 }
1456
1457 ffs_data_put(ffs);
1458}
1459
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001460static struct ffs_data *ffs_data_new(void)
1461{
1462 struct ffs_data *ffs = kzalloc(sizeof *ffs, GFP_KERNEL);
1463 if (unlikely(!ffs))
Felipe Balbif8800d42013-12-12 12:15:43 -06001464 return NULL;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001465
1466 ENTER();
1467
1468 atomic_set(&ffs->ref, 1);
1469 atomic_set(&ffs->opened, 0);
1470 ffs->state = FFS_READ_DESCRIPTORS;
1471 mutex_init(&ffs->mutex);
1472 spin_lock_init(&ffs->eps_lock);
1473 init_waitqueue_head(&ffs->ev.waitq);
1474 init_completion(&ffs->ep0req_completion);
1475
1476 /* XXX REVISIT need to update it in some places, or do we? */
1477 ffs->ev.can_stall = 1;
1478
1479 return ffs;
1480}
1481
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001482static void ffs_data_clear(struct ffs_data *ffs)
1483{
1484 ENTER();
1485
1486 if (test_and_clear_bit(FFS_FL_CALL_CLOSED_CALLBACK, &ffs->flags))
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01001487 ffs_closed(ffs);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001488
1489 BUG_ON(ffs->gadget);
1490
1491 if (ffs->epfiles)
1492 ffs_epfiles_destroy(ffs->epfiles, ffs->eps_count);
1493
Robert Baldyga5e33f6f2015-01-23 13:41:01 +01001494 if (ffs->ffs_eventfd)
1495 eventfd_ctx_put(ffs->ffs_eventfd);
1496
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05301497 kfree(ffs->raw_descs_data);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001498 kfree(ffs->raw_strings);
1499 kfree(ffs->stringtabs);
1500}
1501
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001502static void ffs_data_reset(struct ffs_data *ffs)
1503{
1504 ENTER();
1505
1506 ffs_data_clear(ffs);
1507
1508 ffs->epfiles = NULL;
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05301509 ffs->raw_descs_data = NULL;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001510 ffs->raw_descs = NULL;
1511 ffs->raw_strings = NULL;
1512 ffs->stringtabs = NULL;
1513
1514 ffs->raw_descs_length = 0;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001515 ffs->fs_descs_count = 0;
1516 ffs->hs_descs_count = 0;
Manu Gautam8d4e8972014-02-28 16:50:22 +05301517 ffs->ss_descs_count = 0;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001518
1519 ffs->strings_count = 0;
1520 ffs->interfaces_count = 0;
1521 ffs->eps_count = 0;
1522
1523 ffs->ev.count = 0;
1524
1525 ffs->state = FFS_READ_DESCRIPTORS;
1526 ffs->setup_state = FFS_NO_SETUP;
1527 ffs->flags = 0;
1528}
1529
1530
1531static int functionfs_bind(struct ffs_data *ffs, struct usb_composite_dev *cdev)
1532{
Michal Nazarewiczfd7c9a02010-06-16 12:08:00 +02001533 struct usb_gadget_strings **lang;
1534 int first_id;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001535
1536 ENTER();
1537
1538 if (WARN_ON(ffs->state != FFS_ACTIVE
1539 || test_and_set_bit(FFS_FL_BOUND, &ffs->flags)))
1540 return -EBADFD;
1541
Michal Nazarewiczfd7c9a02010-06-16 12:08:00 +02001542 first_id = usb_string_ids_n(cdev, ffs->strings_count);
1543 if (unlikely(first_id < 0))
1544 return first_id;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001545
1546 ffs->ep0req = usb_ep_alloc_request(cdev->gadget->ep0, GFP_KERNEL);
1547 if (unlikely(!ffs->ep0req))
1548 return -ENOMEM;
1549 ffs->ep0req->complete = ffs_ep0_complete;
1550 ffs->ep0req->context = ffs;
1551
Michal Nazarewiczfd7c9a02010-06-16 12:08:00 +02001552 lang = ffs->stringtabs;
Michal Nazarewiczf0688c82014-06-17 17:47:41 +02001553 if (lang) {
1554 for (; *lang; ++lang) {
1555 struct usb_string *str = (*lang)->strings;
1556 int id = first_id;
1557 for (; str->s; ++id, ++str)
1558 str->id = id;
1559 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001560 }
1561
1562 ffs->gadget = cdev->gadget;
Michal Nazarewiczfd7c9a02010-06-16 12:08:00 +02001563 ffs_data_get(ffs);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001564 return 0;
1565}
1566
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001567static void functionfs_unbind(struct ffs_data *ffs)
1568{
1569 ENTER();
1570
1571 if (!WARN_ON(!ffs->gadget)) {
1572 usb_ep_free_request(ffs->gadget->ep0, ffs->ep0req);
1573 ffs->ep0req = NULL;
1574 ffs->gadget = NULL;
Andrzej Pietrasiewicze2190a92012-03-12 12:55:41 +01001575 clear_bit(FFS_FL_BOUND, &ffs->flags);
Dan Carpenterdf498992013-08-23 11:16:15 +03001576 ffs_data_put(ffs);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001577 }
1578}
1579
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001580static int ffs_epfiles_create(struct ffs_data *ffs)
1581{
1582 struct ffs_epfile *epfile, *epfiles;
1583 unsigned i, count;
1584
1585 ENTER();
1586
1587 count = ffs->eps_count;
Thomas Meyer9823a522011-11-29 22:08:00 +01001588 epfiles = kcalloc(count, sizeof(*epfiles), GFP_KERNEL);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001589 if (!epfiles)
1590 return -ENOMEM;
1591
1592 epfile = epfiles;
1593 for (i = 1; i <= count; ++i, ++epfile) {
1594 epfile->ffs = ffs;
1595 mutex_init(&epfile->mutex);
1596 init_waitqueue_head(&epfile->wait);
Robert Baldyga1b0bf882014-09-09 08:23:17 +02001597 if (ffs->user_flags & FUNCTIONFS_VIRTUAL_ADDR)
Mario Schuknechtacba23f2015-01-26 20:40:21 +01001598 sprintf(epfile->name, "ep%02x", ffs->eps_addrmap[i]);
Robert Baldyga1b0bf882014-09-09 08:23:17 +02001599 else
Mario Schuknechtacba23f2015-01-26 20:40:21 +01001600 sprintf(epfile->name, "ep%u", i);
1601 epfile->dentry = ffs_sb_create_file(ffs->sb, epfile->name,
Al Viro1bb27ca2014-09-03 13:32:19 -04001602 epfile,
1603 &ffs_epfile_operations);
1604 if (unlikely(!epfile->dentry)) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001605 ffs_epfiles_destroy(epfiles, i - 1);
1606 return -ENOMEM;
1607 }
1608 }
1609
1610 ffs->epfiles = epfiles;
1611 return 0;
1612}
1613
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001614static void ffs_epfiles_destroy(struct ffs_epfile *epfiles, unsigned count)
1615{
1616 struct ffs_epfile *epfile = epfiles;
1617
1618 ENTER();
1619
1620 for (; count; --count, ++epfile) {
1621 BUG_ON(mutex_is_locked(&epfile->mutex) ||
1622 waitqueue_active(&epfile->wait));
1623 if (epfile->dentry) {
1624 d_delete(epfile->dentry);
1625 dput(epfile->dentry);
1626 epfile->dentry = NULL;
1627 }
1628 }
1629
1630 kfree(epfiles);
1631}
1632
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001633static void ffs_func_eps_disable(struct ffs_function *func)
1634{
1635 struct ffs_ep *ep = func->eps;
1636 struct ffs_epfile *epfile = func->ffs->epfiles;
1637 unsigned count = func->ffs->eps_count;
1638 unsigned long flags;
1639
1640 spin_lock_irqsave(&func->ffs->eps_lock, flags);
1641 do {
1642 /* pending requests get nuked */
1643 if (likely(ep->ep))
1644 usb_ep_disable(ep->ep);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001645 ++ep;
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01001646
1647 if (epfile) {
1648 epfile->ep = NULL;
1649 ++epfile;
1650 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001651 } while (--count);
1652 spin_unlock_irqrestore(&func->ffs->eps_lock, flags);
1653}
1654
1655static int ffs_func_eps_enable(struct ffs_function *func)
1656{
1657 struct ffs_data *ffs = func->ffs;
1658 struct ffs_ep *ep = func->eps;
1659 struct ffs_epfile *epfile = ffs->epfiles;
1660 unsigned count = ffs->eps_count;
1661 unsigned long flags;
1662 int ret = 0;
1663
1664 spin_lock_irqsave(&func->ffs->eps_lock, flags);
1665 do {
1666 struct usb_endpoint_descriptor *ds;
Manu Gautam8d4e8972014-02-28 16:50:22 +05301667 int desc_idx;
1668
1669 if (ffs->gadget->speed == USB_SPEED_SUPER)
1670 desc_idx = 2;
1671 else if (ffs->gadget->speed == USB_SPEED_HIGH)
1672 desc_idx = 1;
1673 else
1674 desc_idx = 0;
1675
1676 /* fall-back to lower speed if desc missing for current speed */
1677 do {
1678 ds = ep->descs[desc_idx];
1679 } while (!ds && --desc_idx >= 0);
1680
1681 if (!ds) {
1682 ret = -EINVAL;
1683 break;
1684 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001685
1686 ep->ep->driver_data = ep;
Tatyana Brokhman72c973d2011-06-28 16:33:48 +03001687 ep->ep->desc = ds;
1688 ret = usb_ep_enable(ep->ep);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001689 if (likely(!ret)) {
1690 epfile->ep = ep;
1691 epfile->in = usb_endpoint_dir_in(ds);
1692 epfile->isoc = usb_endpoint_xfer_isoc(ds);
1693 } else {
1694 break;
1695 }
1696
1697 wake_up(&epfile->wait);
1698
1699 ++ep;
1700 ++epfile;
1701 } while (--count);
1702 spin_unlock_irqrestore(&func->ffs->eps_lock, flags);
1703
1704 return ret;
1705}
1706
1707
1708/* Parsing and building descriptors and strings *****************************/
1709
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01001710/*
1711 * This validates if data pointed by data is a valid USB descriptor as
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001712 * well as record how many interfaces, endpoints and strings are
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01001713 * required by given configuration. Returns address after the
1714 * descriptor or NULL if data is invalid.
1715 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001716
1717enum ffs_entity_type {
1718 FFS_DESCRIPTOR, FFS_INTERFACE, FFS_STRING, FFS_ENDPOINT
1719};
1720
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02001721enum ffs_os_desc_type {
1722 FFS_OS_DESC, FFS_OS_DESC_EXT_COMPAT, FFS_OS_DESC_EXT_PROP
1723};
1724
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001725typedef int (*ffs_entity_callback)(enum ffs_entity_type entity,
1726 u8 *valuep,
1727 struct usb_descriptor_header *desc,
1728 void *priv);
1729
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02001730typedef int (*ffs_os_desc_callback)(enum ffs_os_desc_type entity,
1731 struct usb_os_desc_header *h, void *data,
1732 unsigned len, void *priv);
1733
Andrzej Pietrasiewiczf96cbd12014-07-09 12:20:06 +02001734static int __must_check ffs_do_single_desc(char *data, unsigned len,
1735 ffs_entity_callback entity,
1736 void *priv)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001737{
1738 struct usb_descriptor_header *_ds = (void *)data;
1739 u8 length;
1740 int ret;
1741
1742 ENTER();
1743
1744 /* At least two bytes are required: length and type */
1745 if (len < 2) {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001746 pr_vdebug("descriptor too short\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001747 return -EINVAL;
1748 }
1749
1750 /* If we have at least as many bytes as the descriptor takes? */
1751 length = _ds->bLength;
1752 if (len < length) {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001753 pr_vdebug("descriptor longer then available data\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001754 return -EINVAL;
1755 }
1756
1757#define __entity_check_INTERFACE(val) 1
1758#define __entity_check_STRING(val) (val)
1759#define __entity_check_ENDPOINT(val) ((val) & USB_ENDPOINT_NUMBER_MASK)
1760#define __entity(type, val) do { \
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001761 pr_vdebug("entity " #type "(%02x)\n", (val)); \
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001762 if (unlikely(!__entity_check_ ##type(val))) { \
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001763 pr_vdebug("invalid entity's value\n"); \
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001764 return -EINVAL; \
1765 } \
1766 ret = entity(FFS_ ##type, &val, _ds, priv); \
1767 if (unlikely(ret < 0)) { \
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001768 pr_debug("entity " #type "(%02x); ret = %d\n", \
Michal Nazarewiczd8df0b62010-11-12 14:29:29 +01001769 (val), ret); \
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001770 return ret; \
1771 } \
1772 } while (0)
1773
1774 /* Parse descriptor depending on type. */
1775 switch (_ds->bDescriptorType) {
1776 case USB_DT_DEVICE:
1777 case USB_DT_CONFIG:
1778 case USB_DT_STRING:
1779 case USB_DT_DEVICE_QUALIFIER:
1780 /* function can't have any of those */
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001781 pr_vdebug("descriptor reserved for gadget: %d\n",
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01001782 _ds->bDescriptorType);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001783 return -EINVAL;
1784
1785 case USB_DT_INTERFACE: {
1786 struct usb_interface_descriptor *ds = (void *)_ds;
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001787 pr_vdebug("interface descriptor\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001788 if (length != sizeof *ds)
1789 goto inv_length;
1790
1791 __entity(INTERFACE, ds->bInterfaceNumber);
1792 if (ds->iInterface)
1793 __entity(STRING, ds->iInterface);
1794 }
1795 break;
1796
1797 case USB_DT_ENDPOINT: {
1798 struct usb_endpoint_descriptor *ds = (void *)_ds;
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001799 pr_vdebug("endpoint descriptor\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001800 if (length != USB_DT_ENDPOINT_SIZE &&
1801 length != USB_DT_ENDPOINT_AUDIO_SIZE)
1802 goto inv_length;
1803 __entity(ENDPOINT, ds->bEndpointAddress);
1804 }
1805 break;
1806
Koen Beel560f1182012-05-30 20:43:37 +02001807 case HID_DT_HID:
1808 pr_vdebug("hid descriptor\n");
1809 if (length != sizeof(struct hid_descriptor))
1810 goto inv_length;
1811 break;
1812
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001813 case USB_DT_OTG:
1814 if (length != sizeof(struct usb_otg_descriptor))
1815 goto inv_length;
1816 break;
1817
1818 case USB_DT_INTERFACE_ASSOCIATION: {
1819 struct usb_interface_assoc_descriptor *ds = (void *)_ds;
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001820 pr_vdebug("interface association descriptor\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001821 if (length != sizeof *ds)
1822 goto inv_length;
1823 if (ds->iFunction)
1824 __entity(STRING, ds->iFunction);
1825 }
1826 break;
1827
Manu Gautam8d4e8972014-02-28 16:50:22 +05301828 case USB_DT_SS_ENDPOINT_COMP:
1829 pr_vdebug("EP SS companion descriptor\n");
1830 if (length != sizeof(struct usb_ss_ep_comp_descriptor))
1831 goto inv_length;
1832 break;
1833
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001834 case USB_DT_OTHER_SPEED_CONFIG:
1835 case USB_DT_INTERFACE_POWER:
1836 case USB_DT_DEBUG:
1837 case USB_DT_SECURITY:
1838 case USB_DT_CS_RADIO_CONTROL:
1839 /* TODO */
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001840 pr_vdebug("unimplemented descriptor: %d\n", _ds->bDescriptorType);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001841 return -EINVAL;
1842
1843 default:
1844 /* We should never be here */
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001845 pr_vdebug("unknown descriptor: %d\n", _ds->bDescriptorType);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001846 return -EINVAL;
1847
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01001848inv_length:
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001849 pr_vdebug("invalid length: %d (descriptor %d)\n",
Michal Nazarewiczd8df0b62010-11-12 14:29:29 +01001850 _ds->bLength, _ds->bDescriptorType);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001851 return -EINVAL;
1852 }
1853
1854#undef __entity
1855#undef __entity_check_DESCRIPTOR
1856#undef __entity_check_INTERFACE
1857#undef __entity_check_STRING
1858#undef __entity_check_ENDPOINT
1859
1860 return length;
1861}
1862
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001863static int __must_check ffs_do_descs(unsigned count, char *data, unsigned len,
1864 ffs_entity_callback entity, void *priv)
1865{
1866 const unsigned _len = len;
1867 unsigned long num = 0;
1868
1869 ENTER();
1870
1871 for (;;) {
1872 int ret;
1873
1874 if (num == count)
1875 data = NULL;
1876
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01001877 /* Record "descriptor" entity */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001878 ret = entity(FFS_DESCRIPTOR, (u8 *)num, (void *)data, priv);
1879 if (unlikely(ret < 0)) {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001880 pr_debug("entity DESCRIPTOR(%02lx); ret = %d\n",
Michal Nazarewiczd8df0b62010-11-12 14:29:29 +01001881 num, ret);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001882 return ret;
1883 }
1884
1885 if (!data)
1886 return _len - len;
1887
Andrzej Pietrasiewiczf96cbd12014-07-09 12:20:06 +02001888 ret = ffs_do_single_desc(data, len, entity, priv);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001889 if (unlikely(ret < 0)) {
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01001890 pr_debug("%s returns %d\n", __func__, ret);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001891 return ret;
1892 }
1893
1894 len -= ret;
1895 data += ret;
1896 ++num;
1897 }
1898}
1899
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001900static int __ffs_data_do_entity(enum ffs_entity_type type,
1901 u8 *valuep, struct usb_descriptor_header *desc,
1902 void *priv)
1903{
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02001904 struct ffs_desc_helper *helper = priv;
1905 struct usb_endpoint_descriptor *d;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001906
1907 ENTER();
1908
1909 switch (type) {
1910 case FFS_DESCRIPTOR:
1911 break;
1912
1913 case FFS_INTERFACE:
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01001914 /*
1915 * Interfaces are indexed from zero so if we
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001916 * encountered interface "n" then there are at least
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01001917 * "n+1" interfaces.
1918 */
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02001919 if (*valuep >= helper->interfaces_count)
1920 helper->interfaces_count = *valuep + 1;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001921 break;
1922
1923 case FFS_STRING:
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01001924 /*
1925 * Strings are indexed from 1 (0 is magic ;) reserved
1926 * for languages list or some such)
1927 */
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02001928 if (*valuep > helper->ffs->strings_count)
1929 helper->ffs->strings_count = *valuep;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001930 break;
1931
1932 case FFS_ENDPOINT:
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02001933 d = (void *)desc;
1934 helper->eps_count++;
1935 if (helper->eps_count >= 15)
1936 return -EINVAL;
1937 /* Check if descriptors for any speed were already parsed */
1938 if (!helper->ffs->eps_count && !helper->ffs->interfaces_count)
1939 helper->ffs->eps_addrmap[helper->eps_count] =
1940 d->bEndpointAddress;
1941 else if (helper->ffs->eps_addrmap[helper->eps_count] !=
1942 d->bEndpointAddress)
1943 return -EINVAL;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02001944 break;
1945 }
1946
1947 return 0;
1948}
1949
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02001950static int __ffs_do_os_desc_header(enum ffs_os_desc_type *next_type,
1951 struct usb_os_desc_header *desc)
1952{
1953 u16 bcd_version = le16_to_cpu(desc->bcdVersion);
1954 u16 w_index = le16_to_cpu(desc->wIndex);
1955
1956 if (bcd_version != 1) {
1957 pr_vdebug("unsupported os descriptors version: %d",
1958 bcd_version);
1959 return -EINVAL;
1960 }
1961 switch (w_index) {
1962 case 0x4:
1963 *next_type = FFS_OS_DESC_EXT_COMPAT;
1964 break;
1965 case 0x5:
1966 *next_type = FFS_OS_DESC_EXT_PROP;
1967 break;
1968 default:
1969 pr_vdebug("unsupported os descriptor type: %d", w_index);
1970 return -EINVAL;
1971 }
1972
1973 return sizeof(*desc);
1974}
1975
1976/*
1977 * Process all extended compatibility/extended property descriptors
1978 * of a feature descriptor
1979 */
1980static int __must_check ffs_do_single_os_desc(char *data, unsigned len,
1981 enum ffs_os_desc_type type,
1982 u16 feature_count,
1983 ffs_os_desc_callback entity,
1984 void *priv,
1985 struct usb_os_desc_header *h)
1986{
1987 int ret;
1988 const unsigned _len = len;
1989
1990 ENTER();
1991
1992 /* loop over all ext compat/ext prop descriptors */
1993 while (feature_count--) {
1994 ret = entity(type, h, data, len, priv);
1995 if (unlikely(ret < 0)) {
1996 pr_debug("bad OS descriptor, type: %d\n", type);
1997 return ret;
1998 }
1999 data += ret;
2000 len -= ret;
2001 }
2002 return _len - len;
2003}
2004
2005/* Process a number of complete Feature Descriptors (Ext Compat or Ext Prop) */
2006static int __must_check ffs_do_os_descs(unsigned count,
2007 char *data, unsigned len,
2008 ffs_os_desc_callback entity, void *priv)
2009{
2010 const unsigned _len = len;
2011 unsigned long num = 0;
2012
2013 ENTER();
2014
2015 for (num = 0; num < count; ++num) {
2016 int ret;
2017 enum ffs_os_desc_type type;
2018 u16 feature_count;
2019 struct usb_os_desc_header *desc = (void *)data;
2020
2021 if (len < sizeof(*desc))
2022 return -EINVAL;
2023
2024 /*
2025 * Record "descriptor" entity.
2026 * Process dwLength, bcdVersion, wIndex, get b/wCount.
2027 * Move the data pointer to the beginning of extended
2028 * compatibilities proper or extended properties proper
2029 * portions of the data
2030 */
2031 if (le32_to_cpu(desc->dwLength) > len)
2032 return -EINVAL;
2033
2034 ret = __ffs_do_os_desc_header(&type, desc);
2035 if (unlikely(ret < 0)) {
2036 pr_debug("entity OS_DESCRIPTOR(%02lx); ret = %d\n",
2037 num, ret);
2038 return ret;
2039 }
2040 /*
2041 * 16-bit hex "?? 00" Little Endian looks like 8-bit hex "??"
2042 */
2043 feature_count = le16_to_cpu(desc->wCount);
2044 if (type == FFS_OS_DESC_EXT_COMPAT &&
2045 (feature_count > 255 || desc->Reserved))
2046 return -EINVAL;
2047 len -= ret;
2048 data += ret;
2049
2050 /*
2051 * Process all function/property descriptors
2052 * of this Feature Descriptor
2053 */
2054 ret = ffs_do_single_os_desc(data, len, type,
2055 feature_count, entity, priv, desc);
2056 if (unlikely(ret < 0)) {
2057 pr_debug("%s returns %d\n", __func__, ret);
2058 return ret;
2059 }
2060
2061 len -= ret;
2062 data += ret;
2063 }
2064 return _len - len;
2065}
2066
2067/**
2068 * Validate contents of the buffer from userspace related to OS descriptors.
2069 */
2070static int __ffs_data_do_os_desc(enum ffs_os_desc_type type,
2071 struct usb_os_desc_header *h, void *data,
2072 unsigned len, void *priv)
2073{
2074 struct ffs_data *ffs = priv;
2075 u8 length;
2076
2077 ENTER();
2078
2079 switch (type) {
2080 case FFS_OS_DESC_EXT_COMPAT: {
2081 struct usb_ext_compat_desc *d = data;
2082 int i;
2083
2084 if (len < sizeof(*d) ||
2085 d->bFirstInterfaceNumber >= ffs->interfaces_count ||
2086 d->Reserved1)
2087 return -EINVAL;
2088 for (i = 0; i < ARRAY_SIZE(d->Reserved2); ++i)
2089 if (d->Reserved2[i])
2090 return -EINVAL;
2091
2092 length = sizeof(struct usb_ext_compat_desc);
2093 }
2094 break;
2095 case FFS_OS_DESC_EXT_PROP: {
2096 struct usb_ext_prop_desc *d = data;
2097 u32 type, pdl;
2098 u16 pnl;
2099
2100 if (len < sizeof(*d) || h->interface >= ffs->interfaces_count)
2101 return -EINVAL;
2102 length = le32_to_cpu(d->dwSize);
2103 type = le32_to_cpu(d->dwPropertyDataType);
2104 if (type < USB_EXT_PROP_UNICODE ||
2105 type > USB_EXT_PROP_UNICODE_MULTI) {
2106 pr_vdebug("unsupported os descriptor property type: %d",
2107 type);
2108 return -EINVAL;
2109 }
2110 pnl = le16_to_cpu(d->wPropertyNameLength);
2111 pdl = le32_to_cpu(*(u32 *)((u8 *)data + 10 + pnl));
2112 if (length != 14 + pnl + pdl) {
2113 pr_vdebug("invalid os descriptor length: %d pnl:%d pdl:%d (descriptor %d)\n",
2114 length, pnl, pdl, type);
2115 return -EINVAL;
2116 }
2117 ++ffs->ms_os_descs_ext_prop_count;
2118 /* property name reported to the host as "WCHAR"s */
2119 ffs->ms_os_descs_ext_prop_name_len += pnl * 2;
2120 ffs->ms_os_descs_ext_prop_data_len += pdl;
2121 }
2122 break;
2123 default:
2124 pr_vdebug("unknown descriptor: %d\n", type);
2125 return -EINVAL;
2126 }
2127 return length;
2128}
2129
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002130static int __ffs_data_got_descs(struct ffs_data *ffs,
2131 char *const _data, size_t len)
2132{
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302133 char *data = _data, *raw_descs;
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002134 unsigned os_descs_count = 0, counts[3], flags;
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302135 int ret = -EINVAL, i;
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02002136 struct ffs_desc_helper helper;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002137
2138 ENTER();
2139
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302140 if (get_unaligned_le32(data + 4) != len)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002141 goto error;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002142
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302143 switch (get_unaligned_le32(data)) {
2144 case FUNCTIONFS_DESCRIPTORS_MAGIC:
2145 flags = FUNCTIONFS_HAS_FS_DESC | FUNCTIONFS_HAS_HS_DESC;
Manu Gautam8d4e8972014-02-28 16:50:22 +05302146 data += 8;
2147 len -= 8;
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302148 break;
2149 case FUNCTIONFS_DESCRIPTORS_MAGIC_V2:
2150 flags = get_unaligned_le32(data + 8);
Robert Baldyga1b0bf882014-09-09 08:23:17 +02002151 ffs->user_flags = flags;
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302152 if (flags & ~(FUNCTIONFS_HAS_FS_DESC |
2153 FUNCTIONFS_HAS_HS_DESC |
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002154 FUNCTIONFS_HAS_SS_DESC |
Robert Baldyga1b0bf882014-09-09 08:23:17 +02002155 FUNCTIONFS_HAS_MS_OS_DESC |
Robert Baldyga5e33f6f2015-01-23 13:41:01 +01002156 FUNCTIONFS_VIRTUAL_ADDR |
2157 FUNCTIONFS_EVENTFD)) {
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302158 ret = -ENOSYS;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002159 goto error;
2160 }
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302161 data += 12;
2162 len -= 12;
2163 break;
2164 default:
2165 goto error;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002166 }
2167
Robert Baldyga5e33f6f2015-01-23 13:41:01 +01002168 if (flags & FUNCTIONFS_EVENTFD) {
2169 if (len < 4)
2170 goto error;
2171 ffs->ffs_eventfd =
2172 eventfd_ctx_fdget((int)get_unaligned_le32(data));
2173 if (IS_ERR(ffs->ffs_eventfd)) {
2174 ret = PTR_ERR(ffs->ffs_eventfd);
2175 ffs->ffs_eventfd = NULL;
2176 goto error;
2177 }
2178 data += 4;
2179 len -= 4;
2180 }
2181
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302182 /* Read fs_count, hs_count and ss_count (if present) */
2183 for (i = 0; i < 3; ++i) {
2184 if (!(flags & (1 << i))) {
2185 counts[i] = 0;
2186 } else if (len < 4) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002187 goto error;
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302188 } else {
2189 counts[i] = get_unaligned_le32(data);
2190 data += 4;
2191 len -= 4;
2192 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002193 }
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002194 if (flags & (1 << i)) {
2195 os_descs_count = get_unaligned_le32(data);
2196 data += 4;
2197 len -= 4;
2198 };
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002199
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302200 /* Read descriptors */
2201 raw_descs = data;
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02002202 helper.ffs = ffs;
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302203 for (i = 0; i < 3; ++i) {
2204 if (!counts[i])
2205 continue;
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02002206 helper.interfaces_count = 0;
2207 helper.eps_count = 0;
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302208 ret = ffs_do_descs(counts[i], data, len,
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02002209 __ffs_data_do_entity, &helper);
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302210 if (ret < 0)
2211 goto error;
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02002212 if (!ffs->eps_count && !ffs->interfaces_count) {
2213 ffs->eps_count = helper.eps_count;
2214 ffs->interfaces_count = helper.interfaces_count;
2215 } else {
2216 if (ffs->eps_count != helper.eps_count) {
2217 ret = -EINVAL;
2218 goto error;
2219 }
2220 if (ffs->interfaces_count != helper.interfaces_count) {
2221 ret = -EINVAL;
2222 goto error;
2223 }
2224 }
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302225 data += ret;
2226 len -= ret;
2227 }
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002228 if (os_descs_count) {
2229 ret = ffs_do_os_descs(os_descs_count, data, len,
2230 __ffs_data_do_os_desc, ffs);
2231 if (ret < 0)
2232 goto error;
2233 data += ret;
2234 len -= ret;
2235 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002236
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302237 if (raw_descs == data || len) {
2238 ret = -EINVAL;
2239 goto error;
2240 }
2241
2242 ffs->raw_descs_data = _data;
2243 ffs->raw_descs = raw_descs;
2244 ffs->raw_descs_length = data - raw_descs;
2245 ffs->fs_descs_count = counts[0];
2246 ffs->hs_descs_count = counts[1];
2247 ffs->ss_descs_count = counts[2];
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002248 ffs->ms_os_descs_count = os_descs_count;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002249
2250 return 0;
2251
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002252error:
2253 kfree(_data);
2254 return ret;
2255}
2256
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002257static int __ffs_data_got_strings(struct ffs_data *ffs,
2258 char *const _data, size_t len)
2259{
2260 u32 str_count, needed_count, lang_count;
2261 struct usb_gadget_strings **stringtabs, *t;
2262 struct usb_string *strings, *s;
2263 const char *data = _data;
2264
2265 ENTER();
2266
2267 if (unlikely(get_unaligned_le32(data) != FUNCTIONFS_STRINGS_MAGIC ||
2268 get_unaligned_le32(data + 4) != len))
2269 goto error;
2270 str_count = get_unaligned_le32(data + 8);
2271 lang_count = get_unaligned_le32(data + 12);
2272
2273 /* if one is zero the other must be zero */
2274 if (unlikely(!str_count != !lang_count))
2275 goto error;
2276
2277 /* Do we have at least as many strings as descriptors need? */
2278 needed_count = ffs->strings_count;
2279 if (unlikely(str_count < needed_count))
2280 goto error;
2281
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002282 /*
2283 * If we don't need any strings just return and free all
2284 * memory.
2285 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002286 if (!needed_count) {
2287 kfree(_data);
2288 return 0;
2289 }
2290
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002291 /* Allocate everything in one chunk so there's less maintenance. */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002292 {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002293 unsigned i = 0;
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002294 vla_group(d);
2295 vla_item(d, struct usb_gadget_strings *, stringtabs,
2296 lang_count + 1);
2297 vla_item(d, struct usb_gadget_strings, stringtab, lang_count);
2298 vla_item(d, struct usb_string, strings,
2299 lang_count*(needed_count+1));
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002300
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002301 char *vlabuf = kmalloc(vla_group_size(d), GFP_KERNEL);
2302
2303 if (unlikely(!vlabuf)) {
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002304 kfree(_data);
2305 return -ENOMEM;
2306 }
2307
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002308 /* Initialize the VLA pointers */
2309 stringtabs = vla_ptr(vlabuf, d, stringtabs);
2310 t = vla_ptr(vlabuf, d, stringtab);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002311 i = lang_count;
2312 do {
2313 *stringtabs++ = t++;
2314 } while (--i);
2315 *stringtabs = NULL;
2316
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002317 /* stringtabs = vlabuf = d_stringtabs for later kfree */
2318 stringtabs = vla_ptr(vlabuf, d, stringtabs);
2319 t = vla_ptr(vlabuf, d, stringtab);
2320 s = vla_ptr(vlabuf, d, strings);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002321 strings = s;
2322 }
2323
2324 /* For each language */
2325 data += 16;
2326 len -= 16;
2327
2328 do { /* lang_count > 0 so we can use do-while */
2329 unsigned needed = needed_count;
2330
2331 if (unlikely(len < 3))
2332 goto error_free;
2333 t->language = get_unaligned_le16(data);
2334 t->strings = s;
2335 ++t;
2336
2337 data += 2;
2338 len -= 2;
2339
2340 /* For each string */
2341 do { /* str_count > 0 so we can use do-while */
2342 size_t length = strnlen(data, len);
2343
2344 if (unlikely(length == len))
2345 goto error_free;
2346
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002347 /*
2348 * User may provide more strings then we need,
2349 * if that's the case we simply ignore the
2350 * rest
2351 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002352 if (likely(needed)) {
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002353 /*
2354 * s->id will be set while adding
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002355 * function to configuration so for
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002356 * now just leave garbage here.
2357 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002358 s->s = data;
2359 --needed;
2360 ++s;
2361 }
2362
2363 data += length + 1;
2364 len -= length + 1;
2365 } while (--str_count);
2366
2367 s->id = 0; /* terminator */
2368 s->s = NULL;
2369 ++s;
2370
2371 } while (--lang_count);
2372
2373 /* Some garbage left? */
2374 if (unlikely(len))
2375 goto error_free;
2376
2377 /* Done! */
2378 ffs->stringtabs = stringtabs;
2379 ffs->raw_strings = _data;
2380
2381 return 0;
2382
2383error_free:
2384 kfree(stringtabs);
2385error:
2386 kfree(_data);
2387 return -EINVAL;
2388}
2389
2390
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002391/* Events handling and management *******************************************/
2392
2393static void __ffs_event_add(struct ffs_data *ffs,
2394 enum usb_functionfs_event_type type)
2395{
2396 enum usb_functionfs_event_type rem_type1, rem_type2 = type;
2397 int neg = 0;
2398
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002399 /*
2400 * Abort any unhandled setup
2401 *
2402 * We do not need to worry about some cmpxchg() changing value
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002403 * of ffs->setup_state without holding the lock because when
2404 * state is FFS_SETUP_PENDING cmpxchg() in several places in
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002405 * the source does nothing.
2406 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002407 if (ffs->setup_state == FFS_SETUP_PENDING)
Michal Nazarewicze46318a2014-02-10 10:42:40 +01002408 ffs->setup_state = FFS_SETUP_CANCELLED;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002409
Michal Nazarewicz67913bb2014-09-10 17:50:24 +02002410 /*
2411 * Logic of this function guarantees that there are at most four pending
2412 * evens on ffs->ev.types queue. This is important because the queue
2413 * has space for four elements only and __ffs_ep0_read_events function
2414 * depends on that limit as well. If more event types are added, those
2415 * limits have to be revisited or guaranteed to still hold.
2416 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002417 switch (type) {
2418 case FUNCTIONFS_RESUME:
2419 rem_type2 = FUNCTIONFS_SUSPEND;
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002420 /* FALL THROUGH */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002421 case FUNCTIONFS_SUSPEND:
2422 case FUNCTIONFS_SETUP:
2423 rem_type1 = type;
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002424 /* Discard all similar events */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002425 break;
2426
2427 case FUNCTIONFS_BIND:
2428 case FUNCTIONFS_UNBIND:
2429 case FUNCTIONFS_DISABLE:
2430 case FUNCTIONFS_ENABLE:
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002431 /* Discard everything other then power management. */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002432 rem_type1 = FUNCTIONFS_SUSPEND;
2433 rem_type2 = FUNCTIONFS_RESUME;
2434 neg = 1;
2435 break;
2436
2437 default:
Michal Nazarewiczfe00bcb2014-09-11 18:52:49 +02002438 WARN(1, "%d: unknown event, this should not happen\n", type);
2439 return;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002440 }
2441
2442 {
2443 u8 *ev = ffs->ev.types, *out = ev;
2444 unsigned n = ffs->ev.count;
2445 for (; n; --n, ++ev)
2446 if ((*ev == rem_type1 || *ev == rem_type2) == neg)
2447 *out++ = *ev;
2448 else
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01002449 pr_vdebug("purging event %d\n", *ev);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002450 ffs->ev.count = out - ffs->ev.types;
2451 }
2452
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01002453 pr_vdebug("adding event %d\n", type);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002454 ffs->ev.types[ffs->ev.count++] = type;
2455 wake_up_locked(&ffs->ev.waitq);
Robert Baldyga5e33f6f2015-01-23 13:41:01 +01002456 if (ffs->ffs_eventfd)
2457 eventfd_signal(ffs->ffs_eventfd, 1);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002458}
2459
2460static void ffs_event_add(struct ffs_data *ffs,
2461 enum usb_functionfs_event_type type)
2462{
2463 unsigned long flags;
2464 spin_lock_irqsave(&ffs->ev.waitq.lock, flags);
2465 __ffs_event_add(ffs, type);
2466 spin_unlock_irqrestore(&ffs->ev.waitq.lock, flags);
2467}
2468
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002469/* Bind/unbind USB function hooks *******************************************/
2470
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02002471static int ffs_ep_addr2idx(struct ffs_data *ffs, u8 endpoint_address)
2472{
2473 int i;
2474
2475 for (i = 1; i < ARRAY_SIZE(ffs->eps_addrmap); ++i)
2476 if (ffs->eps_addrmap[i] == endpoint_address)
2477 return i;
2478 return -ENOENT;
2479}
2480
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002481static int __ffs_func_bind_do_descs(enum ffs_entity_type type, u8 *valuep,
2482 struct usb_descriptor_header *desc,
2483 void *priv)
2484{
2485 struct usb_endpoint_descriptor *ds = (void *)desc;
2486 struct ffs_function *func = priv;
2487 struct ffs_ep *ffs_ep;
Dan Carpenter85b06f52014-09-09 15:06:09 +03002488 unsigned ep_desc_id;
2489 int idx;
Manu Gautam8d4e8972014-02-28 16:50:22 +05302490 static const char *speed_names[] = { "full", "high", "super" };
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002491
2492 if (type != FFS_DESCRIPTOR)
2493 return 0;
2494
Manu Gautam8d4e8972014-02-28 16:50:22 +05302495 /*
2496 * If ss_descriptors is not NULL, we are reading super speed
2497 * descriptors; if hs_descriptors is not NULL, we are reading high
2498 * speed descriptors; otherwise, we are reading full speed
2499 * descriptors.
2500 */
2501 if (func->function.ss_descriptors) {
2502 ep_desc_id = 2;
2503 func->function.ss_descriptors[(long)valuep] = desc;
2504 } else if (func->function.hs_descriptors) {
2505 ep_desc_id = 1;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002506 func->function.hs_descriptors[(long)valuep] = desc;
Manu Gautam8d4e8972014-02-28 16:50:22 +05302507 } else {
2508 ep_desc_id = 0;
Sebastian Andrzej Siewior10287ba2012-10-22 22:15:06 +02002509 func->function.fs_descriptors[(long)valuep] = desc;
Manu Gautam8d4e8972014-02-28 16:50:22 +05302510 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002511
2512 if (!desc || desc->bDescriptorType != USB_DT_ENDPOINT)
2513 return 0;
2514
Robert Baldyga6d5c1c72014-08-25 11:16:27 +02002515 idx = ffs_ep_addr2idx(func->ffs, ds->bEndpointAddress) - 1;
2516 if (idx < 0)
2517 return idx;
2518
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002519 ffs_ep = func->eps + idx;
2520
Manu Gautam8d4e8972014-02-28 16:50:22 +05302521 if (unlikely(ffs_ep->descs[ep_desc_id])) {
2522 pr_err("two %sspeed descriptors for EP %d\n",
2523 speed_names[ep_desc_id],
Michal Nazarewiczd8df0b62010-11-12 14:29:29 +01002524 ds->bEndpointAddress & USB_ENDPOINT_NUMBER_MASK);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002525 return -EINVAL;
2526 }
Manu Gautam8d4e8972014-02-28 16:50:22 +05302527 ffs_ep->descs[ep_desc_id] = ds;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002528
2529 ffs_dump_mem(": Original ep desc", ds, ds->bLength);
2530 if (ffs_ep->ep) {
2531 ds->bEndpointAddress = ffs_ep->descs[0]->bEndpointAddress;
2532 if (!ds->wMaxPacketSize)
2533 ds->wMaxPacketSize = ffs_ep->descs[0]->wMaxPacketSize;
2534 } else {
2535 struct usb_request *req;
2536 struct usb_ep *ep;
Robert Baldyga1b0bf882014-09-09 08:23:17 +02002537 u8 bEndpointAddress;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002538
Robert Baldyga1b0bf882014-09-09 08:23:17 +02002539 /*
2540 * We back up bEndpointAddress because autoconfig overwrites
2541 * it with physical endpoint address.
2542 */
2543 bEndpointAddress = ds->bEndpointAddress;
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01002544 pr_vdebug("autoconfig\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002545 ep = usb_ep_autoconfig(func->gadget, ds);
2546 if (unlikely(!ep))
2547 return -ENOTSUPP;
Joe Perchescc7e60562010-11-14 19:04:49 -08002548 ep->driver_data = func->eps + idx;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002549
2550 req = usb_ep_alloc_request(ep, GFP_KERNEL);
2551 if (unlikely(!req))
2552 return -ENOMEM;
2553
2554 ffs_ep->ep = ep;
2555 ffs_ep->req = req;
2556 func->eps_revmap[ds->bEndpointAddress &
2557 USB_ENDPOINT_NUMBER_MASK] = idx + 1;
Robert Baldyga1b0bf882014-09-09 08:23:17 +02002558 /*
2559 * If we use virtual address mapping, we restore
2560 * original bEndpointAddress value.
2561 */
2562 if (func->ffs->user_flags & FUNCTIONFS_VIRTUAL_ADDR)
2563 ds->bEndpointAddress = bEndpointAddress;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002564 }
2565 ffs_dump_mem(": Rewritten ep desc", ds, ds->bLength);
2566
2567 return 0;
2568}
2569
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002570static int __ffs_func_bind_do_nums(enum ffs_entity_type type, u8 *valuep,
2571 struct usb_descriptor_header *desc,
2572 void *priv)
2573{
2574 struct ffs_function *func = priv;
2575 unsigned idx;
2576 u8 newValue;
2577
2578 switch (type) {
2579 default:
2580 case FFS_DESCRIPTOR:
2581 /* Handled in previous pass by __ffs_func_bind_do_descs() */
2582 return 0;
2583
2584 case FFS_INTERFACE:
2585 idx = *valuep;
2586 if (func->interfaces_nums[idx] < 0) {
2587 int id = usb_interface_id(func->conf, &func->function);
2588 if (unlikely(id < 0))
2589 return id;
2590 func->interfaces_nums[idx] = id;
2591 }
2592 newValue = func->interfaces_nums[idx];
2593 break;
2594
2595 case FFS_STRING:
2596 /* String' IDs are allocated when fsf_data is bound to cdev */
2597 newValue = func->ffs->stringtabs[0]->strings[*valuep - 1].id;
2598 break;
2599
2600 case FFS_ENDPOINT:
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002601 /*
2602 * USB_DT_ENDPOINT are handled in
2603 * __ffs_func_bind_do_descs().
2604 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002605 if (desc->bDescriptorType == USB_DT_ENDPOINT)
2606 return 0;
2607
2608 idx = (*valuep & USB_ENDPOINT_NUMBER_MASK) - 1;
2609 if (unlikely(!func->eps[idx].ep))
2610 return -EINVAL;
2611
2612 {
2613 struct usb_endpoint_descriptor **descs;
2614 descs = func->eps[idx].descs;
2615 newValue = descs[descs[0] ? 0 : 1]->bEndpointAddress;
2616 }
2617 break;
2618 }
2619
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01002620 pr_vdebug("%02x -> %02x\n", *valuep, newValue);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002621 *valuep = newValue;
2622 return 0;
2623}
2624
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002625static int __ffs_func_bind_do_os_desc(enum ffs_os_desc_type type,
2626 struct usb_os_desc_header *h, void *data,
2627 unsigned len, void *priv)
2628{
2629 struct ffs_function *func = priv;
2630 u8 length = 0;
2631
2632 switch (type) {
2633 case FFS_OS_DESC_EXT_COMPAT: {
2634 struct usb_ext_compat_desc *desc = data;
2635 struct usb_os_desc_table *t;
2636
2637 t = &func->function.os_desc_table[desc->bFirstInterfaceNumber];
2638 t->if_id = func->interfaces_nums[desc->bFirstInterfaceNumber];
2639 memcpy(t->os_desc->ext_compat_id, &desc->CompatibleID,
2640 ARRAY_SIZE(desc->CompatibleID) +
2641 ARRAY_SIZE(desc->SubCompatibleID));
2642 length = sizeof(*desc);
2643 }
2644 break;
2645 case FFS_OS_DESC_EXT_PROP: {
2646 struct usb_ext_prop_desc *desc = data;
2647 struct usb_os_desc_table *t;
2648 struct usb_os_desc_ext_prop *ext_prop;
2649 char *ext_prop_name;
2650 char *ext_prop_data;
2651
2652 t = &func->function.os_desc_table[h->interface];
2653 t->if_id = func->interfaces_nums[h->interface];
2654
2655 ext_prop = func->ffs->ms_os_descs_ext_prop_avail;
2656 func->ffs->ms_os_descs_ext_prop_avail += sizeof(*ext_prop);
2657
2658 ext_prop->type = le32_to_cpu(desc->dwPropertyDataType);
2659 ext_prop->name_len = le16_to_cpu(desc->wPropertyNameLength);
2660 ext_prop->data_len = le32_to_cpu(*(u32 *)
2661 usb_ext_prop_data_len_ptr(data, ext_prop->name_len));
2662 length = ext_prop->name_len + ext_prop->data_len + 14;
2663
2664 ext_prop_name = func->ffs->ms_os_descs_ext_prop_name_avail;
2665 func->ffs->ms_os_descs_ext_prop_name_avail +=
2666 ext_prop->name_len;
2667
2668 ext_prop_data = func->ffs->ms_os_descs_ext_prop_data_avail;
2669 func->ffs->ms_os_descs_ext_prop_data_avail +=
2670 ext_prop->data_len;
2671 memcpy(ext_prop_data,
2672 usb_ext_prop_data_ptr(data, ext_prop->name_len),
2673 ext_prop->data_len);
2674 /* unicode data reported to the host as "WCHAR"s */
2675 switch (ext_prop->type) {
2676 case USB_EXT_PROP_UNICODE:
2677 case USB_EXT_PROP_UNICODE_ENV:
2678 case USB_EXT_PROP_UNICODE_LINK:
2679 case USB_EXT_PROP_UNICODE_MULTI:
2680 ext_prop->data_len *= 2;
2681 break;
2682 }
2683 ext_prop->data = ext_prop_data;
2684
2685 memcpy(ext_prop_name, usb_ext_prop_name_ptr(data),
2686 ext_prop->name_len);
2687 /* property name reported to the host as "WCHAR"s */
2688 ext_prop->name_len *= 2;
2689 ext_prop->name = ext_prop_name;
2690
2691 t->os_desc->ext_prop_len +=
2692 ext_prop->name_len + ext_prop->data_len + 14;
2693 ++t->os_desc->ext_prop_count;
2694 list_add_tail(&ext_prop->entry, &t->os_desc->ext_prop);
2695 }
2696 break;
2697 default:
2698 pr_vdebug("unknown descriptor: %d\n", type);
2699 }
2700
2701 return length;
2702}
2703
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01002704static inline struct f_fs_opts *ffs_do_functionfs_bind(struct usb_function *f,
2705 struct usb_configuration *c)
2706{
2707 struct ffs_function *func = ffs_func_from_usb(f);
2708 struct f_fs_opts *ffs_opts =
2709 container_of(f->fi, struct f_fs_opts, func_inst);
2710 int ret;
2711
2712 ENTER();
2713
2714 /*
2715 * Legacy gadget triggers binding in functionfs_ready_callback,
2716 * which already uses locking; taking the same lock here would
2717 * cause a deadlock.
2718 *
2719 * Configfs-enabled gadgets however do need ffs_dev_lock.
2720 */
2721 if (!ffs_opts->no_configfs)
2722 ffs_dev_lock();
2723 ret = ffs_opts->dev->desc_ready ? 0 : -ENODEV;
2724 func->ffs = ffs_opts->dev->ffs_data;
2725 if (!ffs_opts->no_configfs)
2726 ffs_dev_unlock();
2727 if (ret)
2728 return ERR_PTR(ret);
2729
2730 func->conf = c;
2731 func->gadget = c->cdev->gadget;
2732
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01002733 /*
2734 * in drivers/usb/gadget/configfs.c:configfs_composite_bind()
2735 * configurations are bound in sequence with list_for_each_entry,
2736 * in each configuration its functions are bound in sequence
2737 * with list_for_each_entry, so we assume no race condition
2738 * with regard to ffs_opts->bound access
2739 */
2740 if (!ffs_opts->refcnt) {
2741 ret = functionfs_bind(func->ffs, c->cdev);
2742 if (ret)
2743 return ERR_PTR(ret);
2744 }
2745 ffs_opts->refcnt++;
2746 func->function.strings = func->ffs->stringtabs;
2747
2748 return ffs_opts;
2749}
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01002750
2751static int _ffs_func_bind(struct usb_configuration *c,
2752 struct usb_function *f)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002753{
2754 struct ffs_function *func = ffs_func_from_usb(f);
2755 struct ffs_data *ffs = func->ffs;
2756
2757 const int full = !!func->ffs->fs_descs_count;
2758 const int high = gadget_is_dualspeed(func->gadget) &&
2759 func->ffs->hs_descs_count;
Manu Gautam8d4e8972014-02-28 16:50:22 +05302760 const int super = gadget_is_superspeed(func->gadget) &&
2761 func->ffs->ss_descs_count;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002762
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002763 int fs_len, hs_len, ss_len, ret, i;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002764
2765 /* Make it a single chunk, less management later on */
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002766 vla_group(d);
2767 vla_item_with_sz(d, struct ffs_ep, eps, ffs->eps_count);
2768 vla_item_with_sz(d, struct usb_descriptor_header *, fs_descs,
2769 full ? ffs->fs_descs_count + 1 : 0);
2770 vla_item_with_sz(d, struct usb_descriptor_header *, hs_descs,
2771 high ? ffs->hs_descs_count + 1 : 0);
Manu Gautam8d4e8972014-02-28 16:50:22 +05302772 vla_item_with_sz(d, struct usb_descriptor_header *, ss_descs,
2773 super ? ffs->ss_descs_count + 1 : 0);
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002774 vla_item_with_sz(d, short, inums, ffs->interfaces_count);
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002775 vla_item_with_sz(d, struct usb_os_desc_table, os_desc_table,
2776 c->cdev->use_os_string ? ffs->interfaces_count : 0);
2777 vla_item_with_sz(d, char[16], ext_compat,
2778 c->cdev->use_os_string ? ffs->interfaces_count : 0);
2779 vla_item_with_sz(d, struct usb_os_desc, os_desc,
2780 c->cdev->use_os_string ? ffs->interfaces_count : 0);
2781 vla_item_with_sz(d, struct usb_os_desc_ext_prop, ext_prop,
2782 ffs->ms_os_descs_ext_prop_count);
2783 vla_item_with_sz(d, char, ext_prop_name,
2784 ffs->ms_os_descs_ext_prop_name_len);
2785 vla_item_with_sz(d, char, ext_prop_data,
2786 ffs->ms_os_descs_ext_prop_data_len);
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302787 vla_item_with_sz(d, char, raw_descs, ffs->raw_descs_length);
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002788 char *vlabuf;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002789
2790 ENTER();
2791
Manu Gautam8d4e8972014-02-28 16:50:22 +05302792 /* Has descriptors only for speeds gadget does not support */
2793 if (unlikely(!(full | high | super)))
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002794 return -ENOTSUPP;
2795
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002796 /* Allocate a single chunk, less management later on */
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002797 vlabuf = kzalloc(vla_group_size(d), GFP_KERNEL);
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002798 if (unlikely(!vlabuf))
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002799 return -ENOMEM;
2800
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002801 ffs->ms_os_descs_ext_prop_avail = vla_ptr(vlabuf, d, ext_prop);
2802 ffs->ms_os_descs_ext_prop_name_avail =
2803 vla_ptr(vlabuf, d, ext_prop_name);
2804 ffs->ms_os_descs_ext_prop_data_avail =
2805 vla_ptr(vlabuf, d, ext_prop_data);
2806
Michal Nazarewiczac8dde12014-02-28 16:50:23 +05302807 /* Copy descriptors */
2808 memcpy(vla_ptr(vlabuf, d, raw_descs), ffs->raw_descs,
2809 ffs->raw_descs_length);
Manu Gautam8d4e8972014-02-28 16:50:22 +05302810
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002811 memset(vla_ptr(vlabuf, d, inums), 0xff, d_inums__sz);
2812 for (ret = ffs->eps_count; ret; --ret) {
2813 struct ffs_ep *ptr;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002814
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002815 ptr = vla_ptr(vlabuf, d, eps);
2816 ptr[ret].num = -1;
2817 }
2818
2819 /* Save pointers
2820 * d_eps == vlabuf, func->eps used to kfree vlabuf later
2821 */
2822 func->eps = vla_ptr(vlabuf, d, eps);
2823 func->interfaces_nums = vla_ptr(vlabuf, d, inums);
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002824
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002825 /*
2826 * Go through all the endpoint descriptors and allocate
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002827 * endpoints first, so that later we can rewrite the endpoint
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002828 * numbers without worrying that it may be described later on.
2829 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002830 if (likely(full)) {
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002831 func->function.fs_descriptors = vla_ptr(vlabuf, d, fs_descs);
Manu Gautam8d4e8972014-02-28 16:50:22 +05302832 fs_len = ffs_do_descs(ffs->fs_descs_count,
2833 vla_ptr(vlabuf, d, raw_descs),
2834 d_raw_descs__sz,
2835 __ffs_func_bind_do_descs, func);
2836 if (unlikely(fs_len < 0)) {
2837 ret = fs_len;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002838 goto error;
Manu Gautam8d4e8972014-02-28 16:50:22 +05302839 }
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002840 } else {
Manu Gautam8d4e8972014-02-28 16:50:22 +05302841 fs_len = 0;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002842 }
2843
2844 if (likely(high)) {
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002845 func->function.hs_descriptors = vla_ptr(vlabuf, d, hs_descs);
Manu Gautam8d4e8972014-02-28 16:50:22 +05302846 hs_len = ffs_do_descs(ffs->hs_descs_count,
2847 vla_ptr(vlabuf, d, raw_descs) + fs_len,
2848 d_raw_descs__sz - fs_len,
2849 __ffs_func_bind_do_descs, func);
2850 if (unlikely(hs_len < 0)) {
2851 ret = hs_len;
2852 goto error;
2853 }
2854 } else {
2855 hs_len = 0;
2856 }
2857
2858 if (likely(super)) {
2859 func->function.ss_descriptors = vla_ptr(vlabuf, d, ss_descs);
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002860 ss_len = ffs_do_descs(ffs->ss_descs_count,
Manu Gautam8d4e8972014-02-28 16:50:22 +05302861 vla_ptr(vlabuf, d, raw_descs) + fs_len + hs_len,
2862 d_raw_descs__sz - fs_len - hs_len,
2863 __ffs_func_bind_do_descs, func);
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002864 if (unlikely(ss_len < 0)) {
2865 ret = ss_len;
Robert Baldyga88548942013-09-27 12:28:54 +02002866 goto error;
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002867 }
2868 } else {
2869 ss_len = 0;
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002870 }
2871
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002872 /*
2873 * Now handle interface numbers allocation and interface and
2874 * endpoint numbers rewriting. We can do that in one go
2875 * now.
2876 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002877 ret = ffs_do_descs(ffs->fs_descs_count +
Manu Gautam8d4e8972014-02-28 16:50:22 +05302878 (high ? ffs->hs_descs_count : 0) +
2879 (super ? ffs->ss_descs_count : 0),
Andrzej Pietrasiewicze6f38622013-12-03 15:15:30 +01002880 vla_ptr(vlabuf, d, raw_descs), d_raw_descs__sz,
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002881 __ffs_func_bind_do_nums, func);
2882 if (unlikely(ret < 0))
2883 goto error;
2884
Andrzej Pietrasiewiczf0175ab2014-07-09 12:20:08 +02002885 func->function.os_desc_table = vla_ptr(vlabuf, d, os_desc_table);
2886 if (c->cdev->use_os_string)
2887 for (i = 0; i < ffs->interfaces_count; ++i) {
2888 struct usb_os_desc *desc;
2889
2890 desc = func->function.os_desc_table[i].os_desc =
2891 vla_ptr(vlabuf, d, os_desc) +
2892 i * sizeof(struct usb_os_desc);
2893 desc->ext_compat_id =
2894 vla_ptr(vlabuf, d, ext_compat) + i * 16;
2895 INIT_LIST_HEAD(&desc->ext_prop);
2896 }
2897 ret = ffs_do_os_descs(ffs->ms_os_descs_count,
2898 vla_ptr(vlabuf, d, raw_descs) +
2899 fs_len + hs_len + ss_len,
2900 d_raw_descs__sz - fs_len - hs_len - ss_len,
2901 __ffs_func_bind_do_os_desc, func);
2902 if (unlikely(ret < 0))
2903 goto error;
2904 func->function.os_desc_n =
2905 c->cdev->use_os_string ? ffs->interfaces_count : 0;
2906
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002907 /* And we're done */
2908 ffs_event_add(ffs, FUNCTIONFS_BIND);
2909 return 0;
2910
2911error:
2912 /* XXX Do we need to release all claimed endpoints here? */
2913 return ret;
2914}
2915
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01002916static int ffs_func_bind(struct usb_configuration *c,
2917 struct usb_function *f)
2918{
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01002919 struct f_fs_opts *ffs_opts = ffs_do_functionfs_bind(f, c);
2920
2921 if (IS_ERR(ffs_opts))
2922 return PTR_ERR(ffs_opts);
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01002923
2924 return _ffs_func_bind(c, f);
2925}
2926
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002927
2928/* Other USB function hooks *************************************************/
2929
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01002930static void ffs_reset_work(struct work_struct *work)
2931{
2932 struct ffs_data *ffs = container_of(work,
2933 struct ffs_data, reset_work);
2934 ffs_data_reset(ffs);
2935}
2936
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002937static int ffs_func_set_alt(struct usb_function *f,
2938 unsigned interface, unsigned alt)
2939{
2940 struct ffs_function *func = ffs_func_from_usb(f);
2941 struct ffs_data *ffs = func->ffs;
2942 int ret = 0, intf;
2943
2944 if (alt != (unsigned)-1) {
2945 intf = ffs_func_revmap_intf(func, interface);
2946 if (unlikely(intf < 0))
2947 return intf;
2948 }
2949
2950 if (ffs->func)
2951 ffs_func_eps_disable(ffs->func);
2952
Robert Baldyga18d6b32f2014-12-18 09:55:10 +01002953 if (ffs->state == FFS_DEACTIVATED) {
2954 ffs->state = FFS_CLOSING;
2955 INIT_WORK(&ffs->reset_work, ffs_reset_work);
2956 schedule_work(&ffs->reset_work);
2957 return -ENODEV;
2958 }
2959
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002960 if (ffs->state != FFS_ACTIVE)
2961 return -ENODEV;
2962
2963 if (alt == (unsigned)-1) {
2964 ffs->func = NULL;
2965 ffs_event_add(ffs, FUNCTIONFS_DISABLE);
2966 return 0;
2967 }
2968
2969 ffs->func = func;
2970 ret = ffs_func_eps_enable(func);
2971 if (likely(ret >= 0))
2972 ffs_event_add(ffs, FUNCTIONFS_ENABLE);
2973 return ret;
2974}
2975
2976static void ffs_func_disable(struct usb_function *f)
2977{
2978 ffs_func_set_alt(f, 0, (unsigned)-1);
2979}
2980
2981static int ffs_func_setup(struct usb_function *f,
2982 const struct usb_ctrlrequest *creq)
2983{
2984 struct ffs_function *func = ffs_func_from_usb(f);
2985 struct ffs_data *ffs = func->ffs;
2986 unsigned long flags;
2987 int ret;
2988
2989 ENTER();
2990
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01002991 pr_vdebug("creq->bRequestType = %02x\n", creq->bRequestType);
2992 pr_vdebug("creq->bRequest = %02x\n", creq->bRequest);
2993 pr_vdebug("creq->wValue = %04x\n", le16_to_cpu(creq->wValue));
2994 pr_vdebug("creq->wIndex = %04x\n", le16_to_cpu(creq->wIndex));
2995 pr_vdebug("creq->wLength = %04x\n", le16_to_cpu(creq->wLength));
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002996
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01002997 /*
2998 * Most requests directed to interface go through here
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02002999 * (notable exceptions are set/get interface) so we need to
3000 * handle them. All other either handled by composite or
3001 * passed to usb_configuration->setup() (if one is set). No
3002 * matter, we will handle requests directed to endpoint here
3003 * as well (as it's straightforward) but what to do with any
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01003004 * other request?
3005 */
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02003006 if (ffs->state != FFS_ACTIVE)
3007 return -ENODEV;
3008
3009 switch (creq->bRequestType & USB_RECIP_MASK) {
3010 case USB_RECIP_INTERFACE:
3011 ret = ffs_func_revmap_intf(func, le16_to_cpu(creq->wIndex));
3012 if (unlikely(ret < 0))
3013 return ret;
3014 break;
3015
3016 case USB_RECIP_ENDPOINT:
3017 ret = ffs_func_revmap_ep(func, le16_to_cpu(creq->wIndex));
3018 if (unlikely(ret < 0))
3019 return ret;
Robert Baldyga1b0bf882014-09-09 08:23:17 +02003020 if (func->ffs->user_flags & FUNCTIONFS_VIRTUAL_ADDR)
3021 ret = func->ffs->eps_addrmap[ret];
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02003022 break;
3023
3024 default:
3025 return -EOPNOTSUPP;
3026 }
3027
3028 spin_lock_irqsave(&ffs->ev.waitq.lock, flags);
3029 ffs->ev.setup = *creq;
3030 ffs->ev.setup.wIndex = cpu_to_le16(ret);
3031 __ffs_event_add(ffs, FUNCTIONFS_SETUP);
3032 spin_unlock_irqrestore(&ffs->ev.waitq.lock, flags);
3033
3034 return 0;
3035}
3036
3037static void ffs_func_suspend(struct usb_function *f)
3038{
3039 ENTER();
3040 ffs_event_add(ffs_func_from_usb(f)->ffs, FUNCTIONFS_SUSPEND);
3041}
3042
3043static void ffs_func_resume(struct usb_function *f)
3044{
3045 ENTER();
3046 ffs_event_add(ffs_func_from_usb(f)->ffs, FUNCTIONFS_RESUME);
3047}
3048
3049
Michal Nazarewicz5ab54cf2010-11-12 14:29:28 +01003050/* Endpoint and interface numbers reverse mapping ***************************/
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02003051
3052static int ffs_func_revmap_ep(struct ffs_function *func, u8 num)
3053{
3054 num = func->eps_revmap[num & USB_ENDPOINT_NUMBER_MASK];
3055 return num ? num : -EDOM;
3056}
3057
3058static int ffs_func_revmap_intf(struct ffs_function *func, u8 intf)
3059{
3060 short *nums = func->interfaces_nums;
3061 unsigned count = func->ffs->interfaces_count;
3062
3063 for (; count; --count, ++nums) {
3064 if (*nums >= 0 && *nums == intf)
3065 return nums - func->interfaces_nums;
3066 }
3067
3068 return -EDOM;
3069}
3070
3071
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003072/* Devices management *******************************************************/
3073
3074static LIST_HEAD(ffs_devices);
3075
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003076static struct ffs_dev *_ffs_do_find_dev(const char *name)
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003077{
3078 struct ffs_dev *dev;
3079
3080 list_for_each_entry(dev, &ffs_devices, entry) {
3081 if (!dev->name || !name)
3082 continue;
3083 if (strcmp(dev->name, name) == 0)
3084 return dev;
3085 }
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +01003086
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003087 return NULL;
3088}
3089
3090/*
3091 * ffs_lock must be taken by the caller of this function
3092 */
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003093static struct ffs_dev *_ffs_get_single_dev(void)
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003094{
3095 struct ffs_dev *dev;
3096
3097 if (list_is_singular(&ffs_devices)) {
3098 dev = list_first_entry(&ffs_devices, struct ffs_dev, entry);
3099 if (dev->single)
3100 return dev;
3101 }
3102
3103 return NULL;
3104}
3105
3106/*
3107 * ffs_lock must be taken by the caller of this function
3108 */
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003109static struct ffs_dev *_ffs_find_dev(const char *name)
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003110{
3111 struct ffs_dev *dev;
3112
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003113 dev = _ffs_get_single_dev();
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003114 if (dev)
3115 return dev;
3116
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003117 return _ffs_do_find_dev(name);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003118}
3119
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +01003120/* Configfs support *********************************************************/
3121
3122static inline struct f_fs_opts *to_ffs_opts(struct config_item *item)
3123{
3124 return container_of(to_config_group(item), struct f_fs_opts,
3125 func_inst.group);
3126}
3127
3128static void ffs_attr_release(struct config_item *item)
3129{
3130 struct f_fs_opts *opts = to_ffs_opts(item);
3131
3132 usb_put_function_instance(&opts->func_inst);
3133}
3134
3135static struct configfs_item_operations ffs_item_ops = {
3136 .release = ffs_attr_release,
3137};
3138
3139static struct config_item_type ffs_func_type = {
3140 .ct_item_ops = &ffs_item_ops,
3141 .ct_owner = THIS_MODULE,
3142};
3143
3144
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003145/* Function registration interface ******************************************/
3146
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003147static void ffs_free_inst(struct usb_function_instance *f)
3148{
3149 struct f_fs_opts *opts;
3150
3151 opts = to_f_fs_opts(f);
3152 ffs_dev_lock();
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003153 _ffs_free_dev(opts->dev);
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003154 ffs_dev_unlock();
3155 kfree(opts);
3156}
3157
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +01003158#define MAX_INST_NAME_LEN 40
3159
3160static int ffs_set_inst_name(struct usb_function_instance *fi, const char *name)
3161{
3162 struct f_fs_opts *opts;
3163 char *ptr;
3164 const char *tmp;
3165 int name_len, ret;
3166
3167 name_len = strlen(name) + 1;
3168 if (name_len > MAX_INST_NAME_LEN)
3169 return -ENAMETOOLONG;
3170
3171 ptr = kstrndup(name, name_len, GFP_KERNEL);
3172 if (!ptr)
3173 return -ENOMEM;
3174
3175 opts = to_f_fs_opts(fi);
3176 tmp = NULL;
3177
3178 ffs_dev_lock();
3179
3180 tmp = opts->dev->name_allocated ? opts->dev->name : NULL;
3181 ret = _ffs_name_dev(opts->dev, ptr);
3182 if (ret) {
3183 kfree(ptr);
3184 ffs_dev_unlock();
3185 return ret;
3186 }
3187 opts->dev->name_allocated = true;
3188
3189 ffs_dev_unlock();
3190
3191 kfree(tmp);
3192
3193 return 0;
3194}
3195
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003196static struct usb_function_instance *ffs_alloc_inst(void)
3197{
3198 struct f_fs_opts *opts;
3199 struct ffs_dev *dev;
3200
3201 opts = kzalloc(sizeof(*opts), GFP_KERNEL);
3202 if (!opts)
3203 return ERR_PTR(-ENOMEM);
3204
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +01003205 opts->func_inst.set_inst_name = ffs_set_inst_name;
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003206 opts->func_inst.free_func_inst = ffs_free_inst;
3207 ffs_dev_lock();
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003208 dev = _ffs_alloc_dev();
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003209 ffs_dev_unlock();
3210 if (IS_ERR(dev)) {
3211 kfree(opts);
3212 return ERR_CAST(dev);
3213 }
3214 opts->dev = dev;
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +01003215 dev->opts = opts;
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003216
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +01003217 config_group_init_type_name(&opts->func_inst.group, "",
3218 &ffs_func_type);
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003219 return &opts->func_inst;
3220}
3221
3222static void ffs_free(struct usb_function *f)
3223{
3224 kfree(ffs_func_from_usb(f));
3225}
3226
3227static void ffs_func_unbind(struct usb_configuration *c,
3228 struct usb_function *f)
3229{
3230 struct ffs_function *func = ffs_func_from_usb(f);
3231 struct ffs_data *ffs = func->ffs;
3232 struct f_fs_opts *opts =
3233 container_of(f->fi, struct f_fs_opts, func_inst);
3234 struct ffs_ep *ep = func->eps;
3235 unsigned count = ffs->eps_count;
3236 unsigned long flags;
3237
3238 ENTER();
3239 if (ffs->func == func) {
3240 ffs_func_eps_disable(func);
3241 ffs->func = NULL;
3242 }
3243
3244 if (!--opts->refcnt)
3245 functionfs_unbind(ffs);
3246
3247 /* cleanup after autoconfig */
3248 spin_lock_irqsave(&func->ffs->eps_lock, flags);
3249 do {
3250 if (ep->ep && ep->req)
3251 usb_ep_free_request(ep->ep, ep->req);
3252 ep->req = NULL;
3253 ++ep;
3254 } while (--count);
3255 spin_unlock_irqrestore(&func->ffs->eps_lock, flags);
3256 kfree(func->eps);
3257 func->eps = NULL;
3258 /*
3259 * eps, descriptors and interfaces_nums are allocated in the
3260 * same chunk so only one free is required.
3261 */
3262 func->function.fs_descriptors = NULL;
3263 func->function.hs_descriptors = NULL;
Manu Gautam8d4e8972014-02-28 16:50:22 +05303264 func->function.ss_descriptors = NULL;
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003265 func->interfaces_nums = NULL;
3266
3267 ffs_event_add(ffs, FUNCTIONFS_UNBIND);
3268}
3269
3270static struct usb_function *ffs_alloc(struct usb_function_instance *fi)
3271{
3272 struct ffs_function *func;
3273
3274 ENTER();
3275
3276 func = kzalloc(sizeof(*func), GFP_KERNEL);
3277 if (unlikely(!func))
3278 return ERR_PTR(-ENOMEM);
3279
3280 func->function.name = "Function FS Gadget";
3281
3282 func->function.bind = ffs_func_bind;
3283 func->function.unbind = ffs_func_unbind;
3284 func->function.set_alt = ffs_func_set_alt;
3285 func->function.disable = ffs_func_disable;
3286 func->function.setup = ffs_func_setup;
3287 func->function.suspend = ffs_func_suspend;
3288 func->function.resume = ffs_func_resume;
3289 func->function.free_func = ffs_free;
3290
3291 return &func->function;
3292}
3293
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003294/*
3295 * ffs_lock must be taken by the caller of this function
3296 */
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003297static struct ffs_dev *_ffs_alloc_dev(void)
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003298{
3299 struct ffs_dev *dev;
3300 int ret;
3301
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003302 if (_ffs_get_single_dev())
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003303 return ERR_PTR(-EBUSY);
3304
3305 dev = kzalloc(sizeof(*dev), GFP_KERNEL);
3306 if (!dev)
3307 return ERR_PTR(-ENOMEM);
3308
3309 if (list_empty(&ffs_devices)) {
3310 ret = functionfs_init();
3311 if (ret) {
3312 kfree(dev);
3313 return ERR_PTR(ret);
3314 }
3315 }
3316
3317 list_add(&dev->entry, &ffs_devices);
3318
3319 return dev;
3320}
3321
3322/*
3323 * ffs_lock must be taken by the caller of this function
3324 * The caller is responsible for "name" being available whenever f_fs needs it
3325 */
3326static int _ffs_name_dev(struct ffs_dev *dev, const char *name)
3327{
3328 struct ffs_dev *existing;
3329
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003330 existing = _ffs_do_find_dev(name);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003331 if (existing)
3332 return -EBUSY;
Andrzej Pietrasiewiczab13cb02014-01-13 16:49:36 +01003333
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003334 dev->name = name;
3335
3336 return 0;
3337}
3338
3339/*
3340 * The caller is responsible for "name" being available whenever f_fs needs it
3341 */
3342int ffs_name_dev(struct ffs_dev *dev, const char *name)
3343{
3344 int ret;
3345
3346 ffs_dev_lock();
3347 ret = _ffs_name_dev(dev, name);
3348 ffs_dev_unlock();
3349
3350 return ret;
3351}
Felipe Balbi0700faa2014-04-01 13:19:32 -05003352EXPORT_SYMBOL_GPL(ffs_name_dev);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003353
3354int ffs_single_dev(struct ffs_dev *dev)
3355{
3356 int ret;
3357
3358 ret = 0;
3359 ffs_dev_lock();
3360
3361 if (!list_is_singular(&ffs_devices))
3362 ret = -EBUSY;
3363 else
3364 dev->single = true;
3365
3366 ffs_dev_unlock();
3367 return ret;
3368}
Felipe Balbi0700faa2014-04-01 13:19:32 -05003369EXPORT_SYMBOL_GPL(ffs_single_dev);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003370
3371/*
3372 * ffs_lock must be taken by the caller of this function
3373 */
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003374static void _ffs_free_dev(struct ffs_dev *dev)
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003375{
3376 list_del(&dev->entry);
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +01003377 if (dev->name_allocated)
3378 kfree(dev->name);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003379 kfree(dev);
3380 if (list_empty(&ffs_devices))
3381 functionfs_cleanup();
3382}
3383
3384static void *ffs_acquire_dev(const char *dev_name)
3385{
3386 struct ffs_dev *ffs_dev;
3387
3388 ENTER();
3389 ffs_dev_lock();
3390
Andrzej Pietrasiewiczda13a772014-01-13 16:49:38 +01003391 ffs_dev = _ffs_find_dev(dev_name);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003392 if (!ffs_dev)
Krzysztof Opasiakd668b4f2014-05-21 14:05:35 +02003393 ffs_dev = ERR_PTR(-ENOENT);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003394 else if (ffs_dev->mounted)
3395 ffs_dev = ERR_PTR(-EBUSY);
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003396 else if (ffs_dev->ffs_acquire_dev_callback &&
3397 ffs_dev->ffs_acquire_dev_callback(ffs_dev))
Krzysztof Opasiakd668b4f2014-05-21 14:05:35 +02003398 ffs_dev = ERR_PTR(-ENOENT);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003399 else
3400 ffs_dev->mounted = true;
3401
3402 ffs_dev_unlock();
3403 return ffs_dev;
3404}
3405
3406static void ffs_release_dev(struct ffs_data *ffs_data)
3407{
3408 struct ffs_dev *ffs_dev;
3409
3410 ENTER();
3411 ffs_dev_lock();
3412
3413 ffs_dev = ffs_data->private_data;
Andrzej Pietrasiewiczea365922014-01-13 16:49:35 +01003414 if (ffs_dev) {
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003415 ffs_dev->mounted = false;
Andrzej Pietrasiewiczea365922014-01-13 16:49:35 +01003416
3417 if (ffs_dev->ffs_release_dev_callback)
3418 ffs_dev->ffs_release_dev_callback(ffs_dev);
3419 }
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003420
3421 ffs_dev_unlock();
3422}
3423
3424static int ffs_ready(struct ffs_data *ffs)
3425{
3426 struct ffs_dev *ffs_obj;
3427 int ret = 0;
3428
3429 ENTER();
3430 ffs_dev_lock();
3431
3432 ffs_obj = ffs->private_data;
3433 if (!ffs_obj) {
3434 ret = -EINVAL;
3435 goto done;
3436 }
3437 if (WARN_ON(ffs_obj->desc_ready)) {
3438 ret = -EBUSY;
3439 goto done;
3440 }
3441
3442 ffs_obj->desc_ready = true;
3443 ffs_obj->ffs_data = ffs;
3444
3445 if (ffs_obj->ffs_ready_callback)
3446 ret = ffs_obj->ffs_ready_callback(ffs);
3447
3448done:
3449 ffs_dev_unlock();
3450 return ret;
3451}
3452
3453static void ffs_closed(struct ffs_data *ffs)
3454{
3455 struct ffs_dev *ffs_obj;
3456
3457 ENTER();
3458 ffs_dev_lock();
3459
3460 ffs_obj = ffs->private_data;
3461 if (!ffs_obj)
3462 goto done;
3463
3464 ffs_obj->desc_ready = false;
3465
3466 if (ffs_obj->ffs_closed_callback)
3467 ffs_obj->ffs_closed_callback(ffs);
Andrzej Pietrasiewiczb6584992013-12-03 15:15:36 +01003468
3469 if (!ffs_obj->opts || ffs_obj->opts->no_configfs
3470 || !ffs_obj->opts->func_inst.group.cg_item.ci_parent)
3471 goto done;
3472
3473 unregister_gadget_item(ffs_obj->opts->
3474 func_inst.group.cg_item.ci_parent->ci_parent);
Andrzej Pietrasiewicz4b187fc2013-12-03 15:15:32 +01003475done:
3476 ffs_dev_unlock();
3477}
3478
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02003479/* Misc helper functions ****************************************************/
3480
3481static int ffs_mutex_lock(struct mutex *mutex, unsigned nonblock)
3482{
3483 return nonblock
3484 ? likely(mutex_trylock(mutex)) ? 0 : -EAGAIN
3485 : mutex_lock_interruptible(mutex);
3486}
3487
Al Viro260ef312012-09-26 21:43:45 -04003488static char *ffs_prepare_buffer(const char __user *buf, size_t len)
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02003489{
3490 char *data;
3491
3492 if (unlikely(!len))
3493 return NULL;
3494
3495 data = kmalloc(len, GFP_KERNEL);
3496 if (unlikely(!data))
3497 return ERR_PTR(-ENOMEM);
3498
3499 if (unlikely(__copy_from_user(data, buf, len))) {
3500 kfree(data);
3501 return ERR_PTR(-EFAULT);
3502 }
3503
Michal Nazarewiczaa02f172010-11-17 17:09:47 +01003504 pr_vdebug("Buffer from user space:\n");
Michal Nazarewiczddf8abd2010-05-05 12:53:14 +02003505 ffs_dump_mem("", data, len);
3506
3507 return data;
3508}
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003509
Andrzej Pietrasiewicz5920cda2013-12-03 15:15:33 +01003510DECLARE_USB_FUNCTION_INIT(ffs, ffs_alloc_inst, ffs_alloc);
3511MODULE_LICENSE("GPL");
3512MODULE_AUTHOR("Michal Nazarewicz");