usb: gadget: mtp: add new ioctl for compat
authorRohith Seelaboyina <rseelaboyina@nvidia.com>
Wed, 5 Mar 2014 10:40:00 +0000 (16:10 +0530)
committerHuang, Tao <huangtao@rock-chips.com>
Mon, 23 May 2016 07:53:13 +0000 (15:53 +0800)
Define a new ioctl for MTP_SEND_EVENT, as its
ioctl numbers depends on the size of struct
mtp_event, which varies in ARCH32 and ARCH64.

Change-Id: I060604057ac6c55991118b3f61b187468b4ee0fd
Signed-off-by: Rohith Seelaboyina <rseelaboyina@nvidia.com>
Reviewed-on: http://git-master/r/377800
Reviewed-by: Automatic_Commit_Validation_User
Reviewed-by: Venkat Moganty <vmoganty@nvidia.com>
Signed-off-by: Wu Liang feng <wulf@rock-chips.com>
drivers/usb/gadget/function/f_mtp.c
include/uapi/linux/usb/f_mtp.h

index d26f3b98ffa92667340d989cafd74ee028afe77b..23f866f391073aa851e81fd9f737a5e5e2eab4cb 100644 (file)
@@ -1008,6 +1008,25 @@ static long mtp_ioctl(struct file *fp, unsigned code, unsigned long value)
                        ret = mtp_send_event(dev, &event);
                goto out;
        }
+#ifdef CONFIG_COMPAT
+       case MTP_SEND_EVENT_32:
+       {
+               struct mtp_event_32     event_32;
+               struct mtp_event        event;
+               /* return here so we don't change dev->state below,
+                * which would interfere with bulk transfer state.
+                */
+               if (copy_from_user(&event_32, (void __user *)value,
+                                  sizeof(event_32)))
+                       ret = -EFAULT;
+               else {
+                       event.length = event_32.length;
+                       event.data = (void *)(unsigned long)event_32.data;
+                       ret = mtp_send_event(dev, &event);
+               }
+               goto out;
+       }
+#endif
        }
 
 fail:
index 503291855abda22a46d4f365259c45accdae11a7..b48a74b3695c7b401f468a533398bd27654fd58f 100644 (file)
@@ -4,6 +4,8 @@
  * Copyright (C) 2010 Google, Inc.
  * Author: Mike Lockwood <lockwood@android.com>
  *
+ * Copyright (C) 2014, NVIDIA CORPORATION. All rights reserved.
+ *
  * This software is licensed under the terms of the GNU General Public
  * License version 2, as published by the Free Software Foundation, and
  * may be copied, distributed, and modified under those terms.
@@ -45,6 +47,17 @@ struct mtp_event {
        void            *data;
 };
 
+#ifdef CONFIG_COMPAT
+struct mtp_event_32 {
+       /* size of the event */
+       compat_size_t   length;
+       /* event data to send */
+       compat_uptr_t   data;
+};
+
+#define MTP_SEND_EVENT_32          _IOW('M', 3, struct mtp_event_32)
+#endif
+
 /* Sends the specified file range to the host */
 #define MTP_SEND_FILE              _IOW('M', 0, struct mtp_file_range)
 /* Receives data from the host and writes it to a file.