]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/commitdiff
vcsm: Add no-op cache operation constant
authorSugizaki Yukimasa <i.can.speak.c.and.basic@gmail.com>
Tue, 9 Jan 2018 19:32:20 +0000 (04:32 +0900)
committerKleber Sacilotto de Souza <kleber.souza@canonical.com>
Wed, 15 Aug 2018 17:23:07 +0000 (19:23 +0200)
Signed-off-by: Sugizaki Yukimasa <i.can.speak.c.and.basic@gmail.com>
(cherry picked from commit 6e3d5ea5d602ae145bf7502933fff44ad3a28926
https://github.com/raspberrypi/linux raspi/rpi-4.15.y)
Signed-off-by: Paolo Pisati <paolo.pisati@canonical.com>
Signed-off-by: Seth Forshee <seth.forshee@canonical.com>
drivers/char/broadcom/vc_sm/vmcs_sm.c
include/linux/broadcom/vmcs_sm_ioctl.h

index 0d14c511da2ab8f542d51ad87746be854d5180dc..122ea149790b549aa7550ddb9cff64dc2195fc61 100644 (file)
@@ -1269,6 +1269,8 @@ static int clean_invalid_mem_2d(const void __user *addr,
        }
 
        switch (cache_op) {
+       case VCSM_CACHE_OP_NOP:
+               return 0;
        case VCSM_CACHE_OP_INV:
                op_fn = dmac_inv_range;
                break;
@@ -1312,6 +1314,8 @@ static int clean_invalid_resource(const void __user *addr, const size_t size,
                return 0;
 
        switch (cache_op) {
+       case VCSM_CACHE_OP_NOP:
+               return 0;
        case VCSM_CACHE_OP_INV:
                stat_attempt = INVALID;
                stat_failure = INVALID_FAIL;
@@ -2936,6 +2940,9 @@ static long vc_sm_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
                                goto out;
                        }
                        for (i = 0; i < sizeof(ioparam.s) / sizeof(*ioparam.s); i++) {
+                               if (ioparam.s[i].cmd == VCSM_CACHE_OP_NOP)
+                                       break;
+
                                /* Locate resource from GUID. */
                                resource =
                                        vmcs_sm_acquire_resource(file_data, ioparam.s[i].handle);
@@ -2989,6 +2996,9 @@ static long vc_sm_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
                                        ret = clean_invalid_mem_2d((void __user*) op->start_address,
                                                        op->block_count, op->block_size,
                                                        op->inter_block_stride, op->invalidate_mode);
+                                       if (op->invalidate_mode == VCSM_CACHE_OP_NOP)
+                                               continue;
+
                                        if (ret)
                                                break;
                                }
index e881fa8ee8e1474cdaa0759b742a5f67c122c9eb..a4492b921b48e2c7fdd2745f2d2bad4846a15cdc 100644 (file)
@@ -172,6 +172,7 @@ struct vmcs_sm_ioctl_cache {
  * Cache functions to be set to struct vmcs_sm_ioctl_clean_invalid cmd and
  * vmcs_sm_ioctl_clean_invalid2 invalidate_mode.
  */
+#define VCSM_CACHE_OP_NOP       0x00
 #define VCSM_CACHE_OP_INV       0x01
 #define VCSM_CACHE_OP_CLEAN     0x02
 #define VCSM_CACHE_OP_FLUSH     0x03