1. 07 Apr, 2020 1 commit
  2. 03 Apr, 2020 5 commits
    • Jules Irenge's avatar
      ipmi: Add missing annotation for ipmi_ssif_lock_cond() and ipmi_ssif_unlock_cond() · 562bf770
      Jules Irenge authored
      Sparse reports a warning at ipmi_ssif_unlock_cond()
      	and ipmi_ssif_lock_cond()
      
      warning: context imbalance in ipmi_ssif_lock_cond()
      	- wrong count at exit
       warning: context imbalance in ipmi_ssif_unlock_cond()
      	- unexpected unlock
      
      The root cause is the missing annotation at ipmi_ssif_unlock_cond()
      	and ipmi_ssif_lock_cond()
      
      Add the missing __acquires(&ata_scsi_rbuf_lock)
      Add the missing __releases(&ata_scsi_rbuf_lock)
      Signed-off-by: default avatarJules Irenge <jbi.octave@gmail.com>
      Message-Id: <20200403160505.2832-6-jbi.octave@gmail.com>
      Signed-off-by: default avatarCorey Minyard <cminyard@mvista.com>
      562bf770
    • Andrew Jeffery's avatar
      ipmi: kcs: aspeed: Implement v2 bindings · 09f5f680
      Andrew Jeffery authored
      The v2 bindings allow us to extract the resources from the devicetree.
      The table in the driver is retained to derive the channel index, which
      removes the need for kcs_chan property from the v1 bindings. The v2
      bindings allow us to reduce the number of warnings generated by the
      existing devicetree nodes.
      Signed-off-by: default avatarAndrew Jeffery <andrew@aj.id.au>
      Reviewed-by: default avatarJoel Stanley <joel@jms.id.au>
      Reviewed-by: default avatarHaiyue Wang <haiyue.wang@linux.intel.com>
      Message-Id: <01ef3787e9ddaa9d87cfd55a2ac793053b5a69de.1576462051.git-series.andrew@aj.id.au>
      Signed-off-by: default avatarCorey Minyard <cminyard@mvista.com>
      09f5f680
    • Andrew Jeffery's avatar
      ipmi: kcs: Finish configuring ASPEED KCS device before enable · af6432c7
      Andrew Jeffery authored
      The interrupts were configured after the channel was enabled. Configure
      them beforehand so they will work.
      Signed-off-by: default avatarAndrew Jeffery <andrew@aj.id.au>
      Reviewed-by: default avatarJoel Stanley <joel@jms.id.au>
      Reviewed-by: default avatarHaiyue Wang <haiyue.wang@linux.intel.com>
      Message-Id: <c0aba2c9dfe2d0525e9cefd37995983ead0ec242.1576462051.git-series.andrew@aj.id.au>
      Signed-off-by: default avatarCorey Minyard <cminyard@mvista.com>
      af6432c7
    • Andrew Jeffery's avatar
      dt-bindings: ipmi: aspeed: Introduce a v2 binding for KCS · 782da920
      Andrew Jeffery authored
      The v2 binding utilises reg and renames some of the v1 properties.
      Signed-off-by: default avatarAndrew Jeffery <andrew@aj.id.au>
      Message-Id: <8aec8994bbe1186d257b0a712e13cf914c5ebe35.1576462051.git-series.andrew@aj.id.au>
      Reviewed-by: default avatarRob Herring <robh@kernel.org>
      Signed-off-by: default avatarCorey Minyard <cminyard@mvista.com>
      782da920
    • Wen Yang's avatar
      ipmi: fix hung processes in __get_guid() · 32830a05
      Wen Yang authored
      The wait_event() function is used to detect command completion.
      When send_guid_cmd() returns an error, smi_send() has not been
      called to send data. Therefore, wait_event() should not be used
      on the error path, otherwise it will cause the following warning:
      
      [ 1361.588808] systemd-udevd   D    0  1501   1436 0x00000004
      [ 1361.588813]  ffff883f4b1298c0 0000000000000000 ffff883f4b188000 ffff887f7e3d9f40
      [ 1361.677952]  ffff887f64bd4280 ffffc90037297a68 ffffffff8173ca3b ffffc90000000010
      [ 1361.767077]  00ffc90037297ad0 ffff887f7e3d9f40 0000000000000286 ffff883f4b188000
      [ 1361.856199] Call Trace:
      [ 1361.885578]  [<ffffffff8173ca3b>] ? __schedule+0x23b/0x780
      [ 1361.951406]  [<ffffffff8173cfb6>] schedule+0x36/0x80
      [ 1362.010979]  [<ffffffffa071f178>] get_guid+0x118/0x150 [ipmi_msghandler]
      [ 1362.091281]  [<ffffffff810d5350>] ? prepare_to_wait_event+0x100/0x100
      [ 1362.168533]  [<ffffffffa071f755>] ipmi_register_smi+0x405/0x940 [ipmi_msghandler]
      [ 1362.258337]  [<ffffffffa0230ae9>] try_smi_init+0x529/0x950 [ipmi_si]
      [ 1362.334521]  [<ffffffffa022f350>] ? std_irq_setup+0xd0/0xd0 [ipmi_si]
      [ 1362.411701]  [<ffffffffa0232bd2>] init_ipmi_si+0x492/0x9e0 [ipmi_si]
      [ 1362.487917]  [<ffffffffa0232740>] ? ipmi_pci_probe+0x280/0x280 [ipmi_si]
      [ 1362.568219]  [<ffffffff810021a0>] do_one_initcall+0x50/0x180
      [ 1362.636109]  [<ffffffff812231b2>] ? kmem_cache_alloc_trace+0x142/0x190
      [ 1362.714330]  [<ffffffff811b2ae1>] do_init_module+0x5f/0x200
      [ 1362.781208]  [<ffffffff81123ca8>] load_module+0x1898/0x1de0
      [ 1362.848069]  [<ffffffff811202e0>] ? __symbol_put+0x60/0x60
      [ 1362.913886]  [<ffffffff8130696b>] ? security_kernel_post_read_file+0x6b/0x80
      [ 1362.998514]  [<ffffffff81124465>] SYSC_finit_module+0xe5/0x120
      [ 1363.068463]  [<ffffffff81124465>] ? SYSC_finit_module+0xe5/0x120
      [ 1363.140513]  [<ffffffff811244be>] SyS_finit_module+0xe/0x10
      [ 1363.207364]  [<ffffffff81003c04>] do_syscall_64+0x74/0x180
      
      Fixes: 50c812b2 ("[PATCH] ipmi: add full sysfs support")
      Signed-off-by: default avatarWen Yang <wenyang@linux.alibaba.com>
      Cc: Corey Minyard <minyard@acm.org>
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Cc: openipmi-developer@lists.sourceforge.net
      Cc: linux-kernel@vger.kernel.org
      Cc: stable@vger.kernel.org # 2.6.17-
      Message-Id: <20200403090408.58745-1-wenyang@linux.alibaba.com>
      Signed-off-by: default avatarCorey Minyard <cminyard@mvista.com>
      32830a05
  3. 12 Mar, 2020 4 commits
  4. 11 Mar, 2020 7 commits
    • Linus Torvalds's avatar
      Merge tag 'fscrypt-for-linus' of git://git.kernel.org/pub/scm/fs/fscrypt/fscrypt · e6e6ec48
      Linus Torvalds authored
      Pull fscrypt fix from Eric Biggers:
       "Fix a bug where if userspace is writing to encrypted files while the
        FS_IOC_REMOVE_ENCRYPTION_KEY ioctl (introduced in v5.4) is running,
        dirty inodes could be evicted, causing writes could be lost or the
        filesystem to hang due to a use-after-free. This was encountered
        during real-world use, not just theoretical.
      
        Tested with the existing fscrypt xfstests, and with a new xfstest I
        wrote to reproduce this bug. This fix does expose an existing bug with
        '-o lazytime' that Ted is working on fixing, but this fix is more
        critical and needed anyway regardless of the lazytime fix"
      
      * tag 'fscrypt-for-linus' of git://git.kernel.org/pub/scm/fs/fscrypt/fscrypt:
        fscrypt: don't evict dirty inodes after removing key
      e6e6ec48
    • Linus Torvalds's avatar
      Merge tag 'for-linus-2020-03-10' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux · addcb1d0
      Linus Torvalds authored
      Pull thread fix from Christian Brauner:
       "This contains a single fix for a regression which was introduced when
        we introduced the ability to select a specific pid at process creation
        time.
      
        When this feature is requested, the error value will be set to -EPERM
        after exiting the pid allocation loop. This caused EPERM to be
        returned when e.g. the init process/child subreaper of the pid
        namespace has already died where we used to return ENOMEM before.
      
        The first patch here simply fixes the regression by unconditionally
        setting the return value back to ENOMEM again once we've successfully
        allocated the requested pid number. This should be easy to backport to
        v5.5.
      
        The second patch adds a comment explaining that we must keep returning
        ENOMEM since we've been doing it for a long time and have explicitly
        documented this behavior for userspace. This seemed worthwhile because
        we now have at least two separate example where people tried to change
        the return value to something other than ENOMEM (The first version of
        the regression fix did that too and the commit message links to an
        earlier patch that tried to do the same.).
      
        I have a simple regression test to make sure we catch this regression
        in the future but since that introduces a whole new selftest subdir
        and test files I'll keep this for v5.7"
      
      * tag 'for-linus-2020-03-10' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux:
        pid: make ENOMEM return value more obvious
        pid: Fix error return value in some cases
      addcb1d0
    • Linus Torvalds's avatar
      Merge tag 'trace-v5.6-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace · 36feb996
      Linus Torvalds authored
      Pull ftrace fix from Steven Rostedt:
       "Have ftrace lookup_rec() return a consistent record otherwise it can
        break live patching"
      
      * tag 'trace-v5.6-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace:
        ftrace: Return the first found result in lookup_rec()
      36feb996
    • Linus Torvalds's avatar
      Merge tag 'mips_fixes_5.6.1' of git://git.kernel.org/pub/scm/linux/kernel/git/mips/linux · c7f26a0c
      Linus Torvalds authored
      Pull MIPS fixes from Thomas Bogendoerfer:
       "A few MIPS fixes:
      
         - DT fixes for CI20
      
         - Fix command line handling
      
         - Correct patchwork URL"
      
      * tag 'mips_fixes_5.6.1' of git://git.kernel.org/pub/scm/linux/kernel/git/mips/linux:
        MAINTAINERS: Correct MIPS patchwork URL
        MIPS: DTS: CI20: fix interrupt for pcf8563 RTC
        MIPS: DTS: CI20: fix PMU definitions for ACT8600
        MIPS: Fix CONFIG_MIPS_CMDLINE_DTB_EXTEND handling
      c7f26a0c
    • Linus Torvalds's avatar
      Merge tag 'pinctrl-v5.6-2' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl · a6ff4631
      Linus Torvalds authored
      Pull pin control fixes from Linus Walleij:
       "Some pin control fixes for the v5.6 series.
      
        It comes down to memory leaks in the core and driver fixes. Some
        should have been sent earlier but they kept piling up and the world is
        just so full of distractions these days.
      
         - Fix some inverted pins in the Meson GLX driver.
      
         - Align the i.MX SC message structs causing warnings from KASan.
      
         - Balance the kref in pinctrl hogs so they are actually free:d when
           removing a pin control module. We haven't seen it before as people
           don't use modules for pin control that much, I think.
      
         - Add a missing call to pinctrl_unregister_mappings() another memory
           leak when using modules.
      
         - Fix the fwspec parsing in the Qualcomm driver.
      
         - Fix a syntax error in the Falcon driver.
      
         - Assign .irq_eoi conditionally in the Qualcomm driver, fixing a bug
           affecting elder Qualcomm platforms"
      
      * tag 'pinctrl-v5.6-2' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl:
        pinctrl: qcom: Assign irq_eoi conditionally
        pinctrl: falcon: fix syntax error
        pinctrl: qcom: ssbi-gpio: Fix fwspec parsing bug
        pinctrl: madera: Add missing call to pinctrl_unregister_mappings
        pinctrl: core: Remove extra kref_get which blocks hogs being freed
        pinctrl: imx: scu: Align imx sc msg structs to 4
        pinctrl: meson-gxl: fix GPIOX sdio pins
      a6ff4631
    • Christoph Hellwig's avatar
      driver code: clarify and fix platform device DMA mask allocation · e3a36eb6
      Christoph Hellwig authored
      This does three inter-related things to clarify the usage of the
      platform device dma_mask field. In the process, fix the bug introduced
      by cdfee562 ("driver core: initialize a default DMA mask for
      platform device") that caused Artem Tashkinov's laptop to not boot with
      newer Fedora kernels.
      
      This does:
      
       - First off, rename the field to "platform_dma_mask" to make it
         greppable.
      
         We have way too many different random fields called "dma_mask" in
         various data structures, where some of them are actual masks, and
         some of them are just pointers to the mask. And the structures all
         have pointers to each other, or embed each other inside themselves,
         and "pdev" sometimes means "platform device" and sometimes it means
         "PCI device".
      
         So to make it clear in the code when you actually use this new field,
         give it a unique name (it really should be something even more unique
         like "platform_device_dma_mask", since it's per platform device, not
         per platform, but that gets old really fast, and this is unique
         enough in context).
      
         To further clarify when the field gets used, initialize it when we
         actually start using it with the default value.
      
       - Then, use this field instead of the random one-off allocation in
         platform_device_register_full() that is now unnecessary since we now
         already have a perfectly fine allocation for it in the platform
         device structure.
      
       - The above then allows us to fix the actual bug, where the error path
         of platform_device_register_full() would unconditionally free the
         platform device DMA allocation with 'kfree()'.
      
         That kfree() was dont regardless of whether the allocation had been
         done earlier with the (now removed) kmalloc, or whether
         setup_pdev_dma_masks() had already been used and the dma_mask pointer
         pointed to the mask that was part of the platform device.
      
      It seems most people never triggered the error path, or only triggered
      it from a call chain that set an explicit pdevinfo->dma_mask value (and
      thus caused the unnecessary allocation that was "cleaned up" in the
      error path) before calling platform_device_register_full().
      
      Robin Murphy points out that in Artem's case the wdat_wdt driver failed
      in platform_device_add(), and that was the one that had called
      platform_device_register_full() with pdevinfo.dma_mask = 0, and would
      have caused that kfree() of pdev.dma_mask corrupting the heap.
      
      A later unrelated kmalloc() then oopsed due to the heap corruption.
      
      Fixes: cdfee562 ("driver core: initialize a default DMA mask for platform device")
      Reported-bisected-and-tested-by: default avatarArtem S. Tashkinov <aros@gmx.com>
      Reviewed-by: default avatarRobin Murphy <robin.murphy@arm.com>
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      e3a36eb6
    • Artem Savkov's avatar
      ftrace: Return the first found result in lookup_rec() · d9815bff
      Artem Savkov authored
      It appears that ip ranges can overlap so. In that case lookup_rec()
      returns whatever results it got last even if it found nothing in last
      searched page.
      
      This breaks an obscure livepatch late module patching usecase:
        - load livepatch
        - load the patched module
        - unload livepatch
        - try to load livepatch again
      
      To fix this return from lookup_rec() as soon as it found the record
      containing searched-for ip. This used to be this way prior lookup_rec()
      introduction.
      
      Link: http://lkml.kernel.org/r/20200306174317.21699-1-asavkov@redhat.com
      
      Cc: stable@vger.kernel.org
      Fixes: 7e16f581 ("ftrace: Separate out functionality from ftrace_location_range()")
      Signed-off-by: default avatarArtem Savkov <asavkov@redhat.com>
      Signed-off-by: default avatarSteven Rostedt (VMware) <rostedt@goodmis.org>
      d9815bff
  5. 10 Mar, 2020 5 commits
    • Linus Torvalds's avatar
      Merge tag 'clang-format-for-linus-v5.6-rc6' of git://github.com/ojeda/linux · f35111a9
      Linus Torvalds authored
      Pull clang-format update from Miguel Ojeda:
       "Another update for the .clang-format macro list
      
        It has been a while since the last time I sent one!"
      
      * tag 'clang-format-for-linus-v5.6-rc6' of git://github.com/ojeda/linux:
        clang-format: Update with the latest for_each macro list
      f35111a9
    • Linus Torvalds's avatar
      Merge tag 'auxdisplay-for-linus-v5.6-rc6' of git://github.com/ojeda/linux · 2a48b379
      Linus Torvalds authored
      Pull auxdisplay updates from Miguel Ojeda:
       "A few minor auxdisplay improvements:
      
         - charlcd: replace zero-length array with flexible-array member
           (kernel-wide cleanup by Gustavo A. R. Silva)
      
         - img-ascii-lcd: convert to devm_platform_ioremap_resource (Yangtao
           Li)
      
         - Fix Kconfig indentation (Krzysztof Kozlowski)
      
      * tag 'auxdisplay-for-linus-v5.6-rc6' of git://github.com/ojeda/linux:
        auxdisplay: charlcd: replace zero-length array with flexible-array member
        auxdisplay: img-ascii-lcd: convert to devm_platform_ioremap_resource
        auxdisplay: Fix Kconfig indentation
      2a48b379
    • Linus Torvalds's avatar
      Merge branch 'for-5.6-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup · e9414845
      Linus Torvalds authored
      Pull cgroup fixes from Tejun Heo:
      
       - cgroup.procs listing related fixes.
      
         It didn't interlock properly with exiting tasks leaving a short
         window where a cgroup has empty cgroup.procs but still can't be
         removed and misbehaved on short reads.
      
       - psi_show() crash fix on 32bit ino archs
      
       - Empty release_agent handling fix
      
      * 'for-5.6-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup:
        cgroup1: don't call release_agent when it is ""
        cgroup: fix psi_show() crash on 32bit ino archs
        cgroup: Iterate tasks that did not finish do_exit()
        cgroup: cgroup_procs_next should increase position index
        cgroup-v1: cgroup_pidlist_next should update position index
      e9414845
    • Linus Torvalds's avatar
      Merge branch 'for-5.6-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq · 2c1aca4b
      Linus Torvalds authored
      Pull workqueue fixes from Tejun Heo:
       "Workqueue has been incorrectly round-robining per-cpu work items.
        Hillf's patch fixes that.
      
        The other patch documents memory-ordering properties of workqueue
        operations"
      
      * 'for-5.6-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq:
        workqueue: don't use wq_select_unbound_cpu() for bound works
        workqueue: Document (some) memory-ordering properties of {queue,schedule}_work()
      2c1aca4b
    • Hillf Danton's avatar
      workqueue: don't use wq_select_unbound_cpu() for bound works · aa202f1f
      Hillf Danton authored
      wq_select_unbound_cpu() is designed for unbound workqueues only, but
      it's wrongly called when using a bound workqueue too.
      
      Fixing this ensures work queued to a bound workqueue with
      cpu=WORK_CPU_UNBOUND always runs on the local CPU.
      
      Before, that would happen only if wq_unbound_cpumask happened to include
      it (likely almost always the case), or was empty, or we got lucky with
      forced round-robin placement.  So restricting
      /sys/devices/virtual/workqueue/cpumask to a small subset of a machine's
      CPUs would cause some bound work items to run unexpectedly there.
      
      Fixes: ef557180 ("workqueue: schedule WORK_CPU_UNBOUND work on wq_unbound_cpumask CPUs")
      Cc: stable@vger.kernel.org # v4.5+
      Signed-off-by: default avatarHillf Danton <hdanton@sina.com>
      [dj: massage changelog]
      Signed-off-by: default avatarDaniel Jordan <daniel.m.jordan@oracle.com>
      Cc: Tejun Heo <tj@kernel.org>
      Cc: Lai Jiangshan <jiangshanlai@gmail.com>
      Cc: linux-kernel@vger.kernel.org
      Signed-off-by: default avatarTejun Heo <tj@kernel.org>
      aa202f1f
  6. 09 Mar, 2020 15 commits
  7. 08 Mar, 2020 3 commits
    • Linus Torvalds's avatar
      Merge tag 'char-misc-5.6-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc · 378fee2e
      Linus Torvalds authored
      Pull char/misc fixes from Greg KH:
       "Here are four small char/misc driver fixes for reported issues for
        5.6-rc5.
      
        These fixes are:
      
         - binder fix for a potential use-after-free problem found (took two
           tries to get it right)
      
         - interconnect core fix
      
         - altera-stapl driver fix
      
        All four of these have been in linux-next for a while with no reported
        issues"
      
      * tag 'char-misc-5.6-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc:
        binder: prevent UAF for binderfs devices II
        interconnect: Handle memory allocation errors
        altera-stapl: altera_get_note: prevent write beyond end of 'key'
        binder: prevent UAF for binderfs devices
      378fee2e
    • Linus Torvalds's avatar
      Merge tag 'driver-core-5.6-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core · b34e5c13
      Linus Torvalds authored
      Pull driver core and debugfs fixes from Greg KH:
       "Here are four small driver core / debugfs patches for 5.6-rc3:
      
         - debugfs api cleanup now that all debugfs_create_regset32() callers
           have been fixed up. This was waiting until after the -rc1 merge as
           these fixes came in through different trees
      
         - driver core sync state fixes based on reports of minor issues found
           in the feature
      
        All of these have been in linux-next with no reported issues"
      
      * tag 'driver-core-5.6-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core:
        driver core: Skip unnecessary work when device doesn't have sync_state()
        driver core: Add dev_has_sync_state()
        driver core: Call sync_state() even if supplier has no consumers
        debugfs: remove return value of debugfs_create_regset32()
      b34e5c13
    • Linus Torvalds's avatar
      Merge tag 'tty-5.6-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty · cc432aee
      Linus Torvalds authored
      Pull tty/serial fixes from Greg KH:
       "Here are some small tty/serial fixes for 5.6-rc5
      
        Just some small serial driver fixes, and a vt core fixup, full details
        are:
      
         - vt fixes for issues found by syzbot
      
         - serdev fix for Apple boxes
      
         - fsl_lpuart serial driver fixes
      
         - MAINTAINER update for incorrect serial files
      
         - new device ids for 8250_exar driver
      
         - mvebu-uart fix
      
        All of these have been in linux-next with no reported issues"
      
      * tag 'tty-5.6-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty:
        tty: serial: fsl_lpuart: free IDs allocated by IDA
        Revert "tty: serial: fsl_lpuart: drop EARLYCON_DECLARE"
        serdev: Fix detection of UART devices on Apple machines.
        MAINTAINERS: Add missed files related to Synopsys DesignWare UART
        serial: 8250_exar: add support for ACCES cards
        tty:serial:mvebu-uart:fix a wrong return
        vt: selection, push sel_lock up
        vt: selection, push console lock down
      cc432aee