aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/gadget/storage_common.c
diff options
context:
space:
mode:
authorMichal Nazarewicz <m.nazarewicz@samsung.com>2010-07-05 10:38:04 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2010-08-10 17:35:38 -0400
commitd0893264db29b9bfdb1bc66e731f4ed7f8b52795 (patch)
treeb72a6637bcb4541e0e9429c0019e5f7e45805070 /drivers/usb/gadget/storage_common.c
parent1e413943fabdc228e86e4fbaa11e77efa861c23f (diff)
USB: gadget: storage_common: comments updated
Updated comment to describe why printing macros are needed even thought they are copied form the composite.h. Also, made multiline comments follow the coding standard. Signed-off-by: Michal Nazarewicz <m.nazarewicz@samsung.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/gadget/storage_common.c')
-rw-r--r--drivers/usb/gadget/storage_common.c69
1 files changed, 48 insertions, 21 deletions
diff --git a/drivers/usb/gadget/storage_common.c b/drivers/usb/gadget/storage_common.c
index 04c462ff0ea6..a10faecfabcd 100644
--- a/drivers/usb/gadget/storage_common.c
+++ b/drivers/usb/gadget/storage_common.c
@@ -57,10 +57,12 @@
57#include <asm/unaligned.h> 57#include <asm/unaligned.h>
58 58
59 59
60/* Thanks to NetChip Technologies for donating this product ID. 60/*
61 * Thanks to NetChip Technologies for donating this product ID.
61 * 62 *
62 * DO NOT REUSE THESE IDs with any other driver!! Ever!! 63 * DO NOT REUSE THESE IDs with any other driver!! Ever!!
63 * Instead: allocate your own, using normal USB-IF procedures. */ 64 * Instead: allocate your own, using normal USB-IF procedures.
65 */
64#define FSG_VENDOR_ID 0x0525 /* NetChip */ 66#define FSG_VENDOR_ID 0x0525 /* NetChip */
65#define FSG_PRODUCT_ID 0xa4a5 /* Linux-USB File-backed Storage Gadget */ 67#define FSG_PRODUCT_ID 0xa4a5 /* Linux-USB File-backed Storage Gadget */
66 68
@@ -84,14 +86,27 @@
84#define LWARN(lun, fmt, args...) dev_warn(&(lun)->dev, fmt, ## args) 86#define LWARN(lun, fmt, args...) dev_warn(&(lun)->dev, fmt, ## args)
85#define LINFO(lun, fmt, args...) dev_info(&(lun)->dev, fmt, ## args) 87#define LINFO(lun, fmt, args...) dev_info(&(lun)->dev, fmt, ## args)
86 88
87/* Keep those macros in sync with thos in 89/*
88 * include/linux/ubs/composite.h or else GCC will complain. If they 90 * Keep those macros in sync with those in
91 * include/linux/usb/composite.h or else GCC will complain. If they
89 * are identical (the same names of arguments, white spaces in the 92 * are identical (the same names of arguments, white spaces in the
90 * same places) GCC will allow redefinition otherwise (even if some 93 * same places) GCC will allow redefinition otherwise (even if some
91 * white space is removed or added) warning will be issued. No 94 * white space is removed or added) warning will be issued.
92 * checking if those symbols is defined is performed because warning 95 *
93 * is desired when those macros were defined by someone else to mean 96 * Those macros are needed here because File Storage Gadget does not
94 * something else. */ 97 * include the composite.h header. For composite gadgets those macros
98 * are redundant since composite.h is included any way.
99 *
100 * One could check whether those macros are already defined (which
101 * would indicate composite.h had been included) or not (which would
102 * indicate we were in FSG) but this is not done because a warning is
103 * desired if definitions here differ from the ones in composite.h.
104 *
105 * We want the definitions to match and be the same in File Storage
106 * Gadget as well as Mass Storage Function (and so composite gadgets
107 * using MSF). If someone changes them in composite.h it will produce
108 * a warning in this file when building MSF.
109 */
95#define DBG(d, fmt, args...) dev_dbg(&(d)->gadget->dev , fmt , ## args) 110#define DBG(d, fmt, args...) dev_dbg(&(d)->gadget->dev , fmt , ## args)
96#define VDBG(d, fmt, args...) dev_vdbg(&(d)->gadget->dev , fmt , ## args) 111#define VDBG(d, fmt, args...) dev_vdbg(&(d)->gadget->dev , fmt , ## args)
97#define ERROR(d, fmt, args...) dev_err(&(d)->gadget->dev , fmt , ## args) 112#define ERROR(d, fmt, args...) dev_err(&(d)->gadget->dev , fmt , ## args)
@@ -313,9 +328,11 @@ struct fsg_buffhd {
313 enum fsg_buffer_state state; 328 enum fsg_buffer_state state;
314 struct fsg_buffhd *next; 329 struct fsg_buffhd *next;
315 330
316 /* The NetChip 2280 is faster, and handles some protocol faults 331 /*
332 * The NetChip 2280 is faster, and handles some protocol faults
317 * better, if we don't submit any short bulk-out read requests. 333 * better, if we don't submit any short bulk-out read requests.
318 * So we will record the intended request length here. */ 334 * So we will record the intended request length here.
335 */
319 unsigned int bulk_out_intended_length; 336 unsigned int bulk_out_intended_length;
320 337
321 struct usb_request *inreq; 338 struct usb_request *inreq;
@@ -395,8 +412,10 @@ fsg_intf_desc = {
395 .iInterface = FSG_STRING_INTERFACE, 412 .iInterface = FSG_STRING_INTERFACE,
396}; 413};
397 414
398/* Three full-speed endpoint descriptors: bulk-in, bulk-out, 415/*
399 * and interrupt-in. */ 416 * Three full-speed endpoint descriptors: bulk-in, bulk-out, and
417 * interrupt-in.
418 */
400 419
401static struct usb_endpoint_descriptor 420static struct usb_endpoint_descriptor
402fsg_fs_bulk_in_desc = { 421fsg_fs_bulk_in_desc = {
@@ -459,7 +478,7 @@ static struct usb_descriptor_header *fsg_fs_function[] = {
459 * 478 *
460 * That means alternate endpoint descriptors (bigger packets) 479 * That means alternate endpoint descriptors (bigger packets)
461 * and a "device qualifier" ... plus more construction options 480 * and a "device qualifier" ... plus more construction options
462 * for the config descriptor. 481 * for the configuration descriptor.
463 */ 482 */
464static struct usb_endpoint_descriptor 483static struct usb_endpoint_descriptor
465fsg_hs_bulk_in_desc = { 484fsg_hs_bulk_in_desc = {
@@ -547,8 +566,10 @@ static struct usb_gadget_strings fsg_stringtab = {
547 566
548 /*-------------------------------------------------------------------------*/ 567 /*-------------------------------------------------------------------------*/
549 568
550/* If the next two routines are called while the gadget is registered, 569/*
551 * the caller must own fsg->filesem for writing. */ 570 * If the next two routines are called while the gadget is registered,
571 * the caller must own fsg->filesem for writing.
572 */
552 573
553static int fsg_lun_open(struct fsg_lun *curlun, const char *filename) 574static int fsg_lun_open(struct fsg_lun *curlun, const char *filename)
554{ 575{
@@ -587,8 +608,10 @@ static int fsg_lun_open(struct fsg_lun *curlun, const char *filename)
587 goto out; 608 goto out;
588 } 609 }
589 610
590 /* If we can't read the file, it's no good. 611 /*
591 * If we can't write the file, use it read-only. */ 612 * If we can't read the file, it's no good.
613 * If we can't write the file, use it read-only.
614 */
592 if (!filp->f_op || !(filp->f_op->read || filp->f_op->aio_read)) { 615 if (!filp->f_op || !(filp->f_op->read || filp->f_op->aio_read)) {
593 LINFO(curlun, "file not readable: %s\n", filename); 616 LINFO(curlun, "file not readable: %s\n", filename);
594 goto out; 617 goto out;
@@ -646,8 +669,10 @@ static void fsg_lun_close(struct fsg_lun *curlun)
646 669
647/*-------------------------------------------------------------------------*/ 670/*-------------------------------------------------------------------------*/
648 671
649/* Sync the file data, don't bother with the metadata. 672/*
650 * This code was copied from fs/buffer.c:sys_fdatasync(). */ 673 * Sync the file data, don't bother with the metadata.
674 * This code was copied from fs/buffer.c:sys_fdatasync().
675 */
651static int fsg_lun_fsync_sub(struct fsg_lun *curlun) 676static int fsg_lun_fsync_sub(struct fsg_lun *curlun)
652{ 677{
653 struct file *filp = curlun->filp; 678 struct file *filp = curlun->filp;
@@ -728,8 +753,10 @@ static ssize_t fsg_store_ro(struct device *dev, struct device_attribute *attr,
728 if (sscanf(buf, "%d", &i) != 1) 753 if (sscanf(buf, "%d", &i) != 1)
729 return -EINVAL; 754 return -EINVAL;
730 755
731 /* Allow the write-enable status to change only while the backing file 756 /*
732 * is closed. */ 757 * Allow the write-enable status to change only while the
758 * backing file is closed.
759 */
733 down_read(filesem); 760 down_read(filesem);
734 if (fsg_lun_is_open(curlun)) { 761 if (fsg_lun_is_open(curlun)) {
735 LDBG(curlun, "read-only status change prevented\n"); 762 LDBG(curlun, "read-only status change prevented\n");