1. 22 Oct, 2019 1 commit
    • Alexander Shishkin's avatar
      perf/aux: Fix AUX output stopping · f3a519e4
      Alexander Shishkin authored
      Commit:
      
        8a58ddae ("perf/core: Fix exclusive events' grouping")
      
      allows CAP_EXCLUSIVE events to be grouped with other events. Since all
      of those also happen to be AUX events (which is not the case the other
      way around, because arch/s390), this changes the rules for stopping the
      output: the AUX event may not be on its PMU's context any more, if it's
      grouped with a HW event, in which case it will be on that HW event's
      context instead. If that's the case, munmap() of the AUX buffer can't
      find and stop the AUX event, potentially leaving the last reference with
      the atomic context, which will then end up freeing the AUX buffer. This
      will then trip warnings:
      
      Fix this by using the context's PMU context when looking for events
      to stop, instead of the event's PMU context.
      Signed-off-by: default avatarAlexander Shishkin <alexander.shishkin@linux.intel.com>
      Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
      Cc: Jiri Olsa <jolsa@redhat.com>
      Cc: Linus Torvalds <torvalds@linux-foundation.org>
      Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
      Cc: Peter Zijlstra <peterz@infradead.org>
      Cc: Stephane Eranian <eranian@google.com>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Vince Weaver <vincent.weaver@maine.edu>
      Cc: stable@vger.kernel.org
      Link: https://lkml.kernel.org/r/20191022073940.61814-1-alexander.shishkin@linux.intel.comSigned-off-by: default avatarIngo Molnar <mingo@kernel.org>
      f3a519e4
  2. 21 Oct, 2019 2 commits
    • Thomas Richter's avatar
      perf/aux: Fix tracking of auxiliary trace buffer allocation · 5e6c3c7b
      Thomas Richter authored
      The following commit from the v5.4 merge window:
      
        d44248a4 ("perf/core: Rework memory accounting in perf_mmap()")
      
      ... breaks auxiliary trace buffer tracking.
      
      If I run command 'perf record -e rbd000' to record samples and saving
      them in the **auxiliary** trace buffer then the value of 'locked_vm' becomes
      negative after all trace buffers have been allocated and released:
      
      During allocation the values increase:
      
        [52.250027] perf_mmap user->locked_vm:0x87 pinned_vm:0x0 ret:0
        [52.250115] perf_mmap user->locked_vm:0x107 pinned_vm:0x0 ret:0
        [52.250251] perf_mmap user->locked_vm:0x188 pinned_vm:0x0 ret:0
        [52.250326] perf_mmap user->locked_vm:0x208 pinned_vm:0x0 ret:0
        [52.250441] perf_mmap user->locked_vm:0x289 pinned_vm:0x0 ret:0
        [52.250498] perf_mmap user->locked_vm:0x309 pinned_vm:0x0 ret:0
        [52.250613] perf_mmap user->locked_vm:0x38a pinned_vm:0x0 ret:0
        [52.250715] perf_mmap user->locked_vm:0x408 pinned_vm:0x2 ret:0
        [52.250834] perf_mmap user->locked_vm:0x408 pinned_vm:0x83 ret:0
        [52.250915] perf_mmap user->locked_vm:0x408 pinned_vm:0x103 ret:0
        [52.251061] perf_mmap user->locked_vm:0x408 pinned_vm:0x184 ret:0
        [52.251146] perf_mmap user->locked_vm:0x408 pinned_vm:0x204 ret:0
        [52.251299] perf_mmap user->locked_vm:0x408 pinned_vm:0x285 ret:0
        [52.251383] perf_mmap user->locked_vm:0x408 pinned_vm:0x305 ret:0
        [52.251544] perf_mmap user->locked_vm:0x408 pinned_vm:0x386 ret:0
        [52.251634] perf_mmap user->locked_vm:0x408 pinned_vm:0x406 ret:0
        [52.253018] perf_mmap user->locked_vm:0x408 pinned_vm:0x487 ret:0
        [52.253197] perf_mmap user->locked_vm:0x408 pinned_vm:0x508 ret:0
        [52.253374] perf_mmap user->locked_vm:0x408 pinned_vm:0x589 ret:0
        [52.253550] perf_mmap user->locked_vm:0x408 pinned_vm:0x60a ret:0
        [52.253726] perf_mmap user->locked_vm:0x408 pinned_vm:0x68b ret:0
        [52.253903] perf_mmap user->locked_vm:0x408 pinned_vm:0x70c ret:0
        [52.254084] perf_mmap user->locked_vm:0x408 pinned_vm:0x78d ret:0
        [52.254263] perf_mmap user->locked_vm:0x408 pinned_vm:0x80e ret:0
      
      The value of user->locked_vm increases to a limit then the memory
      is tracked by pinned_vm.
      
      During deallocation the size is subtracted from pinned_vm until
      it hits a limit. Then a larger value is subtracted from locked_vm
      leading to a large number (because of type unsigned):
      
        [64.267797] perf_mmap_close mmap_user->locked_vm:0x408 pinned_vm:0x78d
        [64.267826] perf_mmap_close mmap_user->locked_vm:0x408 pinned_vm:0x70c
        [64.267848] perf_mmap_close mmap_user->locked_vm:0x408 pinned_vm:0x68b
        [64.267869] perf_mmap_close mmap_user->locked_vm:0x408 pinned_vm:0x60a
        [64.267891] perf_mmap_close mmap_user->locked_vm:0x408 pinned_vm:0x589
        [64.267911] perf_mmap_close mmap_user->locked_vm:0x408 pinned_vm:0x508
        [64.267933] perf_mmap_close mmap_user->locked_vm:0x408 pinned_vm:0x487
        [64.267952] perf_mmap_close mmap_user->locked_vm:0x408 pinned_vm:0x406
        [64.268883] perf_mmap_close mmap_user->locked_vm:0x307 pinned_vm:0x406
        [64.269117] perf_mmap_close mmap_user->locked_vm:0x206 pinned_vm:0x406
        [64.269433] perf_mmap_close mmap_user->locked_vm:0x105 pinned_vm:0x406
        [64.269536] perf_mmap_close mmap_user->locked_vm:0x4 pinned_vm:0x404
        [64.269797] perf_mmap_close mmap_user->locked_vm:0xffffffffffffff84 pinned_vm:0x303
        [64.270105] perf_mmap_close mmap_user->locked_vm:0xffffffffffffff04 pinned_vm:0x202
        [64.270374] perf_mmap_close mmap_user->locked_vm:0xfffffffffffffe84 pinned_vm:0x101
        [64.270628] perf_mmap_close mmap_user->locked_vm:0xfffffffffffffe04 pinned_vm:0x0
      
      This value sticks for the user until system is rebooted, causing
      follow-on system calls using locked_vm resource limit to fail.
      
      Note: There is no issue using the normal trace buffer.
      
      In fact the issue is in perf_mmap_close(). During allocation auxiliary
      trace buffer memory is either traced as 'extra' and added to 'pinned_vm'
      or trace as 'user_extra' and added to 'locked_vm'. This applies for
      normal trace buffers and auxiliary trace buffer.
      
      However in function perf_mmap_close() all auxiliary trace buffer is
      subtraced from 'locked_vm' and never from 'pinned_vm'. This breaks the
      ballance.
      Signed-off-by: default avatarThomas Richter <tmricht@linux.ibm.com>
      Acked-by: default avatarPeter Zijlstra <a.p.zijlstra@chello.nl>
      Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
      Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
      Cc: Jiri Olsa <jolsa@redhat.com>
      Cc: Linus Torvalds <torvalds@linux-foundation.org>
      Cc: Mark Rutland <mark.rutland@arm.com>
      Cc: Namhyung Kim <namhyung@kernel.org>
      Cc: Peter Zijlstra <peterz@infradead.org>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: acme@kernel.org
      Cc: gor@linux.ibm.com
      Cc: hechaol@fb.com
      Cc: heiko.carstens@de.ibm.com
      Cc: linux-perf-users@vger.kernel.org
      Cc: songliubraving@fb.com
      Fixes: d44248a4 ("perf/core: Rework memory accounting in perf_mmap()")
      Link: https://lkml.kernel.org/r/20191021083354.67868-1-tmricht@linux.ibm.com
      [ Minor readability edits. ]
      Signed-off-by: default avatarIngo Molnar <mingo@kernel.org>
      5e6c3c7b
    • Ingo Molnar's avatar
      Merge tag 'perf-urgent-for-mingo-5.4-20191017' of... · 22f12a0e
      Ingo Molnar authored
      Merge tag 'perf-urgent-for-mingo-5.4-20191017' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux into perf/urgent
      
      Pull perf/urgent fixes from Arnaldo Carvalho de Melo:
      
      perf buildid-cache:
      
        Adrian Hunter:
      
        - Fix mode setting in copyfile_mode_ns() when copying /proc/kcore.
      
      perf evlist:
      
        Andi Kleen:
      
        - Fix freeing id arrays.
      
      tools headers:
      
        - Sync sched.h anc kvm.h headers with the kernel sources.
      
      perf jvmti:
      
        Thomas Richter:
      
        - Link against tools/lib/ctype.o to have weak strlcpy().
      
      perf annotate:
      
        Gustavo A. R. Silva:
      
        - Fix multiple memory and file descriptor leaks, found by coverity.
      
      perf c2c/kmem:
      
        Yunfeng Ye:
      
         - Fix leaks in error handling paths in 'perf c2c', 'perf kmem',  found by
           internal static analysis tool.
      Signed-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
      Signed-off-by: default avatarIngo Molnar <mingo@kernel.org>
      22f12a0e
  3. 20 Oct, 2019 1 commit
  4. 16 Oct, 2019 1 commit
  5. 15 Oct, 2019 10 commits
  6. 13 Oct, 2019 16 commits
  7. 12 Oct, 2019 9 commits
    • Linus Torvalds's avatar
      Merge tag 'char-misc-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc · da940012
      Linus Torvalds authored
      Pull char/misc driver fixes from Greg KH:
       "Here are some small char/misc driver fixes for 5.4-rc3.
      
        Nothing huge here. Some binder driver fixes (although it is still
        being discussed if these all fix the reported issues or not, so more
        might be coming later), some mei device ids and fixes, and a google
        firmware driver bugfix that fixes a regression, as well as some other
        tiny fixes.
      
        All have been in linux-next with no reported issues"
      
      * tag 'char-misc-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc:
        firmware: google: increment VPD key_len properly
        w1: ds250x: Fix build error without CRC16
        virt: vbox: fix memory leak in hgcm_call_preprocess_linaddr
        binder: Fix comment headers on binder_alloc_prepare_to_free()
        binder: prevent UAF read in print_binder_transaction_log_entry()
        misc: fastrpc: prevent memory leak in fastrpc_dma_buf_attach
        mei: avoid FW version request on Ibex Peak and earlier
        mei: me: add comet point (lake) LP device ids
      da940012
    • Linus Torvalds's avatar
      Merge tag 'staging-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging · 9cbc6348
      Linus Torvalds authored
      Pull staging/IIO driver fixes from Greg KH:
       "Here are some staging and IIO driver fixes for 5.4-rc3.
      
        The "biggest" thing here is a removal of the fbtft device and flexfb
        code as they have been abandoned by their authors and are no longer
        needed for that hardware.
      
        Other than that, the usual amount of staging driver and iio driver
        fixes for reported issues, and some speakup sysfs file documentation,
        which has been long awaited for.
      
        All have been in linux-next with no reported issues"
      
      * tag 'staging-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging: (32 commits)
        iio: Fix an undefied reference error in noa1305_probe
        iio: light: opt3001: fix mutex unlock race
        iio: adc: ad799x: fix probe error handling
        iio: light: add missing vcnl4040 of_compatible
        iio: light: fix vcnl4000 devicetree hooks
        iio: imu: st_lsm6dsx: fix waitime for st_lsm6dsx i2c controller
        iio: adc: axp288: Override TS pin bias current for some models
        iio: imu: adis16400: fix memory leak
        iio: imu: adis16400: release allocated memory on failure
        iio: adc: stm32-adc: fix a race when using several adcs with dma and irq
        iio: adc: stm32-adc: move registers definitions
        iio: accel: adxl372: Perform a reset at start up
        iio: accel: adxl372: Fix push to buffers lost samples
        iio: accel: adxl372: Fix/remove limitation for FIFO samples
        iio: adc: hx711: fix bug in sampling of data
        staging: vt6655: Fix memory leak in vt6655_probe
        staging: exfat: Use kvzalloc() instead of kzalloc() for exfat_sb_info
        Staging: fbtft: fix memory leak in fbtft_framebuffer_alloc
        staging: speakup: document sysfs attributes
        staging: rtl8188eu: fix HighestRate check in odm_ARFBRefresh_8188E()
        ...
      9cbc6348
    • Linus Torvalds's avatar
      Merge tag 'tty-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty · 82c87e7d
      Linus Torvalds authored
      Pull tty/serial driver fixes from Greg KH:
       "Here are some small tty and serial driver fixes for 5.4-rc3 that
        resolve a number of reported issues and regressions.
      
        None of these are huge, full details are in the shortlog. There's also
        a MAINTAINERS update that I think you might have already taken in your
        tree already, but git should handle that merge easily.
      
        All have been in linux-next with no reported issues"
      
      * tag 'tty-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty:
        MAINTAINERS: kgdb: Add myself as a reviewer for kgdb/kdb
        tty: serial: imx: Use platform_get_irq_optional() for optional IRQs
        serial: fix kernel-doc warning in comments
        serial: 8250_omap: Fix gpio check for auto RTS/CTS
        serial: mctrl_gpio: Check for NULL pointer
        tty: serial: fsl_lpuart: Fix lpuart_flush_buffer()
        tty: serial: Fix PORT_LINFLEXUART definition
        tty: n_hdlc: fix build on SPARC
        serial: uartps: Fix uartps_major handling
        serial: uartlite: fix exit path null pointer
        tty: serial: linflexuart: Fix magic SysRq handling
        serial: sh-sci: Use platform_get_irq_optional() for optional interrupts
        dt-bindings: serial: sh-sci: Document r8a774b1 bindings
        serial/sifive: select SERIAL_EARLYCON
        tty: serial: rda: Fix the link time qualifier of 'rda_uart_exit()'
        tty: serial: owl: Fix the link time qualifier of 'owl_uart_exit()'
      82c87e7d
    • Linus Torvalds's avatar
      Merge tag 'usb-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb · 6c90bbd0
      Linus Torvalds authored
      Pull USB fixes from Greg KH:
       "Here are a lot of small USB driver fixes for 5.4-rc3.
      
        syzbot has stepped up its testing of the USB driver stack, now able to
        trigger fun race conditions between disconnect and probe functions.
        Because of that we have a lot of fixes in here from Johan and others
        fixing these reported issues that have been around since almost all
        time.
      
        We also are just deleting the rio500 driver, making all of the syzbot
        bugs found in it moot as it turns out no one has been using it for
        years as there is a userspace version that is being used instead.
      
        There are also a number of other small fixes in here, all resolving
        reported issues or regressions.
      
        All have been in linux-next without any reported issues"
      
      * tag 'usb-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb: (65 commits)
        USB: yurex: fix NULL-derefs on disconnect
        USB: iowarrior: use pr_err()
        USB: iowarrior: drop redundant iowarrior mutex
        USB: iowarrior: drop redundant disconnect mutex
        USB: iowarrior: fix use-after-free after driver unbind
        USB: iowarrior: fix use-after-free on release
        USB: iowarrior: fix use-after-free on disconnect
        USB: chaoskey: fix use-after-free on release
        USB: adutux: fix use-after-free on release
        USB: ldusb: fix NULL-derefs on driver unbind
        USB: legousbtower: fix use-after-free on release
        usb: cdns3: Fix for incorrect DMA mask.
        usb: cdns3: fix cdns3_core_init_role()
        usb: cdns3: gadget: Fix full-speed mode
        USB: usb-skeleton: drop redundant in-urb check
        USB: usb-skeleton: fix use-after-free after driver unbind
        USB: usb-skeleton: fix NULL-deref on disconnect
        usb:cdns3: Fix for CV CH9 running with g_zero driver.
        usb: dwc3: Remove dev_err() on platform_get_irq() failure
        usb: dwc3: Switch to platform_get_irq_byname_optional()
        ...
      6c90bbd0
    • Linus Torvalds's avatar
      Merge branch 'sched-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 328fefad
      Linus Torvalds authored
      Pull scheduler fixes from Ingo Molnar:
       "Two fixes: a guest-cputime accounting fix, and a cgroup bandwidth
        quota precision fix"
      
      * 'sched-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        sched/vtime: Fix guest/system mis-accounting on task switch
        sched/fair: Scale bandwidth quota and period without losing quota/period ratio precision
      328fefad
    • Linus Torvalds's avatar
      Merge branch 'perf-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 465a7e29
      Linus Torvalds authored
      Pull perf fixes from Ingo Molnar:
       "Mostly tooling fixes, but also a couple of updates for new Intel
        models (which are technically hw-enablement, but to users it's a fix
        to perf behavior on those new CPUs - hope this is fine), an AUX
        inheritance fix, event time-sharing fix, and a fix for lost non-perf
        NMI events on AMD systems"
      
      * 'perf-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (36 commits)
        perf/x86/cstate: Add Tiger Lake CPU support
        perf/x86/msr: Add Tiger Lake CPU support
        perf/x86/intel: Add Tiger Lake CPU support
        perf/x86/cstate: Update C-state counters for Ice Lake
        perf/x86/msr: Add new CPU model numbers for Ice Lake
        perf/x86/cstate: Add Comet Lake CPU support
        perf/x86/msr: Add Comet Lake CPU support
        perf/x86/intel: Add Comet Lake CPU support
        perf/x86/amd: Change/fix NMI latency mitigation to use a timestamp
        perf/core: Fix corner case in perf_rotate_context()
        perf/core: Rework memory accounting in perf_mmap()
        perf/core: Fix inheritance of aux_output groups
        perf annotate: Don't return -1 for error when doing BPF disassembly
        perf annotate: Return appropriate error code for allocation failures
        perf annotate: Fix arch specific ->init() failure errors
        perf annotate: Propagate the symbol__annotate() error return
        perf annotate: Fix the signedness of failure returns
        perf annotate: Propagate perf_env__arch() error
        perf evsel: Fall back to global 'perf_env' in perf_evsel__env()
        perf tools: Propagate get_cpuid() error
        ...
      465a7e29
    • Linus Torvalds's avatar
      Merge branch 'efi-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 9b4e40c8
      Linus Torvalds authored
      Pull EFI fixes from Ingo Molnar:
       "Misc EFI fixes all across the map: CPER error report fixes, fixes to
        TPM event log parsing, fix for a kexec hang, a Sparse fix and other
        fixes"
      
      * 'efi-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        efi/tpm: Fix sanity check of unsigned tbl_size being less than zero
        efi/x86: Do not clean dummy variable in kexec path
        efi: Make unexported efi_rci2_sysfs_init() static
        efi/tpm: Only set 'efi_tpm_final_log_size' after successful event log parsing
        efi/tpm: Don't traverse an event log with no events
        efi/tpm: Don't access event->count when it isn't mapped
        efivar/ssdt: Don't iterate over EFI vars if no SSDT override was specified
        efi/cper: Fix endianness of PCIe class code
      9b4e40c8
    • Linus Torvalds's avatar
      Merge branch 'x86-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · fcb45a28
      Linus Torvalds authored
      Pull x86 fixes from Ingo Molnar:
       "A handful of fixes: a kexec linking fix, an AMD MWAITX fix, a vmware
        guest support fix when built under Clang, and new CPU model number
        definitions"
      
      * 'x86-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/cpu: Add Comet Lake to the Intel CPU models header
        lib/string: Make memzero_explicit() inline instead of external
        x86/cpu/vmware: Use the full form of INL in VMWARE_PORT
        x86/asm: Fix MWAITX C-state hint value
      fcb45a28
    • Linus Torvalds's avatar
      Merge branch 'core-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · e9ec3588
      Linus Torvalds authored
      Pull x86 license tag fixlets from Ingo Molnar:
       "Fix a couple of SPDX tags in x86 headers to follow the canonical
        pattern"
      
      * 'core-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86: Use the correct SPDX License Identifier in headers
      e9ec3588