Skip to content
  1. Aug 10, 2019
    • Linus Torvalds's avatar
      Merge tag 'kbuild-fixes-v5.3-3' of... · 451577f3
      Linus Torvalds authored
      Merge tag 'kbuild-fixes-v5.3-3' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild
      
      Pull Kbuild fixes from Masahiro Yamada:
      
       - revive single target %.ko
      
       - do not create built-in.a where it is unneeded
      
       - do not create modules.order where it is unneeded
      
       - show a warning if subdir-y/m is used to visit a module Makefile
      
      * tag 'kbuild-fixes-v5.3-3' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild:
        kbuild: show hint if subdir-y/m is used to visit module Makefile
        kbuild: generate modules.order only in directories visited by obj-y/m
        kbuild: fix false-positive need-builtin calculation
        kbuild: revive single target %.ko
      451577f3
    • Linus Torvalds's avatar
      Merge tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm · 7f20fd23
      Linus Torvalds authored
      Pull kvm fixes from Paolo Bonzini:
       "Bugfixes (arm and x86) and cleanups"
      
      * tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm:
        selftests: kvm: Adding config fragments
        KVM: selftests: Update gitignore file for latest changes
        kvm: remove unnecessary PageReserved check
        KVM: arm/arm64: vgic: Reevaluate level sensitive interrupts on enable
        KVM: arm: Don't write junk to CP15 registers on reset
        KVM: arm64: Don't write junk to sysregs on reset
        KVM: arm/arm64: Sync ICH_VMCR_EL2 back when about to block
        x86: kvm: remove useless calls to kvm_para_available
        KVM: no need to check return value of debugfs_create functions
        KVM: remove kvm_arch_has_vcpu_debugfs()
        KVM: Fix leak vCPU's VMCS value into other pCPU
        KVM: Check preempted_in_kernel for involuntary preemption
        KVM: LAPIC: Don't need to wakeup vCPU twice afer timer fire
        arm64: KVM: hyp: debug-sr: Mark expected switch fall-through
        KVM: arm64: Update kvm_arm_ex...
      7f20fd23
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input · 15abf142
      Linus Torvalds authored
      Pull input updates from Dmitry Torokhov:
      
       - newer systems with Elan touchpads will be switched over to SMBus
      
       - HP Spectre X360 will be using SMbus/RMI4
      
       - checks for invalid USB descriptors in kbtab and iforce
      
       - build fixes for applespi driver (misconfigs)
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input:
        Input: iforce - add sanity checks
        Input: applespi - use struct_size() helper
        Input: kbtab - sanity check for endpoint type
        Input: usbtouchscreen - initialize PM mutex before using it
        Input: applespi - add dependency on LEDS_CLASS
        Input: synaptics - enable RMI mode for HP Spectre X360
        Input: elantech - annotate fall-through case in elantech_use_host_notify()
        Input: elantech - enable SMBus on new (2018+) systems
        Input: applespi - fix trivial typo in struct description
        Input: applespi - select CRC16 module
        Input: applespi - fix warnings detected by sparse
      15abf142
    • Masahiro Yamada's avatar
      kbuild: show hint if subdir-y/m is used to visit module Makefile · c07d8d47
      Masahiro Yamada authored
      Since commit ff9b45c5
      
       ("kbuild: modpost: read modules.order instead
      of $(MODVERDIR)/*.mod"), a module is no longer built in the following
      pattern:
      
        [Makefile]
        subdir-y := some-module
      
        [some-module/Makefile]
        obj-m := some-module.o
      
      You cannot write Makefile this way in upstream because modules.order is
      not correctly generated. subdir-y is used to descend to a sub-directory
      that builds tools, device trees, etc.
      
      For external modules, the modules order does not matter. So, the
      Makefile above was known to work.
      
      I believe the Makefile should be re-written as follows:
      
        [Makefile]
        obj-m := some-module/
      
        [some-module/Makefile]
        obj-m := some-module.o
      
      However, people will have no idea if their Makefile suddenly stops
      working. In fact, I received questions from multiple people.
      
      Show a warning for a while if obj-m is specified in a Makefile visited
      by subdir-y or subdir-m.
      
      I touched the %/ rule to avoid false-positive warnings for the single
      target.
      
      Cc: Jan Kiszka <jan.kiszka@siemens.com>
      Cc: Tom Stonecypher <thomas.edwardx.stonecypher@intel.com>
      Signed-off-by: default avatarMasahiro Yamada <yamada.masahiro@socionext.com>
      Tested-by: default avatarJan Kiszka <jan.kiszka@siemens.com>
      c07d8d47
    • Masahiro Yamada's avatar
      kbuild: generate modules.order only in directories visited by obj-y/m · 4f2c8f30
      Masahiro Yamada authored
      
      
      The modules.order files in directories visited by the chain of obj-y
      or obj-m are merged to the upper-level ones, and become parts of the
      top-level modules.order. On the other hand, there is no need to
      generate modules.order in directories visited by subdir-y or subdir-m
      since they would become orphan anyway.
      
      Signed-off-by: default avatarMasahiro Yamada <yamada.masahiro@socionext.com>
      4f2c8f30
    • Masahiro Yamada's avatar
      kbuild: fix false-positive need-builtin calculation · d9f78edf
      Masahiro Yamada authored
      
      
      The current implementation of need-builtin is false-positive,
      for example, in the following Makefile:
      
        obj-m := foo/
        obj-y := foo/bar/
      
      ..., where foo/built-in.a is not required.
      
      Signed-off-by: default avatarMasahiro Yamada <yamada.masahiro@socionext.com>
      d9f78edf
    • Masahiro Yamada's avatar
      kbuild: revive single target %.ko · 47801c97
      Masahiro Yamada authored
      I removed the single target %.ko in commit ff9b45c5 ("kbuild:
      modpost: read modules.order instead of $(MODVERDIR)/*.mod") because
      the modpost stage does not work reliably. For instance, the module
      dependency, modversion, etc. do not work if we lack symbol information
      from the other modules.
      
      Yet, some people still want to build only one module in their interest,
      and it may be still useful if it is used within those limitations.
      
      Fixes: ff9b45c5
      
       ("kbuild: modpost: read modules.order instead of $(MODVERDIR)/*.mod")
      Reported-by: default avatarDon Brace <don.brace@microsemi.com>
      Reported-by: default avatarArend Van Spriel <arend.vanspriel@broadcom.com>
      Signed-off-by: default avatarMasahiro Yamada <yamada.masahiro@socionext.com>
      47801c97
    • Linus Torvalds's avatar
      Merge tag 'drm-fixes-2019-08-09' of git://anongit.freedesktop.org/drm/drm · 2226fb57
      Linus Torvalds authored
      Pull drm fixes from Dave Airlie:
       "Usual fixes roundup. Nothing too crazy or serious, one non-released
        ioctl is removed in the amdkfd driver.
      
        core:
         - mode parser strncpy fix
      
        i915:
         - GLK DSI escape clock setting
         - HDCP memleak fix
      
        tegra:
         - one gpiod/of regression fix
      
        amdgpu:
         - fix VCN to handle the latest navi10 firmware
         - fix for fan control on navi10
         - properly handle SMU metrics table on navi10
         - fix a resume regression on Stoney
         - kfd revert a GWS ioctl
      
        vmwgfx:
         - memory leak fix
      
        rockchip:
         - suspend fix"
      
      * tag 'drm-fixes-2019-08-09' of git://anongit.freedesktop.org/drm/drm:
        drm/vmwgfx: fix memory leak when too many retries have occurred
        Revert "drm/amdkfd: New IOCTL to allocate queue GWS"
        Revert "drm/amdgpu: fix transform feedback GDS hang on gfx10 (v2)"
        drm/amdgpu: pin the csb buffer on hw init for gfx v8
        drm/rockchip: Suspend DP late
        drm/i915: Fix wrong escape clock divisor init for GLK
        drm/i915: fix possible memory leak in intel_hdcp_auth_downstream()
        drm/modes: Fix unterminated strncpy
        drm/amd/powerplay: correct navi10 vcn powergate
        drm/amd/powerplay: honor hw limit on fetching metrics data for navi10
        drm/amd/powerplay: Allow changing of fan_control in smu_v11_0
        drm/amd/amdgpu/vcn_v2_0: Move VCN 2.0 specific dec ring test to vcn_v2_0
        drm/amd/amdgpu/vcn_v2_0: Mark RB commands as KMD commands
        drm/tegra: Fix gpiod_get_from_of_node() regression
      2226fb57
    • Linus Torvalds's avatar
      Merge tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux · 15a555a4
      Linus Torvalds authored
      Pull arm64 fix from Catalin Marinas:
       "Fix bad_pte warning caused by pte_mkdevmap() not setting PTE_SPECIAL"
      
      * tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux:
        arm64: mm: add missing PTE_SPECIAL in pte_mkdevmap on arm64
      15a555a4
    • Linus Torvalds's avatar
      Merge tag 's390-5.3-5' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux · cb7ef4bc
      Linus Torvalds authored
      Pull s390 fixes from Vasily Gorbik:
      
       - Map vdso also for statically linked binaries like all other
         architectures.
      
       - Fix no .bss usage compile-time check to account common objects with
         the help of binutils size tool. Top level Makefile change acked-by
         Masahiro.
      
       - A fix to make perf happy with _etext symbol type.
      
       - Fix dump_pagetables which is broken since p*d_offset implementation
         change to comply with mm/gup.c expectations.
      
       - Revert memory sharing for diag calls in protected virtualization,
         since this is not required after all.
      
       - Couple of other minor code cleanups.
      
      * tag 's390-5.3-5' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux:
        s390/vdso: map vdso also for statically linked binaries
        s390/build: use size command to perform empty .bss check
        kbuild: add OBJSIZE variable for the size tool
        s390: put _stext and _etext into .text section
        s390/head64: cleanup unused labels
        s390/unwind: remove stack recursion warning
        s390/setup: adjust start_code of init_mm to _text
        s390/mm: fix dump_pagetables top level page table walking
        s390/protvirt: avoid memory sharing for diag 308 set/store
      cb7ef4bc
    • Linus Torvalds's avatar
      Merge tag 'for-linus-20190809' of git://git.kernel.dk/linux-block · 50e73a4a
      Linus Torvalds authored
      Pull block fixes from Jens Axboe:
      
       - Revert of a bcache patch that caused an oops for some (Coly)
      
       - ata rb532 unused warning fix (Gustavo)
      
       - AoE kernel crash fix (He)
      
       - Error handling fixup for blkdev_get() (Jan)
      
       - libata read/write translation and SFF PIO fix (me)
      
       - Use after free and error handling fix for O_DIRECT fragments. There's
         still a nowait + sync oddity in there, we'll nail that start next
         week. If all else fails, I'll queue a revert of the NOWAIT change.
         (me)
      
       - Loop GFP_KERNEL -> GFP_NOIO deadlock fix (Mikulas)
      
       - Two BFQ regression fixes that caused crashes (Paolo)
      
      * tag 'for-linus-20190809' of git://git.kernel.dk/linux-block:
        bcache: Revert "bcache: use sysfs_match_string() instead of __sysfs_match_string()"
        loop: set PF_MEMALLOC_NOIO for the worker thread
        bdev: Fixup error handling in blkdev_get()
        block, bfq: handle NULL return value by bfq_init_rq()
        block, bfq: move update of waker and woken list to queue freeing
        block, bfq: reset last_completed_rq_bfqq if the pointed queue is freed
        block: aoe: Fix kernel crash due to atomic sleep when exiting
        libata: add SG safety checks in SFF pio transfers
        libata: have ata_scsi_rw_xlat() fail invalid passthrough requests
        block: fix O_DIRECT error handling for bio fragments
        ata: rb532_cf: Fix unused variable warning in rb532_pata_driver_probe
      50e73a4a
    • Linus Torvalds's avatar
      Merge tag 'mmc-v5.3-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/mmc · 461d2815
      Linus Torvalds authored
      Pull MMC fixes from Ulf Hansson:
      
       - cavium: Fix DMA support
      
       - sdhci-sprd: Fix soft reset when runtime resuming"
      
      * tag 'mmc-v5.3-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/mmc:
        mmc: cavium: Add the missing dma unmap when the dma has finished.
        mmc: cavium: Set the correct dma max segment size for mmc_host
        mmc: sdhci-sprd: Fix the incorrect soft reset operation when runtime resuming
      461d2815
    • Linus Torvalds's avatar
      Merge tag 'fbdev-v5.3-rc4' of git://github.com/bzolnier/linux · ec4c99ad
      Linus Torvalds authored
      Pull fbdev fix from Bartlomiej Zolnierkiewicz:
       "fbdev patches will now go to upstream through drm-misc tree for
        improved maintainership and better integration testing so update
        MAINTAINERS file accordingly"
      
      * tag 'fbdev-v5.3-rc4' of git://github.com/bzolnier/linux:
        MAINTAINERS: handle fbdev changes through drm-misc tree
      ec4c99ad
    • Linus Torvalds's avatar
      Merge tag 'pwm/for-5.3-rc4' of... · c808f2ad
      Linus Torvalds authored
      Merge tag 'pwm/for-5.3-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/thierry.reding/linux-pwm
      
      Pull pwm fix from Thierry Reding:
       "A single fix for a backlight brightness regression introduced in
        this merge window"
      
      * tag 'pwm/for-5.3-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/thierry.reding/linux-pwm:
        pwm: Fallback to the static lookup-list when acpi_pwm_get fails
      c808f2ad
    • Linus Torvalds's avatar
      Merge tag 'sound-5.3-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound · cb42f06c
      Linus Torvalds authored
      Pull sound fixes from Takashi Iwai:
       "Lots of small fixes at this time since we've received the ASoC fix
        batch now.
      
         - Some coverage in ASoC core mostly for minor issues like NULL checks
           for DPCM and proper error handling in DAI instantiation
      
         - A collection of small device-specific changes in various ASoC codec
           and platform drivers
      
         - OF-tree refcount fixes in a few ASoC drivers
      
         - Fixes of memory leaks in the error paths of various ASoC / ALSA
           drivers
      
         - A workaround for a long-standing issue on AMD HD-audio device
      
         - Updates of MAINTAINERS, mail addresses, file permission fixups"
      
      * tag 'sound-5.3-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: (38 commits)
        ALSA: firewire: fix a memory leak bug
        sound: fix a memory leak bug
        ALSA: hda - Workaround for crackled sound on AMD controller (1022:1457)
        ALSA: hiface: fix multiple memory leak bugs
        ALSA: hda - Don't override global PCM hw info flag
        ALSA: usb-audio: fix a memory leak bug
        ASoC: max98373: Remove executable bits
        ASoC: amd: acp3x: use dma address for acp3x dma driver
        ASoC: amd: acp3x: use dma_ops of parent device for acp3x dma driver
        ASoC: max98373: add 88200 and 96000 sampling rate support
        ASoC: sun4i-i2s: Incorrect SR and WSS computation
        MAINTAINERS: Update Intel ASoC drivers maintainers
        ASoC: ti: davinci-mcasp: Correct slot_width posed constraint
        ASoC: rockchip: Fix mono capture
        ASoC: Intel: Fix some acpi vs apci typo in somme comments
        ASoC: ti: davinci-mcasp: Fix clk PDIR handling for i2s master mode
        ASoC: Fail card instantiation if DAI format setup fails
        ASoC: SOF: Intel: hda: remove misleading error trace from IRQ thread
        ASoC: qcom: apq8016_sbc: Fix oops with multiple DAI links
        ASoC: dapm: fix a memory leak bug
        ...
      cb42f06c
    • Linus Torvalds's avatar
      Merge tag 'media/v5.3-3' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media · 6c02b630
      Linus Torvalds authored
      Pull media fix from Mauro Carvalho Chehab:
       "A fix at the vivid CEC support"
      
      * tag 'media/v5.3-3' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media:
        media: vivid: fix missing cec adapter name
      6c02b630
    • Linus Torvalds's avatar
      Merge tag 'pm-5.3-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · 0acf5676
      Linus Torvalds authored
      Pull power management fix from Rafael Wysocki:
       "Revert a recent PCI power management change that caused problems to
        occur on multiple systems (Mika Westerberg)"
      
      * tag 'pm-5.3-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
        Revert "PCI: Add missing link delays required by the PCIe spec"
      0acf5676
    • Linus Torvalds's avatar
      Merge branch 'linus' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6 · e577dc15
      Linus Torvalds authored
      Pull crypto fixes from Herbert Xu:
       "Fix a number of bugs in the ccp driver"
      
      * 'linus' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6:
        crypto: ccp - Ignore tag length when decrypting GCM ciphertext
        crypto: ccp - Add support for valid authsize values less than 16
        crypto: ccp - Fix oops by properly managing allocated structures
      e577dc15
  2. Aug 09, 2019
    • Paolo Bonzini's avatar
      Merge tag 'kvmarm-fixes-for-5.3-2' of... · a738b5e7
      Paolo Bonzini authored
      Merge tag 'kvmarm-fixes-for-5.3-2' of git://git.kernel.org/pub/scm/linux/kernel/git/kvmarm/kvmarm into HEAD
      
      KVM/arm fixes for 5.3, take #2
      
      - Fix our system register reset so that we stop writing
        non-sensical values to them, and track which registers
        get reset instead.
      - Sync VMCR back from the GIC on WFI so that KVM has an
        exact vue of PMR.
      - Reevaluate state of HW-mapped, level triggered interrupts
        on enable.
      a738b5e7
    • Paolo Bonzini's avatar
      Merge tag 'kvmarm-fixes-for-5.3' of... · 0e1c438c
      Paolo Bonzini authored
      Merge tag 'kvmarm-fixes-for-5.3' of git://git.kernel.org/pub/scm/linux/kernel/git/kvmarm/kvmarm into HEAD
      
      KVM/arm fixes for 5.3
      
      - A bunch of switch/case fall-through annotation, fixing one actual bug
      - Fix PMU reset bug
      - Add missing exception class debug strings
      0e1c438c
    • Naresh Kamboju's avatar
      selftests: kvm: Adding config fragments · c096397c
      Naresh Kamboju authored
      
      
      selftests kvm test cases need pre-required kernel configs for the test
      to get pass.
      
      Signed-off-by: default avatarNaresh Kamboju <naresh.kamboju@linaro.org>
      Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      c096397c
    • Thomas Huth's avatar
      KVM: selftests: Update gitignore file for latest changes · e2c26537
      Thomas Huth authored
      
      
      The kvm_create_max_vcpus test has been moved to the main directory,
      and sync_regs_test is now available on s390x, too.
      
      Signed-off-by: default avatarThomas Huth <thuth@redhat.com>
      Acked-by: default avatarShuah Khan <skhan@linuxfoundation.org>
      Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      e2c26537
    • Paolo Bonzini's avatar
      kvm: remove unnecessary PageReserved check · 8f946da7
      Paolo Bonzini authored
      
      
      The same check is already done in kvm_is_reserved_pfn.
      
      Reviewed-by: default avatarSean Christopherson <sean.j.christopherson@intel.com>
      Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      8f946da7
    • Bartlomiej Zolnierkiewicz's avatar
      MAINTAINERS: handle fbdev changes through drm-misc tree · 6a7553e8
      Bartlomiej Zolnierkiewicz authored
      
      
      fbdev patches will now go to upstream through drm-misc tree (IOW
      starting with v5.4 merge window fbdev changes will be included in
      DRM pull request) for improved maintainership and better integration
      testing. Update MAINTAINERS file accordingly.
      
      Acked-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
      Signed-off-by: default avatarBartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>
      6a7553e8
    • Coly Li's avatar
      bcache: Revert "bcache: use sysfs_match_string() instead of __sysfs_match_string()" · 20621fed
      Coly Li authored
      This reverts commit 89e0341a.
      
      In drivers/md/bcache/sysfs.c:bch_snprint_string_list(), NULL pointer at
      the end of list is necessary. Remove the NULL from last element of each
      lists will cause the following panic,
      
      [ 4340.455652] bcache: register_cache() registered cache device nvme0n1
      [ 4340.464603] bcache: register_bdev() registered backing device sdk
      [ 4421.587335] bcache: bch_cached_dev_run() cached dev sdk is running already
      [ 4421.587348] bcache: bch_cached_dev_attach() Caching sdk as bcache0 on set 354e1d46-d99f-4d8b-870b-078b80dc88a6
      [ 5139.247950] general protection fault: 0000 [#1] SMP NOPTI
      [ 5139.247970] CPU: 9 PID: 5896 Comm: cat Not tainted 4.12.14-95.29-default #1 SLE12-SP4
      [ 5139.247988] Hardware name: HPE ProLiant DL380 Gen10/ProLiant DL380 Gen10, BIOS U30 04/18/2019
      [ 5139.248006] task: ffff888fb25c0b00 task.stack: ffff9bbacc704000
      [ 5139.248021] RIP: 0010:string+0x21/0x70
      [ 5139.248030] RSP: 0018:ffff9bbacc707bf0 EFLAGS: 00010286
      [ 5139.248043] RAX: ffffffffa7e432e3 RBX: ffff8881c20da02a RCX: ffff0a00ffffff04
      [ 5139.248058] RDX: 3f00656863616362 RSI: ffff8881c20db000 RDI: ffffffffffffffff
      [ 5139.248075] RBP: ffff8881c20db000 R08: 0000000000000000 R09: ffff8881c20da02a
      [ 5139.248090] R10: 0000000000000004 R11: 0000000000000000 R12: ffff9bbacc707c48
      [ 5139.248104] R13: 0000000000000fd6 R14: ffffffffc0665855 R15: ffffffffc0665855
      [ 5139.248119] FS:  00007faf253b8700(0000) GS:ffff88903f840000(0000) knlGS:0000000000000000
      [ 5139.248137] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      [ 5139.248149] CR2: 00007faf25395008 CR3: 0000000f72150006 CR4: 00000000007606e0
      [ 5139.248164] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
      [ 5139.248179] DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
      [ 5139.248193] PKRU: 55555554
      [ 5139.248200] Call Trace:
      [ 5139.248210]  vsnprintf+0x1fb/0x510
      [ 5139.248221]  snprintf+0x39/0x40
      [ 5139.248238]  bch_snprint_string_list.constprop.15+0x5b/0x90 [bcache]
      [ 5139.248256]  __bch_cached_dev_show+0x44d/0x5f0 [bcache]
      [ 5139.248270]  ? __alloc_pages_nodemask+0xb2/0x210
      [ 5139.248284]  bch_cached_dev_show+0x2c/0x50 [bcache]
      [ 5139.248297]  sysfs_kf_seq_show+0xbb/0x190
      [ 5139.248308]  seq_read+0xfc/0x3c0
      [ 5139.248317]  __vfs_read+0x26/0x140
      [ 5139.248327]  vfs_read+0x87/0x130
      [ 5139.248336]  SyS_read+0x42/0x90
      [ 5139.248346]  do_syscall_64+0x74/0x160
      [ 5139.248358]  entry_SYSCALL_64_after_hwframe+0x3d/0xa2
      [ 5139.248370] RIP: 0033:0x7faf24eea370
      [ 5139.248379] RSP: 002b:00007fff82d03f38 EFLAGS: 00000246 ORIG_RAX: 0000000000000000
      [ 5139.248395] RAX: ffffffffffffffda RBX: 0000000000020000 RCX: 00007faf24eea370
      [ 5139.248411] RDX: 0000000000020000 RSI: 00007faf25396000 RDI: 0000000000000003
      [ 5139.248426] RBP: 00007faf25396000 R08: 00000000ffffffff R09: 0000000000000000
      [ 5139.248441] R10: 000000007c9d4d41 R11: 0000000000000246 R12: 00007faf25396000
      [ 5139.248456] R13: 0000000000000003 R14: 0000000000000000 R15: 0000000000000fff
      [ 5139.248892] Code: ff ff ff 0f 1f 80 00 00 00 00 49 89 f9 48 89 cf 48 c7 c0 e3 32 e4 a7 48 c1 ff 30 48 81 fa ff 0f 00 00 48 0f 46 d0 48 85 ff 74 45 <44> 0f b6 02 48 8d 42 01 45 84 c0 74 38 48 01 fa 4c 89 cf eb 0e
      
      The simplest way to fix is to revert commit 89e0341a ("bcache: use
      sysfs_match_string() instead of __sysfs_match_string()").
      
      This bug was introduced in Linux v5.2, so this fix only applies to
      Linux v5.2 is enough for stable tree maintainer.
      
      Fixes: 89e0341a
      
       ("bcache: use sysfs_match_string() instead of __sysfs_match_string()")
      Cc: stable@vger.kernel.org
      Cc: Alexandru Ardelean <alexandru.ardelean@analog.com>
      Reported-by: default avatarPeifeng Lin <pflin@suse.com>
      Acked-by: default avatarAlexandru Ardelean <alexandru.ardelean@analog.com>
      Signed-off-by: default avatarColy Li <colyli@suse.de>
      Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
      20621fed
    • Heiko Carstens's avatar
      s390/vdso: map vdso also for statically linked binaries · 404861e1
      Heiko Carstens authored
      s390 does not map the vdso for statically linked binaries, assuming
      that this doesn't make sense. See commit fc5243d9
      
       ("[S390]
      arch_setup_additional_pages arguments").
      
      However with glibc commit d665367f596d ("linux: Enable vDSO for static
      linking as default (BZ#19767)") and commit 5e855c895401 ("s390: Enable
      VDSO for static linking") the vdso is also used for statically linked
      binaries - if the kernel would make it available.
      
      Therefore map the vdso always, just like all other architectures.
      
      Reported-by: default avatarStefan Liebler <stli@linux.ibm.com>
      Signed-off-by: default avatarHeiko Carstens <heiko.carstens@de.ibm.com>
      Signed-off-by: default avatarVasily Gorbik <gor@linux.ibm.com>
      404861e1
    • Alexandru Elisei's avatar
      KVM: arm/arm64: vgic: Reevaluate level sensitive interrupts on enable · 16e604a4
      Alexandru Elisei authored
      
      
      A HW mapped level sensitive interrupt asserted by a device will not be put
      into the ap_list if it is disabled at the VGIC level. When it is enabled
      again, it will be inserted into the ap_list and written to a list register
      on guest entry regardless of the state of the device.
      
      We could argue that this can also happen on real hardware, when the command
      to enable the interrupt reached the GIC before the device had the chance to
      de-assert the interrupt signal; however, we emulate the distributor and
      redistributors in software and we can do better than that.
      
      Signed-off-by: default avatarAlexandru Elisei <alexandru.elisei@arm.com>
      Signed-off-by: default avatarMarc Zyngier <maz@kernel.org>
      16e604a4
    • Marc Zyngier's avatar
      KVM: arm: Don't write junk to CP15 registers on reset · c69509c7
      Marc Zyngier authored
      
      
      At the moment, the way we reset CP15 registers is mildly insane:
      We write junk to them, call the reset functions, and then check that
      we have something else in them.
      
      The "fun" thing is that this can happen while the guest is running
      (PSCI, for example). If anything in KVM has to evaluate the state
      of a CP15 register while junk is in there, bad thing may happen.
      
      Let's stop doing that. Instead, we track that we have called a
      reset function for that register, and assume that the reset
      function has done something.
      
      In the end, the very need of this reset check is pretty dubious,
      as it doesn't check everything (a lot of the CP15 reg leave outside
      of the cp15_regs[] array). It may well be axed in the near future.
      
      Signed-off-by: default avatarMarc Zyngier <maz@kernel.org>
      c69509c7
    • Marc Zyngier's avatar
      KVM: arm64: Don't write junk to sysregs on reset · 03fdfb26
      Marc Zyngier authored
      
      
      At the moment, the way we reset system registers is mildly insane:
      We write junk to them, call the reset functions, and then check that
      we have something else in them.
      
      The "fun" thing is that this can happen while the guest is running
      (PSCI, for example). If anything in KVM has to evaluate the state
      of a system register while junk is in there, bad thing may happen.
      
      Let's stop doing that. Instead, we track that we have called a
      reset function for that register, and assume that the reset
      function has done something. This requires fixing a couple of
      sysreg refinition in the trap table.
      
      In the end, the very need of this reset check is pretty dubious,
      as it doesn't check everything (a lot of the sysregs leave outside of
      the sys_regs[] array). It may well be axed in the near future.
      
      Tested-by: default avatarZenghui Yu <yuzenghui@huawei.com>
      Signed-off-by: default avatarMarc Zyngier <maz@kernel.org>
      03fdfb26
    • Dave Airlie's avatar
      Merge tag 'drm-intel-fixes-2019-08-08' of... · a111ef6b
      Dave Airlie authored
      Merge tag 'drm-intel-fixes-2019-08-08' of git://anongit.freedesktop.org/drm/drm-intel
      
       into drm-fixes
      
      drm/i915 fixes for v5.3-rc4:
      - Fix GLK DSI escape clock setting
      - Fix a memleak on HDCP revoked Ksv error path
      
      Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
      From: Jani Nikula <jani.nikula@intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/87pnlghz79.fsf@intel.com
      a111ef6b
    • Dave Airlie's avatar
      Merge tag 'drm-misc-fixes-2019-08-08' of git://anongit.freedesktop.org/drm/drm-misc into drm-fixes · 359f1dcb
      Dave Airlie authored
      
      
      drm-misc-fixes for v5.3-rc4:
      - Suspend fix for rockchip
      - Fix unterminated strncpy cmdline mode parser
      
      Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
      
      From: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/ace294a6-6bb2-d9b1-695d-3260e1d60831@linux.intel.com
      359f1dcb
    • Dave Airlie's avatar
      6ca847a9
    • Linus Torvalds's avatar
      Merge tag 'nfs-for-5.3-2' of git://git.linux-nfs.org/projects/trondmy/linux-nfs · b678c568
      Linus Torvalds authored
      Pull NFS client fixes from Trond Myklebust:
       "Highlights include:
      
        Stable fixes:
      
         - NFSv4: Ensure we check the return value of update_open_stateid() so
           we correctly track active open state.
      
         - NFSv4: Fix for delegation state recovery to ensure we recover all
           open modes that are active.
      
         - NFSv4: Fix an Oops in nfs4_do_setattr
      
        Fixes:
      
         - NFS: Fix regression whereby fscache errors are appearing on 'nofsc'
           mounts
      
         - NFSv4: Fix a potential sleep while atomic in nfs4_do_reclaim()
      
         - NFSv4: Fix a credential refcount leak in nfs41_check_delegation_stateid
      
         - pNFS: Report errors from the call to nfs4_select_rw_stateid()
      
         - NFSv4: Various other delegation and open stateid recovery fixes
      
         - NFSv4: Fix state recovery behaviour when server connection times
           out"
      
      * tag 'nfs-for-5.3-2' of git://git.linux-nfs.org/projects/trondmy/linux-nfs:
        NFSv4: Ensure state recovery handles ETIMEDOUT correctly
        NFS: Fix regression whereby fscache errors are appearing on 'nofsc' mounts
        NFSv4: Fix an Oops in nfs4_do_setattr
        NFSv4: Fix a potential sleep while atomic in nfs4_do_reclaim()
        NFSv4: Check the return value of update_open_stateid()
        NFSv4.1: Only reap expired delegations
        NFSv4.1: Fix open stateid recovery
        NFSv4: Report the error from nfs4_select_rw_stateid()
        NFSv4: When recovering state fails with EAGAIN, retry the same recovery
        NFSv4: Print an error in the syslog when state is marked as irrecoverable
        NFSv4: Fix delegation state recovery
        NFSv4: Fix a credential refcount leak in nfs41_check_delegation_stateid
      b678c568
    • Jia He's avatar
      arm64: mm: add missing PTE_SPECIAL in pte_mkdevmap on arm64 · 30e23538
      Jia He authored
      Without this patch, the MAP_SYNC test case will cause a print_bad_pte
      warning on arm64 as follows:
      
      [   25.542693] BUG: Bad page map in process mapdax333 pte:2e8000448800f53 pmd:41ff5f003
      [   25.546360] page:ffff7e0010220000 refcount:1 mapcount:-1 mapping:ffff8003e29c7440 index:0x0
      [   25.550281] ext4_dax_aops
      [   25.550282] name:"__aaabbbcccddd__"
      [   25.551553] flags: 0x3ffff0000001002(referenced|reserved)
      [   25.555802] raw: 03ffff0000001002 ffff8003dfffa908 0000000000000000 ffff8003e29c7440
      [   25.559446] raw: 0000000000000000 0000000000000000 00000001fffffffe 0000000000000000
      [   25.563075] page dumped because: bad pte
      [   25.564938] addr:0000ffffbe05b000 vm_flags:208000fb anon_vma:0000000000000000 mapping:ffff8003e29c7440 index:0
      [   25.574272] file:__aaabbbcccddd__ fault:ext4_dax_fault mmmmap:ext4_file_mmap readpage:0x0
      [   25.578799] CPU: 1 PID: 1180 Comm: mapdax333 Not tainted 5.2.0+ #21
      [   25.581702] Hardware name: QEMU KVM Virtual Machine, BIOS 0.0.0 02/06/2015
      [   25.585624] Call trace:
      [   25.587008]  dump_backtrace+0x0/0x178
      [   25.588799]  show_stack+0x24/0x30
      [   25.590328]  dump_stack+0xa8/0xcc
      [   25.591901]  print_bad_pte+0x18c/0x218
      [   25.593628]  unmap_page_range+0x778/0xc00
      [   25.595506]  unmap_single_vma+0x94/0xe8
      [   25.597304]  unmap_vmas+0x90/0x108
      [   25.598901]  unmap_region+0xc0/0x128
      [   25.600566]  __do_munmap+0x284/0x3f0
      [   25.602245]  __vm_munmap+0x78/0xe0
      [   25.603820]  __arm64_sys_munmap+0x34/0x48
      [   25.605709]  el0_svc_common.constprop.0+0x78/0x168
      [   25.607956]  el0_svc_handler+0x34/0x90
      [   25.609698]  el0_svc+0x8/0xc
      [...]
      
      The root cause is in _vm_normal_page, without the PTE_SPECIAL bit,
      the return value will be incorrectly set to pfn_to_page(pfn) instead
      of NULL. Besides, this patch also rewrite the pmd_mkdevmap to avoid
      setting PTE_SPECIAL for pmd
      
      The MAP_SYNC test case is as follows(Provided by Yibo Cai)
      $#include <stdio.h>
      $#include <string.h>
      $#include <unistd.h>
      $#include <sys/file.h>
      $#include <sys/mman.h>
      
      $#ifndef MAP_SYNC
      $#define MAP_SYNC 0x80000
      $#endif
      
      /* mount -o dax /dev/pmem0 /mnt */
      $#define F "/mnt/__aaabbbcccddd__"
      
      int main(void)
      {
          int fd;
          char buf[4096];
          void *addr;
      
          if ((fd = open(F, O_CREAT|O_TRUNC|O_RDWR, 0644)) < 0) {
              perror("open1");
              return 1;
          }
      
          if (write(fd, buf, 4096) != 4096) {
              perror("lseek");
              return 1;
          }
      
          addr = mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_SHARED|MAP_SYNC, fd, 0);
          if (addr == MAP_FAILED) {
              perror("mmap");
              printf("did you mount with '-o dax'?\n");
              return 1;
          }
      
          memset(addr, 0x55, 4096);
      
          if (munmap(addr, 4096) == -1) {
              perror("munmap");
              return 1;
          }
      
          close(fd);
      
          return 0;
      }
      
      Fixes: 73b20c84
      
       ("arm64: mm: implement pte_devmap support")
      Reported-by: default avatarYibo Cai <Yibo.Cai@arm.com>
      Acked-by: default avatarWill Deacon <will@kernel.org>
      Acked-by: default avatarRobin Murphy <Robin.Murphy@arm.com>
      Signed-off-by: default avatarJia He <justin.he@arm.com>
      Signed-off-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
      30e23538
    • Linus Torvalds's avatar
      Merge tag '5.3-rc3-smb3-fixes' of git://git.samba.org/sfrench/cifs-2.6 · 518a1c2f
      Linus Torvalds authored
      Pull cifs fixes from Steve French:
       "Six small SMB3 fixes, two for stable"
      
      * tag '5.3-rc3-smb3-fixes' of git://git.samba.org/sfrench/cifs-2.6:
        SMB3: Kernel oops mounting a encryptData share with CONFIG_DEBUG_VIRTUAL
        smb3: update TODO list of missing features
        smb3: send CAP_DFS capability during session setup
        SMB3: Fix potential memory leak when processing compound chain
        SMB3: Fix deadlock in validate negotiate hits reconnect
        cifs: fix rmmod regression in cifs.ko caused by force_sig changes
      518a1c2f
    • Mikulas Patocka's avatar
      loop: set PF_MEMALLOC_NOIO for the worker thread · d0a255e7
      Mikulas Patocka authored
      
      
      A deadlock with this stacktrace was observed.
      
      The loop thread does a GFP_KERNEL allocation, it calls into dm-bufio
      shrinker and the shrinker depends on I/O completion in the dm-bufio
      subsystem.
      
      In order to fix the deadlock (and other similar ones), we set the flag
      PF_MEMALLOC_NOIO at loop thread entry.
      
      PID: 474    TASK: ffff8813e11f4600  CPU: 10  COMMAND: "kswapd0"
         #0 [ffff8813dedfb938] __schedule at ffffffff8173f405
         #1 [ffff8813dedfb990] schedule at ffffffff8173fa27
         #2 [ffff8813dedfb9b0] schedule_timeout at ffffffff81742fec
         #3 [ffff8813dedfba60] io_schedule_timeout at ffffffff8173f186
         #4 [ffff8813dedfbaa0] bit_wait_io at ffffffff8174034f
         #5 [ffff8813dedfbac0] __wait_on_bit at ffffffff8173fec8
         #6 [ffff8813dedfbb10] out_of_line_wait_on_bit at ffffffff8173ff81
         #7 [ffff8813dedfbb90] __make_buffer_clean at ffffffffa038736f [dm_bufio]
         #8 [ffff8813dedfbbb0] __try_evict_buffer at ffffffffa0387bb8 [dm_bufio]
         #9 [ffff8813dedfbbd0] dm_bufio_shrink_scan at ffffffffa0387cc3 [dm_bufio]
        #10 [ffff8813dedfbc40] shrink_slab at ffffffff811a87ce
        #11 [ffff8813dedfbd30] shrink_zone at ffffffff811ad778
        #12 [ffff8813dedfbdc0] kswapd at ffffffff811ae92f
        #13 [ffff8813dedfbec0] kthread at ffffffff810a8428
        #14 [ffff8813dedfbf50] ret_from_fork at ffffffff81745242
      
        PID: 14127  TASK: ffff881455749c00  CPU: 11  COMMAND: "loop1"
         #0 [ffff88272f5af228] __schedule at ffffffff8173f405
         #1 [ffff88272f5af280] schedule at ffffffff8173fa27
         #2 [ffff88272f5af2a0] schedule_preempt_disabled at ffffffff8173fd5e
         #3 [ffff88272f5af2b0] __mutex_lock_slowpath at ffffffff81741fb5
         #4 [ffff88272f5af330] mutex_lock at ffffffff81742133
         #5 [ffff88272f5af350] dm_bufio_shrink_count at ffffffffa03865f9 [dm_bufio]
         #6 [ffff88272f5af380] shrink_slab at ffffffff811a86bd
         #7 [ffff88272f5af470] shrink_zone at ffffffff811ad778
         #8 [ffff88272f5af500] do_try_to_free_pages at ffffffff811adb34
         #9 [ffff88272f5af590] try_to_free_pages at ffffffff811adef8
        #10 [ffff88272f5af610] __alloc_pages_nodemask at ffffffff811a09c3
        #11 [ffff88272f5af710] alloc_pages_current at ffffffff811e8b71
        #12 [ffff88272f5af760] new_slab at ffffffff811f4523
        #13 [ffff88272f5af7b0] __slab_alloc at ffffffff8173a1b5
        #14 [ffff88272f5af880] kmem_cache_alloc at ffffffff811f484b
        #15 [ffff88272f5af8d0] do_blockdev_direct_IO at ffffffff812535b3
        #16 [ffff88272f5afb00] __blockdev_direct_IO at ffffffff81255dc3
        #17 [ffff88272f5afb30] xfs_vm_direct_IO at ffffffffa01fe3fc [xfs]
        #18 [ffff88272f5afb90] generic_file_read_iter at ffffffff81198994
        #19 [ffff88272f5afc50] __dta_xfs_file_read_iter_2398 at ffffffffa020c970 [xfs]
        #20 [ffff88272f5afcc0] lo_rw_aio at ffffffffa0377042 [loop]
        #21 [ffff88272f5afd70] loop_queue_work at ffffffffa0377c3b [loop]
        #22 [ffff88272f5afe60] kthread_worker_fn at ffffffff810a8a0c
        #23 [ffff88272f5afec0] kthread at ffffffff810a8428
        #24 [ffff88272f5aff50] ret_from_fork at ffffffff81745242
      
      Signed-off-by: default avatarMikulas Patocka <mpatocka@redhat.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
      d0a255e7
  3. Aug 08, 2019