1. 09 1月, 2014 9 次提交
  2. 21 12月, 2013 3 次提交
    • F
      GenWQE: Accidently casting to u32 where u64 is required · a45a0258
      Frank Haverkamp 提交于
      Fix a casting to u32 where u64 would be appropriate.
      The bad casting made the driver unusable.
      Signed-off-by: NFrank Haverkamp <haver@linux.vnet.ibm.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      a45a0258
    • F
      GenWQE: Replace dynamic_hex_dump with print_hex_dump_debug · 65861ab4
      Frank Haverkamp 提交于
      As requested by Greg, replacing the hexdump function from dynamic_debug.h
      with one defined in printk.h. I hope I picked the right one.
      Signed-off-by: NFrank Haverkamp <haver@linux.vnet.ibm.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      65861ab4
    • F
      GenWQE: Fix endian issues detected by sparse · 58d66ce7
      Frank Haverkamp 提交于
      Fengguang Wu used CF=-D__CHECK_ENDIAN__ to check the GenWQE driver for
      endian issues. Sparse found a couple of those. Most of them were caused
      by not correctly handling __be64/32 and __u64/32. Those I was able to
      fix with appropriate castings.
      
      One more serious issue was the ATS entry in struct genwqe_ddcb_cmd.
      The kernel expected it in big-endian, but the type was defined __u64.
      I decided that it is better to keep the interface consistent using
      host endian byte-odering instead of having a mixture. With this change
      the kernel likes to see host endian byte order for the ATS entry. That
      would have been an interface change, if someone would have used the
      driver already. Since this is not the case, I hope it is ok to fix it
      now.
      
      For the genqwe_readq/writeq/readl/writel functions I enforced the casts.
      
      It still complains, as far as I can see, about some copy_to/from_user()
      usages:
      
        CHECK   char-misc/drivers/misc/genwqe/card_dev.c
      char-misc/arch/x86/include/asm/uaccess.h:625:18: warning: incorrect type in argument 1 (different modifiers)
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    expected void *<noident>
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    got void const *from
      char-misc/arch/x86/include/asm/uaccess.h:625:18: warning: incorrect type in argument 1 (different modifiers)
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    expected void *<noident>
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    got void const *from
      char-misc/arch/x86/include/asm/uaccess.h:625:18: warning: incorrect type in argument 1 (different modifiers)
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    expected void *<noident>
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    got void const *from
      char-misc/arch/x86/include/asm/uaccess.h:625:18: warning: incorrect type in argument 1 (different modifiers)
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    expected void *<noident>
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    got void const *from
        CC [M]  drivers/misc/genwqe/card_dev.o
        CHECK   char-misc/drivers/misc/genwqe/card_ddcb.c
      char-misc/arch/x86/include/asm/uaccess.h:625:18: warning: incorrect type in argument 1 (different modifiers)
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    expected void *<noident>
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    got void const *from
      char-misc/arch/x86/include/asm/uaccess.h:625:18: warning: incorrect type in argument 1 (different modifiers)
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    expected void *<noident>
      char-misc/arch/x86/include/asm/uaccess.h:625:18:    got void const *from
        CC [M]  drivers/misc/genwqe/card_ddcb.o
        LD [M]  drivers/misc/genwqe/genwqe_card.o
      
      I appreciate some help from you to figure out what is causig those, and
      making a proposal how to fix them.
      
      I included the missing header file to fix the
      implicit-function-declaration warning when using dynamic_hex_dump.
      Signed-off-by: NFrank Haverkamp <haver@linux.vnet.ibm.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      58d66ce7
  3. 19 12月, 2013 10 次提交
  4. 11 12月, 2013 1 次提交
  5. 09 12月, 2013 1 次提交
  6. 06 12月, 2013 1 次提交
  7. 05 12月, 2013 3 次提交
  8. 03 12月, 2013 1 次提交
    • J
      [SCSI] enclosure: fix WARN_ON in dual path device removing · a1470c7b
      James Bottomley 提交于
      Bug report from: wenxiong@linux.vnet.ibm.com
      
      The issue is happened in dual controller configuration. We got the
      sysfs warnings when rmmod the ipr module.
      
      enclosure_unregister() in drivers/msic/enclosure.c, call device_unregister()
      for each componment deivce, device_unregister() ->device_del()->kobject_del()
      ->sysfs_remove_dir(). In sysfs_remove_dir(), set kobj->sd = NULL.
      
      For each componment device,
      enclosure_component_release()->enclosure_remove_links()->sysfs_remove_link()
      in which checking kobj->sd again, it has been set as NULL when doing
      device_unregister. So we saw all these sysfs WARNING.
      
      Tested-by: wenxiong@linux.vnet.ibm.com
      Cc: stable@vger.kernel.org
      Signed-off-by: NJames Bottomley <JBottomley@Parallels.com>
      a1470c7b
  9. 28 11月, 2013 8 次提交
  10. 15 11月, 2013 2 次提交
  11. 31 10月, 2013 1 次提交