1. 22 Jun, 2023 5 commits
    • Azeem Shaikh's avatar
      tracing/boot: Replace strlcpy with strscpy · 38638ffa
      Azeem Shaikh authored
      strlcpy() reads the entire source buffer first.
      This read may exceed the destination size limit.
      This is both inefficient and can lead to linear read
      overflows if a source string is not NUL-terminated [1].
      In an effort to remove strlcpy() completely [2], replace
      strlcpy() here with strscpy().
      
      Direct replacement is safe here since return value of -E2BIG
      is used to check for truncation instead of sizeof(dest).
      
      [1] https://www.kernel.org/doc/html/latest/process/deprecated.html#strlcpy
      [2] https://github.com/KSPP/linux/issues/89
      
      Link: https://lore.kernel.org/linux-trace-kernel/20230613004125.3539934-1-azeemshaikh38@gmail.com
      
      Cc: Masami Hiramatsu <mhiramat@kernel.org>
      Signed-off-by: default avatarAzeem Shaikh <azeemshaikh38@gmail.com>
      Reviewed-by: default avatarKees Cook <keescook@chromium.org>
      Signed-off-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
      38638ffa
    • Daniel Bristot de Oliveira's avatar
      tracing/timerlat: Add user-space interface · e88ed227
      Daniel Bristot de Oliveira authored
      Going a step further, we propose a way to use any user-space
      workload as the task waiting for the timerlat timer. This is done
      via a per-CPU file named osnoise/cpu$id/timerlat_fd file.
      
      The tracef_fd allows a task to open at a time. When a task reads
      the file, the timerlat timer is armed for future osnoise/timerlat_period_us
      time. When the timer fires, it prints the IRQ latency and
      wakes up the user-space thread waiting in the timerlat_fd.
      
      The thread then starts to run, executes the timerlat measurement, prints
      the thread scheduling latency and returns to user-space.
      
      When the thread rereads the timerlat_fd, the tracer will print the
      user-ret(urn) latency, which is an additional metric.
      
      This additional metric is also traced by the tracer and can be used, for
      example of measuring the context switch overhead from kernel-to-user and
      user-to-kernel, or the response time for an arbitrary execution in
      user-space.
      
      The tracer supports one thread per CPU, the thread must be pinned to
      the CPU, and it cannot migrate while holding the timerlat_fd. The reason
      is that the tracer is per CPU (nothing prohibits the tracer from
      allowing migrations in the future). The tracer monitors the migration
      of the thread and disables the tracer if detected.
      
      The timerlat_fd is only available for opening/reading when timerlat
      tracer is enabled, and NO_OSNOISE_WORKLOAD is set.
      
      The simplest way to activate this feature from user-space is:
      
       -------------------------------- %< -----------------------------------
       int main(void)
       {
      	char buffer[1024];
      	int timerlat_fd;
      	int retval;
      	long cpu = 0;	/* place in CPU 0 */
      	cpu_set_t set;
      
      	CPU_ZERO(&set);
      	CPU_SET(cpu, &set);
      
      	if (sched_setaffinity(gettid(), sizeof(set), &set) == -1)
      		return 1;
      
      	snprintf(buffer, sizeof(buffer),
      		"/sys/kernel/tracing/osnoise/per_cpu/cpu%ld/timerlat_fd",
      		cpu);
      
      	timerlat_fd = open(buffer, O_RDONLY);
      	if (timerlat_fd < 0) {
      		printf("error opening %s: %s\n", buffer, strerror(errno));
      		exit(1);
      	}
      
      	for (;;) {
      		retval = read(timerlat_fd, buffer, 1024);
      		if (retval < 0)
      			break;
      	}
      
      	close(timerlat_fd);
      	exit(0);
      }
       -------------------------------- >% -----------------------------------
      
      When disabling timerlat, if there is a workload holding the timerlat_fd,
      the SIGKILL will be sent to the thread.
      
      Link: https://lkml.kernel.org/r/69fe66a863d2792ff4c3a149bf9e32e26468bb3a.1686063934.git.bristot@kernel.org
      
      Cc: Juri Lelli <juri.lelli@redhat.com>
      Cc: William White <chwhite@redhat.com>
      Cc: Daniel Bristot de Oliveira <bristot@kernel.org>
      Cc: Masami Hiramatsu <mhiramat@kernel.org>
      Cc: Jonathan Corbet <corbet@lwn.net>
      Signed-off-by: default avatarDaniel Bristot de Oliveira <bristot@kernel.org>
      Signed-off-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
      e88ed227
    • Daniel Bristot de Oliveira's avatar
      tracing/osnoise: Skip running osnoise if all instances are off · cb7ca871
      Daniel Bristot de Oliveira authored
      In the case of all tracing instances being off, sleep for the entire
      period.
      
       Q: Why not kill all threads so?
       A: It is valid and useful to start the threads with tracing off.
      For example, rtla disables tracing, starts the tracer, applies the
      scheduling setup to the threads, e.g., sched priority and cgroup,
      and then begin tracing with all set.
      
      Skipping the period helps to speed up rtla setup and save the
      trace after a stop tracing.
      
      Link: https://lkml.kernel.org/r/aa4dd9b7e76fcb63901fe5407e15ec002b318599.1686063934.git.bristot@kernel.org
      
      Cc: Juri Lelli <juri.lelli@redhat.com>
      Cc: William White <chwhite@redhat.com>
      Cc: Daniel Bristot de Oliveira <bristot@kernel.org>
      Cc: Masami Hiramatsu <mhiramat@kernel.org>
      Cc: Jonathan Corbet <corbet@lwn.net>
      Signed-off-by: default avatarDaniel Bristot de Oliveira <bristot@kernel.org>
      Signed-off-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
      cb7ca871
    • Daniel Bristot de Oliveira's avatar
      tracing/osnoise: Switch from PF_NO_SETAFFINITY to migrate_disable · 4998e7fd
      Daniel Bristot de Oliveira authored
      Currently, osnoise/timerlat threads run with PF_NO_SETAFFINITY set.
      It works well, however, cgroups do not allow PF_NO_SETAFFINITY threads
      to be accepted, and this creates a limitation to osnoise/timerlat.
      
      To avoid this limitation, disable migration of the threads as soon
      as they start to run, and then clean the PF_NO_SETAFFINITY flag (still)
      used during thread creation.
      
      If for some reason a thread migration is requested, e.g., via
      sched_settafinity, the tracer thread will notice and exit.
      
      Link: https://lkml.kernel.org/r/8ba8bc9c15b3ea40cf73cf67a9bc061a264609f0.1686063934.git.bristot@kernel.org
      
      Cc: Juri Lelli <juri.lelli@redhat.com>
      Cc: William White <chwhite@redhat.com>
      Cc: Daniel Bristot de Oliveira <bristot@kernel.org>
      Cc: Masami Hiramatsu <mhiramat@kernel.org>
      Cc: Jonathan Corbet <corbet@lwn.net>
      Signed-off-by: default avatarDaniel Bristot de Oliveira <bristot@kernel.org>
      Signed-off-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
      4998e7fd
    • Jiri Olsa's avatar
      ftrace: Show all functions with addresses in available_filter_functions_addrs · 83f74441
      Jiri Olsa authored
      Adding new available_filter_functions_addrs file that shows all available
      functions (same as available_filter_functions) together with addresses,
      like:
      
        # cat available_filter_functions_addrs | head
        ffffffff81000770 __traceiter_initcall_level
        ffffffff810007c0 __traceiter_initcall_start
        ffffffff81000810 __traceiter_initcall_finish
        ffffffff81000860 trace_initcall_finish_cb
        ...
      
      Note displayed address is the patch-site address and can differ from
      /proc/kallsyms address.
      
      It's useful to have address avilable for traceable symbols, so we don't
      need to allways cross check kallsyms with available_filter_functions
      (or the other way around) and have all the data in single file.
      
      For backwards compatibility reasons we can't change the existing
      available_filter_functions file output, but we need to add new file.
      
      The problem is that we need to do 2 passes:
      
       - through available_filter_functions and find out if the function is traceable
       - through /proc/kallsyms to get the address for traceable function
      
      Having available_filter_functions symbols together with addresses allow
      us to skip the kallsyms step and we are ok with the address in
      available_filter_functions_addr not being the function entry, because
      kprobe_multi uses fprobe and that handles both entry and patch-site
      address properly.
      
      We have 2 interfaces how to create kprobe_multi link:
      
        a) passing symbols to kernel
      
           1) user gathers symbols and need to ensure that they are
              trace-able -> pass through available_filter_functions file
      
           2) kernel takes those symbols and translates them to addresses
              through kallsyms api
      
           3) addresses are passed to fprobe/ftrace through:
      
               register_fprobe_ips
               -> ftrace_set_filter_ips
      
        b) passing addresses to kernel
      
           1) user gathers symbols and needs to ensure that they are
              trace-able -> pass through available_filter_functions file
      
           2) user takes those symbols and translates them to addresses
             through /proc/kallsyms
      
           3) addresses are passed to the kernel and kernel calls:
      
               register_fprobe_ips
               -> ftrace_set_filter_ips
      
      The new available_filter_functions_addrs file helps us with option b),
      because we can make 'b 1' and 'b 2' in one step - while filtering traceable
      functions, we get the address directly.
      
      Link: https://lore.kernel.org/linux-trace-kernel/20230611130029.1202298-1-jolsa@kernel.org
      
      Cc: Masami Hiramatsu <mhiramat@kernel.org>
      Cc: Mark Rutland <mark.rutland@arm.com>
      Cc: Andrii Nakryiko <andrii.nakryiko@gmail.com>
      Tested-by: Jackie Liu <liuyun01@kylinos.cn> # x86
      Suggested-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
      Suggested-by: default avatarAndrii Nakryiko <andrii@kernel.org>
      Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
      Signed-off-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
      83f74441
  2. 20 Jun, 2023 7 commits
  3. 04 Jun, 2023 9 commits
    • Linus Torvalds's avatar
      Linux 6.4-rc5 · 9561de3a
      Linus Torvalds authored
      9561de3a
    • Linus Torvalds's avatar
      Merge tag 'irq_urgent_for_v6.4_rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 6f64a5eb
      Linus Torvalds authored
      Pull irq fix from Borislav Petkov:
      
       - Fix open firmware quirks validation so that they don't get applied
         wrongly
      
      * tag 'irq_urgent_for_v6.4_rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        irqchip/gic: Correctly validate OF quirk descriptors
      6f64a5eb
    • Linus Torvalds's avatar
      Merge tag 'media/v6.4-4' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media · 5e89d62e
      Linus Torvalds authored
      Pull media fixes from Mauro Carvalho Chehab:
       "Some driver fixes:
         - a regression fix for the verisilicon driver
         - uvcvideo: don't expose unsupported video formats to userspace
         - camss-video: don't zero subdev format after init
         - mediatek: some fixes for 4K decoder formats
         - fix a Sphinx build warning (missing doc for client_caps)
         - some fixes for imx and atomisp staging drivers
      
        And two CEC core fixes:
         - don't set last_initiator if TX in progress
         - disable adapter in cec_devnode_unregister"
      
      * tag 'media/v6.4-4' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media:
        media: uvcvideo: Don't expose unsupported formats to userspace
        media: v4l2-subdev: Fix missing kerneldoc for client_caps
        media: staging: media: imx: initialize hs_settle to avoid warning
        media: v4l2-mc: Drop subdev check in v4l2_create_fwnode_links_to_pad()
        media: staging: media: atomisp: init high & low vars
        media: cec: core: don't set last_initiator if tx in progress
        media: cec: core: disable adapter in cec_devnode_unregister
        media: mediatek: vcodec: Only apply 4K frame sizes on decoder formats
        media: camss: camss-video: Don't zero subdev format again after initialization
        media: verisilicon: Additional fix for the crash when opening the driver
      5e89d62e
    • Linus Torvalds's avatar
      Merge tag 'char-misc-6.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc · 209835e8
      Linus Torvalds authored
      Pull char/misc driver fixes from Greg KH:
       "Here are a bunch of tiny char/misc/other driver fixes for 6.4-rc5 that
        resolve a number of reported issues. Included in here are:
      
         - iio driver fixes
      
         - fpga driver fixes
      
         - test_firmware bugfixes
      
         - fastrpc driver tiny bugfixes
      
         - MAINTAINERS file updates for some subsystems
      
        All of these have been in linux-next this past week with no reported
        issues"
      
      * tag 'char-misc-6.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc: (34 commits)
        test_firmware: fix the memory leak of the allocated firmware buffer
        test_firmware: fix a memory leak with reqs buffer
        test_firmware: prevent race conditions by a correct implementation of locking
        firmware_loader: Fix a NULL vs IS_ERR() check
        MAINTAINERS: Vaibhav Gupta is the new ipack maintainer
        dt-bindings: fpga: replace Ivan Bornyakov maintainership
        MAINTAINERS: update Microchip MPF FPGA reviewers
        misc: fastrpc: reject new invocations during device removal
        misc: fastrpc: return -EPIPE to invocations on device removal
        misc: fastrpc: Reassign memory ownership only for remote heap
        misc: fastrpc: Pass proper scm arguments for secure map request
        iio: imu: inv_icm42600: fix timestamp reset
        iio: adc: ad_sigma_delta: Fix IRQ issue by setting IRQ_DISABLE_UNLAZY flag
        dt-bindings: iio: adc: renesas,rcar-gyroadc: Fix adi,ad7476 compatible value
        iio: dac: mcp4725: Fix i2c_master_send() return value handling
        iio: accel: kx022a fix irq getting
        iio: bu27034: Ensure reset is written
        iio: dac: build ad5758 driver when AD5758 is selected
        iio: addac: ad74413: fix resistance input processing
        iio: light: vcnl4035: fixed chip ID check
        ...
      209835e8
    • Linus Torvalds's avatar
      Merge tag 'driver-core-6.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core · 41f3ab2d
      Linus Torvalds authored
      Pull driver core fixes from Greg KH:
       "Here are two small driver core cacheinfo fixes for 6.4-rc5 that
        resolve a number of reported issues with that file. These changes have
        been in linux-next this past week with no reported problems"
      
      * tag 'driver-core-6.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core:
        drivers: base: cacheinfo: Update cpu_map_populated during CPU Hotplug
        drivers: base: cacheinfo: Fix shared_cpu_map changes in event of CPU hotplug
      41f3ab2d
    • Linus Torvalds's avatar
      Merge tag 'tty-6.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty · 12c2f77b
      Linus Torvalds authored
      Pull tty/serial driver fixes from Greg KH:
       "Here are some small tty/serial driver fixes for 6.4-rc5 that have all
        been in linux-next this past week with no reported problems. Included
        in here are:
      
         - 8250_tegra driver bugfix
      
         - fsl uart driver bugfixes
      
         - Kconfig fix for dependancy issue
      
         - dt-bindings fix for the 8250_omap driver"
      
      * tag 'tty-6.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty:
        dt-bindings: serial: 8250_omap: add rs485-rts-active-high
        serial: cpm_uart: Fix a COMPILE_TEST dependency
        soc: fsl: cpm1: Fix TSA and QMC dependencies in case of COMPILE_TEST
        tty: serial: fsl_lpuart: use UARTCTRL_TXINV to send break instead of UARTCTRL_SBK
        serial: 8250_tegra: Fix an error handling path in tegra_uart_probe()
      12c2f77b
    • Linus Torvalds's avatar
      Merge tag 'usb-6.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb · 8b435e40
      Linus Torvalds authored
      Pull USB fixes from Greg KH:
       "Here are some USB driver and core fixes for 6.4-rc5. Most of these are
        tiny driver fixes, including:
      
         - udc driver bugfix
      
         - f_fs gadget driver bugfix
      
         - cdns3 driver bugfix
      
         - typec bugfixes
      
        But the "big" thing in here is a fix yet-again for how the USB buffers
        are handled from userspace when dealing with DMA issues. The changes
        were discussed a lot, and tested a lot, on the list, and acked by the
        relevant mm maintainers and have been in linux-next all this past week
        with no reported problems"
      
      * tag 'usb-6.4-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb:
        usb: typec: tps6598x: Fix broken polling mode after system suspend/resume
        mm: page_table_check: Ensure user pages are not slab pages
        mm: page_table_check: Make it dependent on EXCLUSIVE_SYSTEM_RAM
        usb: usbfs: Use consistent mmap functions
        usb: usbfs: Enforce page requirements for mmap
        dt-bindings: usb: snps,dwc3: Fix "snps,hsphy_interface" type
        usb: gadget: udc: fix NULL dereference in remove()
        usb: gadget: f_fs: Add unbind event before functionfs_unbind
        usb: cdns3: fix NCM gadget RX speed 20x slow than expection at iMX8QM
      8b435e40
    • Linus Torvalds's avatar
      Merge tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm · b066935b
      Linus Torvalds authored
      Pull kvm fixes from Paolo Bonzini:
       "ARM:
      
         - Address some fallout of the locking rework, this time affecting the
           way the vgic is configured
      
         - Fix an issue where the page table walker frees a subtree and then
           proceeds with walking what it has just freed...
      
         - Check that a given PA donated to the guest is actually memory (only
           affecting pKVM)
      
         - Correctly handle MTE CMOs by Set/Way
      
         - Fix the reported address of a watchpoint forwarded to userspace
      
         - Fix the freeing of the root of stage-2 page tables
      
         - Stop creating spurious PMU events to perform detection of the
           default PMU and use the existing PMU list instead
      
        x86:
      
         - Fix a memslot lookup bug in the NX recovery thread that could
           theoretically let userspace bypass the NX hugepage mitigation
      
         - Fix a s/BLOCKING/PENDING bug in SVM's vNMI support
      
         - Account exit stats for fastpath VM-Exits that never leave the super
           tight run-loop
      
         - Fix an out-of-bounds bug in the optimized APIC map code, and add a
           regression test for the race"
      
      * tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm:
        KVM: selftests: Add test for race in kvm_recalculate_apic_map()
        KVM: x86: Bail from kvm_recalculate_phys_map() if x2APIC ID is out-of-bounds
        KVM: x86: Account fastpath-only VM-Exits in vCPU stats
        KVM: SVM: vNMI pending bit is V_NMI_PENDING_MASK not V_NMI_BLOCKING_MASK
        KVM: x86/mmu: Grab memslot for correct address space in NX recovery worker
        KVM: arm64: Document default vPMU behavior on heterogeneous systems
        KVM: arm64: Iterate arm_pmus list to probe for default PMU
        KVM: arm64: Drop last page ref in kvm_pgtable_stage2_free_removed()
        KVM: arm64: Populate fault info for watchpoint
        KVM: arm64: Reload PTE after invoking walker callback on preorder traversal
        KVM: arm64: Handle trap of tagged Set/Way CMOs
        arm64: Add missing Set/Way CMO encodings
        KVM: arm64: Prevent unconditional donation of unmapped regions from the host
        KVM: arm64: vgic: Fix a comment
        KVM: arm64: vgic: Fix locking comment
        KVM: arm64: vgic: Wrap vgic_its_create() with config_lock
        KVM: arm64: vgic: Fix a circular locking issue
      b066935b
    • Linus Torvalds's avatar
      Merge tag 'powerpc-6.4-4' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux · 9455b4b6
      Linus Torvalds authored
      Pull powerpc fixes from Michael Ellerman:
      
       - Fix link errors in new aes-gcm-p10 code when built-in with other
         drivers
      
       - Limit number of TCEs passed to H_STUFF_TCE hcall as per spec
      
       - Use KSYM_NAME_LEN in xmon array size to avoid possible OOB write
      
      Thanks to Gaurav Batra and Maninder Singh Vishal Chourasia.
      
      * tag 'powerpc-6.4-4' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux:
        powerpc/xmon: Use KSYM_NAME_LEN in array size
        powerpc/iommu: Limit number of TCEs to 512 for H_STUFF_TCE hcall
        powerpc/crypto: Fix aes-gcm-p10 link errors
      9455b4b6
  4. 03 Jun, 2023 10 commits
  5. 02 Jun, 2023 9 commits