1. 25 4月, 2017 5 次提交
    • A
      scsi: pmcraid: use normal copy_from_user · edb88cef
      Arnd Bergmann 提交于
      As pointed out by Al Viro for my previous series, the driver has no need
      to call access_ok() and __copy_from_user()/__copy_to_user(). Changing
      it to regular copy_from_user()/copy_to_user() simplifies the code without
      any real downsides, making it less error-prone at best.
      
      This patch by itself also addresses the warning about the access_ok()
      macro on MIPS, but both fixes improve the code, so ideally we apply
      them both.
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Reviewed-by: NChristoph Hellwig <hch@lst.de>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      edb88cef
    • A
      scsi: pmcraid: fix minor sparse warnings · 144b139c
      Arnd Bergmann 提交于
      pmcraid_minor is only used in this one file and should be 'static' as suggested
      by sparse:
      
      drivers/scsi/pmcraid.c:80:1: warning: symbol 'pmcraid_minor' was not declared. Should it be static?
      
      In Linux coding style, a literal '0' integer should not be used to represent
      a NULL pointer:
      
      drivers/scsi/pmcraid.c:348:29: warning: Using plain integer as NULL pointer
      drivers/scsi/pmcraid.c:4824:49: warning: Using plain integer as NULL pointer
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Reviewed-by: NChristoph Hellwig <hch@lst.de>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      144b139c
    • A
      scsi: pmcraid: fix endianess sparse annotations · 45c80be6
      Arnd Bergmann 提交于
      The use of le32_to_cpu() etc in this driver looks completely arbitrary.
      It may have made sense at some point, but it is not applied consistently,
      so this driver presumably won't work on big-endian kernel builds.
      
      Unfortunately it's unclear whether the type names or the calls to
      le32_to_cpu() are the correct ones. I'm taking educated guesses here
      and assume that most of the __le32 and __le16 annotations are correct,
      adding the conversion helpers whereever we access those fields.
      
      The exceptions are the 'fw_version' field that is always accessed as
      big-endian, so I'm changing the type here, and the 'hrrq' values that
      are accessed as little-endian, so I'm changing those the other way.
      
      None of these changes should have any effect on little-endian
      architectures like x86, but it addresses the sparse warnings.
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Reviewed-by: NChristoph Hellwig <hch@lst.de>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      45c80be6
    • A
      scsi: pmcraid: use __iomem pointers for ioctl argument · 3397623b
      Arnd Bergmann 提交于
      kernelci.org reports a new compile warning for old code in the pmcraid
      driver:
      
      arch/mips/include/asm/uaccess.h:138:21: warning: passing argument 1 of '__access_ok' makes pointer from integer without a cast [-Wint-conversion]
      
      The warning got introduced by a cleanup to the access_ok() helper that
      requires the argument to be a pointer, where the old version silently
      accepts 'unsigned long' arguments as it still does on most other
      architectures.
      
      The new behavior in MIPS however seems absolutely sensible, and so far I
      could only find one other file with the same issue, so the best solution
      seems to be to clean up the pmcraid driver.
      
      This makes the driver consistently use 'void __iomem *' pointers for
      passing around the address of the user space ioctl arguments, which gets
      rid of the kernelci warning as well as several sparse warnings.
      
      Fixes: f0a955f4 ("mips: sanitize __access_ok()")
      Cc: Alexander Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NArnd Bergmann <arnd@arndb.de>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      3397623b
    • C
      scsi: pmcraid: fix lock imbalance in pmcraid_reset_reload() · 91402608
      Christoph Hellwig 提交于
      sparse found a bug that has always been present since the driver was
      merged:
      
      drivers/scsi/pmcraid.c:2353:12: warning: context imbalance in 'pmcraid_reset_reload' - different lock contexts for basic block
      
      Fix this by using a common unlock goto label, and also reduce the
      indentation level in the function.
      Signed-off-by: NChristoph Hellwig <hch@lst.de>
      Reported-by: NArnd Bergmann <arnd@arndb.de>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      91402608
  2. 21 4月, 2017 3 次提交
  3. 20 4月, 2017 6 次提交
  4. 19 4月, 2017 4 次提交
  5. 14 4月, 2017 20 次提交
  6. 12 4月, 2017 2 次提交