1. 05 Dec, 2023 1 commit
  2. 22 Nov, 2023 17 commits
    • Arnaldo Carvalho de Melo's avatar
      tools: Disable __packed attribute compiler warning due to -Werror=attributes · 57686a72
      Arnaldo Carvalho de Melo authored
      Noticed on several perf tools cross build test containers:
      
        [perfbuilder@five ~]$ grep FAIL ~/dm.log/summary
          19    10.18 debian:experimental-x-mips    : FAIL gcc version 12.3.0 (Debian 12.3.0-6)
          20    11.21 debian:experimental-x-mips64  : FAIL gcc version 12.3.0 (Debian 12.3.0-6)
          21    11.30 debian:experimental-x-mipsel  : FAIL gcc version 12.3.0 (Debian 12.3.0-6)
          37    12.07 ubuntu:18.04-x-arm            : FAIL gcc version 7.5.0 (Ubuntu/Linaro 7.5.0-3ubuntu1~18.04)
          42    11.91 ubuntu:18.04-x-riscv64        : FAIL gcc version 7.5.0 (Ubuntu 7.5.0-3ubuntu1~18.04)
          44    13.17 ubuntu:18.04-x-sh4            : FAIL gcc version 7.5.0 (Ubuntu 7.5.0-3ubuntu1~18.04)
          45    12.09 ubuntu:18.04-x-sparc64        : FAIL gcc version 7.5.0 (Ubuntu 7.5.0-3ubuntu1~18.04)
        [perfbuilder@five ~]$
      
        In file included from util/intel-pt-decoder/intel-pt-pkt-decoder.c:10:
        /tmp/perf-6.6.0-rc1/tools/include/asm-generic/unaligned.h: In function 'get_unaligned_le16':
        /tmp/perf-6.6.0-rc1/tools/include/asm-generic/unaligned.h:13:29: error: packed attribute causes inefficient alignment for 'x' [-Werror=attributes]
           13 |         const struct { type x; } __packed *__pptr = (typeof(__pptr))(ptr);      \
              |                             ^
        /tmp/perf-6.6.0-rc1/tools/include/asm-generic/unaligned.h:27:28: note: in expansion of macro '__get_unaligned_t'
           27 |         return le16_to_cpu(__get_unaligned_t(__le16, p));
              |                            ^~~~~~~~~~~~~~~~~
      
      This comes from the kernel, where the -Wattributes and -Wpacked isn't
      used, -Wpacked is already disabled, do it for the attributes as well.
      
      Fixes: a91c9872 ("perf tools: Add get_unaligned_leNN()")
      Suggested-by: default avatarAdrian Hunter <adrian.hunter@intel.com>
      Cc: Ian Rogers <irogers@google.com>
      Cc: Jiri Olsa <jolsa@kernel.org>
      Cc: Namhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/lkml/7c5b626c-1de9-4c12-a781-e44985b4a797@intel.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      57686a72
    • Oliver Upton's avatar
      perf build: Ensure sysreg-defs Makefile respects output dir · a29ee6ae
      Oliver Upton authored
      Currently the sysreg-defs are written out to the source tree
      unconditionally, ignoring the specified output directory. Correct the
      build rule to emit the header to the output directory. Opportunistically
      reorganize the rules to avoid interleaving with the set of beauty make
      rules.
      Reported-by: default avatarIan Rogers <irogers@google.com>
      Signed-off-by: default avatarOliver Upton <oliver.upton@linux.dev>
      Link: https://lore.kernel.org/r/20231121192956.919380-3-oliver.upton@linux.devSigned-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      a29ee6ae
    • Oliver Upton's avatar
      tools perf: Add arm64 sysreg files to MANIFEST · ef5c9580
      Oliver Upton authored
      Ian pointed out that source tarballs are incomplete as of commit
      e2bdd172 ("perf build: Generate arm64's sysreg-defs.h and add to
      include path"), since the source files needed from the kernel tree do
      not appear in the manifest. Add them.
      Reported-by: default avatarIan Rogers <irogers@google.com>
      Fixes: e2bdd172 ("perf build: Generate arm64's sysreg-defs.h and add to include path")
      Signed-off-by: default avatarOliver Upton <oliver.upton@linux.dev>
      Link: https://lore.kernel.org/r/20231121192956.919380-2-oliver.upton@linux.devSigned-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      ef5c9580
    • Namhyung Kim's avatar
      tools/perf: Update tools's copy of mips syscall table · 027905fe
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
      Cc: linux-mips@vger.kernel.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-14-namhyung@kernel.org
      027905fe
    • Namhyung Kim's avatar
      tools/perf: Update tools's copy of s390 syscall table · d3968c97
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Heiko Carstens <hca@linux.ibm.com>
      Cc: Vasily Gorbik <gor@linux.ibm.com>
      Cc: Alexander Gordeev <agordeev@linux.ibm.com>
      Cc: Christian Borntraeger <borntraeger@linux.ibm.com>
      Cc: Sven Schnelle <svens@linux.ibm.com>
      Cc: linux-s390@vger.kernel.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-13-namhyung@kernel.org
      d3968c97
    • Namhyung Kim's avatar
      tools/perf: Update tools's copy of powerpc syscall table · 3483d244
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Michael Ellerman <mpe@ellerman.id.au>
      Cc: Nicholas Piggin <npiggin@gmail.com>
      Cc: Christophe Leroy <christophe.leroy@csgroup.eu>
      Cc: linuxppc-dev@lists.ozlabs.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-12-namhyung@kernel.org
      3483d244
    • Namhyung Kim's avatar
      tools/perf: Update tools's copy of x86 syscall table · b3b11aed
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Ingo Molnar <mingo@redhat.com>
      Cc: Borislav Petkov <bp@alien8.de>
      Cc: Dave Hansen <dave.hansen@linux.intel.com>
      Cc: x86@kernel.org
      Cc: "H. Peter Anvin" <hpa@zytor.com>
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-11-namhyung@kernel.org
      b3b11aed
    • Namhyung Kim's avatar
      tools headers: Update tools's copy of s390/asm headers · e1d7426b
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Heiko Carstens <hca@linux.ibm.com>
      Cc: Vasily Gorbik <gor@linux.ibm.com>
      Cc: Alexander Gordeev <agordeev@linux.ibm.com>
      Cc: Christian Borntraeger <borntraeger@linux.ibm.com>
      Cc: Sven Schnelle <svens@linux.ibm.com>
      Cc: linux-s390@vger.kernel.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-10-namhyung@kernel.org
      e1d7426b
    • Namhyung Kim's avatar
      tools headers: Update tools's copy of arm64/asm headers · fad8afdc
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Catalin Marinas <catalin.marinas@arm.com>
      Cc: Will Deacon <will@kernel.org>
      Cc: linux-arm-kernel@lists.infradead.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-9-namhyung@kernel.org
      fad8afdc
    • Namhyung Kim's avatar
      tools headers: Update tools's copy of x86/asm headers · c23708f3
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Ingo Molnar <mingo@redhat.com>
      Cc: Borislav Petkov <bp@alien8.de>
      Cc: Dave Hansen <dave.hansen@linux.intel.com>
      Cc: x86@kernel.org
      Cc: "H. Peter Anvin" <hpa@zytor.com>
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-8-namhyung@kernel.org
      c23708f3
    • Namhyung Kim's avatar
      tools headers: Update tools's copy of socket.h header · fd2ddee7
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: netdev@vger.kernel.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-7-namhyung@kernel.org
      fd2ddee7
    • Namhyung Kim's avatar
      tools headers UAPI: Update tools's copy of unistd.h header · 91c97b36
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Arnd Bergmann <arnd@arndb.de>
      Cc: linux-arch@vger.kernel.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-6-namhyung@kernel.org
      91c97b36
    • Namhyung Kim's avatar
      tools headers UAPI: Update tools's copy of vhost.h header · daa97513
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: "Michael S. Tsirkin" <mst@redhat.com>
      Cc: Jason Wang <jasowang@redhat.com>
      Cc: kvm@vger.kernel.org
      Cc: virtualization@lists.linux.dev
      Cc: netdev@vger.kernel.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-5-namhyung@kernel.org
      daa97513
    • Namhyung Kim's avatar
      tools headers UAPI: Update tools's copy of mount.h header · fb3648a6
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Alexander Viro <viro@zeniv.linux.org.uk>
      Cc: Christian Brauner <brauner@kernel.org>
      Cc: linux-fsdevel@vger.kernel.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-4-namhyung@kernel.org
      fb3648a6
    • Namhyung Kim's avatar
      tools headers UAPI: Update tools's copy of kvm.h header · 5a9f95b6
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Paolo Bonzini <pbonzini@redhat.com>
      Cc: kvm@vger.kernel.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-3-namhyung@kernel.org
      5a9f95b6
    • Namhyung Kim's avatar
      tools headers UAPI: Update tools's copy of fscrypt.h header · 11184466
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: Eric Biggers <ebiggers@kernel.org>
      Cc: "Theodore Y. Ts'o" <tytso@mit.edu>
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: linux-fscrypt@vger.kernel.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-2-namhyung@kernel.org
      11184466
    • Namhyung Kim's avatar
      tools headers UAPI: Update tools's copy of drm headers · 1041dfe6
      Namhyung Kim authored
      tldr; Just FYI, I'm carrying this on the perf tools tree.
      
      Full explanation:
      
      There used to be no copies, with tools/ code using kernel headers
      directly. From time to time tools/perf/ broke due to legitimate kernel
      hacking. At some point Linus complained about such direct usage. Then we
      adopted the current model.
      
      The way these headers are used in perf are not restricted to just
      including them to compile something.
      
      There are sometimes used in scripts that convert defines into string
      tables, etc, so some change may break one of these scripts, or new MSRs
      may use some different #define pattern, etc.
      
      E.g.:
      
        $ ls -1 tools/perf/trace/beauty/*.sh | head -5
        tools/perf/trace/beauty/arch_errno_names.sh
        tools/perf/trace/beauty/drm_ioctl.sh
        tools/perf/trace/beauty/fadvise.sh
        tools/perf/trace/beauty/fsconfig.sh
        tools/perf/trace/beauty/fsmount.sh
        $
        $ tools/perf/trace/beauty/fadvise.sh
        static const char *fadvise_advices[] = {
              [0] = "NORMAL",
              [1] = "RANDOM",
              [2] = "SEQUENTIAL",
              [3] = "WILLNEED",
              [4] = "DONTNEED",
              [5] = "NOREUSE",
        };
        $
      
      The tools/perf/check-headers.sh script, part of the tools/ build
      process, points out changes in the original files.
      
      So its important not to touch the copies in tools/ when doing changes in
      the original kernel headers, that will be done later, when
      check-headers.sh inform about the change to the perf tools hackers.
      
      Cc: David Airlie <airlied@gmail.com>
      Cc: Daniel Vetter <daniel@ffwll.ch>
      Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
      Cc: Maxime Ripard <mripard@kernel.org>
      Cc: Thomas Zimmermann <tzimmermann@suse.de>
      Cc: dri-devel@lists.freedesktop.org
      Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
      Link: https://lore.kernel.org/r/20231121225650.390246-1-namhyung@kernel.org
      1041dfe6
  3. 21 Nov, 2023 2 commits
  4. 19 Nov, 2023 8 commits
  5. 18 Nov, 2023 11 commits
    • Linus Torvalds's avatar
      Merge tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi · 037266a5
      Linus Torvalds authored
      Pull SCSI fixes from James Bottomley:
       "Seven small fixes, six in drivers and one in sd.
      
        The sd fix is so large because it changes a struct pointer to a struct
        but otherwise is fairly simple"
      
      * tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi:
        scsi: ufs: qcom-ufs: dt-bindings: Document the SM8650 UFS Controller
        scsi: sd: Fix sshdr use in sd_suspend_common()
        scsi: scsi_debug: Delete some bogus error checking
        scsi: scsi_debug: Fix some bugs in sdebug_error_write()
        scsi: ufs: core: Fix racing issue between ufshcd_mcq_abort() and ISR
        scsi: ufs: core: Expand MCQ queue slot to DeviceQueueDepth + 1
        scsi: qla2xxx: Fix system crash due to bad pointer access
      037266a5
    • Linus Torvalds's avatar
      Merge tag 'parisc-for-6.7-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/parisc-linux · 2254005e
      Linus Torvalds authored
      Pull parisc fixes from Helge Deller:
       "On parisc we still sometimes need writeable stacks, e.g. if programs
        aren't compiled with gcc-14. To avoid issues with the upcoming
        systemd-254 we therefore have to disable prctl(PR_SET_MDWE) for now
        (for parisc only).
      
        The other two patches are minor: a bugfix for the soft power-off on
        qemu with 64-bit kernel and prefer strscpy() over strlcpy():
      
         - Fix power soft-off on qemu
      
         - Disable prctl(PR_SET_MDWE) since parisc sometimes still needs
           writeable stacks
      
         - Use strscpy instead of strlcpy in show_cpuinfo()"
      
      * tag 'parisc-for-6.7-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/parisc-linux:
        prctl: Disable prctl(PR_SET_MDWE) on parisc
        parisc/power: Fix power soft-off when running on qemu
        parisc: Replace strlcpy() with strscpy()
      2254005e
    • Linus Torvalds's avatar
      Merge tag 'xfs-6.7-fixes-1' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux · b8f1fa24
      Linus Torvalds authored
      Pull xfs fixes from Chandan Babu:
      
       - Fix deadlock arising due to intent items in AIL not being cleared
         when log recovery fails
      
       - Fix stale data exposure bug when remapping COW fork extents to data
         fork
      
       - Fix deadlock when data device flush fails
      
       - Fix AGFL minimum size calculation
      
       - Select DEBUG_FS instead of XFS_DEBUG when XFS_ONLINE_SCRUB_STATS is
         selected
      
       - Fix corruption of log inode's extent count field when NREXT64 feature
         is enabled
      
      * tag 'xfs-6.7-fixes-1' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux:
        xfs: recovery should not clear di_flushiter unconditionally
        xfs: inode recovery does not validate the recovered inode
        xfs: fix again select in kconfig XFS_ONLINE_SCRUB_STATS
        xfs: fix internal error from AGFL exhaustion
        xfs: up(ic_sema) if flushing data device fails
        xfs: only remap the written blocks in xfs_reflink_end_cow_extent
        XFS: Update MAINTAINERS to catch all XFS documentation
        xfs: abort intent items when recovery intents fail
        xfs: factor out xfs_defer_pending_abort
      b8f1fa24
    • Linus Torvalds's avatar
      Merge tag 'nfsd-6.7-1' of git://git.kernel.org/pub/scm/linux/kernel/git/cel/linux · bb28378a
      Linus Torvalds authored
      Pull nfsd fixes from Chuck Lever:
      
       - Fix several long-standing bugs in the duplicate reply cache
      
       - Fix a memory leak
      
      * tag 'nfsd-6.7-1' of git://git.kernel.org/pub/scm/linux/kernel/git/cel/linux:
        NFSD: Fix checksum mismatches in the duplicate reply cache
        NFSD: Fix "start of NFS reply" pointer passed to nfsd_cache_update()
        NFSD: Update nfsd_cache_append() to use xdr_stream
        nfsd: fix file memleak on client_opens_release
      bb28378a
    • Linus Torvalds's avatar
      Merge tag '6.7-rc1-smb3-client-fixes' of git://git.samba.org/sfrench/cifs-2.6 · 33b63f15
      Linus Torvalds authored
      Pull smb client fixes from Steve French:
      
       - multichannel fixes (including a lock ordering fix and an important
         refcounting fix)
      
       - spnego fix
      
      * tag '6.7-rc1-smb3-client-fixes' of git://git.samba.org/sfrench/cifs-2.6:
        cifs: fix lock ordering while disabling multichannel
        cifs: fix leak of iface for primary channel
        cifs: fix check of rc in function generate_smb3signingkey
        cifs: spnego: add ';' in HOST_KEY_LEN
      33b63f15
    • Helge Deller's avatar
      prctl: Disable prctl(PR_SET_MDWE) on parisc · 79383813
      Helge Deller authored
      systemd-254 tries to use prctl(PR_SET_MDWE) for it's MemoryDenyWriteExecute
      functionality, but fails on parisc which still needs executable stacks in
      certain combinations of gcc/glibc/kernel.
      
      Disable prctl(PR_SET_MDWE) by returning -EINVAL for now on parisc, until
      userspace has catched up.
      Signed-off-by: default avatarHelge Deller <deller@gmx.de>
      Co-developed-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      Reported-by: default avatarSam James <sam@gentoo.org>
      Closes: https://github.com/systemd/systemd/issues/29775Tested-by: default avatarSam James <sam@gentoo.org>
      Link: https://lore.kernel.org/all/875y2jro9a.fsf@gentoo.org/
      Cc: <stable@vger.kernel.org> # v6.3+
      79383813
    • Linus Torvalds's avatar
      Merge tag 'for-6.7/dm-fixes' of... · 05aa69b0
      Linus Torvalds authored
      Merge tag 'for-6.7/dm-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm
      
      Pull device mapper fixes from Mike Snitzer:
      
       - Various fixes for the DM delay target to address regressions
         introduced during the 6.7 merge window
      
       - Fixes to both DM bufio and the verity target for no-sleep mode,
         to address sleeping while atomic issues
      
       - Update DM crypt target in response to the treewide change that
         made MAX_ORDER inclusive
      
      * tag 'for-6.7/dm-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm:
        dm-crypt: start allocating with MAX_ORDER
        dm-verity: don't use blocking calls from tasklets
        dm-bufio: fix no-sleep mode
        dm-delay: avoid duplicate logic
        dm-delay: fix bugs introduced by kthread mode
        dm-delay: fix a race between delay_presuspend and delay_bio
      05aa69b0
    • Helge Deller's avatar
      parisc/power: Fix power soft-off when running on qemu · 6ad6e15a
      Helge Deller authored
      Firmware returns the physical address of the power switch,
      so need to use gsc_writel() instead of direct memory access.
      
      Fixes: d0c21947 ("parisc/power: Add power soft-off when running on qemu")
      Signed-off-by: default avatarHelge Deller <deller@gmx.de>
      Cc: stable@vger.kernel.org # v6.0+
      6ad6e15a
    • Kees Cook's avatar
      parisc: Replace strlcpy() with strscpy() · 721d28f3
      Kees Cook 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].
      Additionally, it returns the size of the source string, not the
      resulting size of the destination string. In an effort to remove strlcpy()
      completely[2], replace strlcpy() here with strscpy().
      
      Link: https://www.kernel.org/doc/html/latest/process/deprecated.html#strlcpy [1]
      Link: https://github.com/KSPP/linux/issues/89 [2]
      Cc: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com>
      Cc: Helge Deller <deller@gmx.de>
      Cc: Azeem Shaikh <azeemshaikh38@gmail.com>
      Cc: linux-parisc@vger.kernel.org
      Signed-off-by: default avatarKees Cook <keescook@chromium.org>
      Signed-off-by: default avatarHelge Deller <deller@gmx.de>
      721d28f3
    • Linus Torvalds's avatar
      Merge tag 'i2c-for-6.7-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux · 23dfa043
      Linus Torvalds authored
      Pull i2c fixes from Wolfram Sang:
       "Revert a not-working conversion to generic recovery for PXA,
        use proper IO accessors for designware, and use proper PM level
        for ocores to allow accessing interrupt providers late"
      
      * tag 'i2c-for-6.7-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux:
        i2c: ocores: Move system PM hooks to the NOIRQ phase
        i2c: designware: Fix corrupted memory seen in the ISR
        Revert "i2c: pxa: move to generic GPIO recovery"
      23dfa043
    • Linus Torvalds's avatar
      Merge tag 'turbostat-2023.11.07' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux · 9ea991a5
      Linus Torvalds authored
      Pull turbostat updates from Len Brown:
      
       - Turbostat features are now table-driven (Rui Zhang)
      
       - Add support for some new platforms (Sumeet Pawnikar, Rui Zhang)
      
       - Gracefully run in configs when CPUs are limited (Rui Zhang, Srinivas
         Pandruvada)
      
       - misc minor fixes
      
      [ This came in during the merge window, but sorting out the signed tag
        took a while, so thus the late merge   - Linus ]
      
      * tag 'turbostat-2023.11.07' of git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux: (86 commits)
        tools/power turbostat: version 2023.11.07
        tools/power/turbostat: bugfix "--show IPC"
        tools/power/turbostat: Add initial support for LunarLake
        tools/power/turbostat: Add initial support for ArrowLake
        tools/power/turbostat: Add initial support for GrandRidge
        tools/power/turbostat: Add initial support for SierraForest
        tools/power/turbostat: Add initial support for GraniteRapids
        tools/power/turbostat: Add MSR_CORE_C1_RES support for spr_features
        tools/power/turbostat: Move process to root cgroup
        tools/power/turbostat: Handle cgroup v2 cpu limitation
        tools/power/turbostat: Abstrct function for parsing cpu string
        tools/power/turbostat: Handle offlined CPUs in cpu_subset
        tools/power/turbostat: Obey allowed CPUs for system summary
        tools/power/turbostat: Obey allowed CPUs for primary thread/core detection
        tools/power/turbostat: Abstract several functions
        tools/power/turbostat: Obey allowed CPUs during startup
        tools/power/turbostat: Obey allowed CPUs when accessing CPU counters
        tools/power/turbostat: Introduce cpu_allowed_set
        tools/power/turbostat: Remove PC7/PC9 support on ADL/RPL
        tools/power/turbostat: Enable MSR_CORE_C1_RES on recent Intel client platforms
        ...
      9ea991a5
  6. 17 Nov, 2023 1 commit
    • Linus Torvalds's avatar
      Merge tag 'bcachefs-2023-11-17' of https://evilpiepirate.org/git/bcachefs · 791c8ab0
      Linus Torvalds authored
      Pull bcachefs fixes from Kent Overstreet:
       "Lots of small fixes for minor nits and compiler warnings.
      
        Bigger items:
      
         - The six locks lost wakeup is finally fixed: six_read_trylock() was
           checking for the waiting bit before decrementing the number of
           readers - validated the fix with a torture test.
      
         - Fix for a memory reclaim issue: when needing to reallocate a key
           cache key, we now do our usual GFP_NOWAIT; unlock(); GFP_KERNEL
           dance.
      
         - Multiple deleted inodes btree fixes
      
         - Fix an issue in fsck, where i_nlink would be recalculated
           incorrectly for hardlinked files if a snapshot had ever been taken.
      
         - Kill journal pre-reservations: This is a bigger patch than I would
           normally send at this point, but it deletes code and it fixes some
           of our tests that would sporadically die with the journal getting
           stuck, and it's a performance improvement, too"
      
      * tag 'bcachefs-2023-11-17' of https://evilpiepirate.org/git/bcachefs: (22 commits)
        bcachefs: Fix missing locking for dentry->d_parent access
        bcachefs: six locks: Fix lost wakeup
        bcachefs: Fix no_data_io mode checksum check
        bcachefs: Fix bch2_check_nlinks() for snapshots
        bcachefs: Don't decrease BTREE_ITER_MAX when LOCKDEP=y
        bcachefs: Disable debug log statements
        bcachefs: Fix missing transaction commit
        bcachefs: Fix error path in bch2_mount()
        bcachefs: Fix potential sleeping during mount
        bcachefs: Fix iterator leak in may_delete_deleted_inode()
        bcachefs: Kill journal pre-reservations
        bcachefs: Check for nonce offset inconsistency in data_update path
        bcachefs: Make sure to drop/retake btree locks before reclaim
        bcachefs: btree_trans->write_locked
        bcachefs: Run btree key cache shrinker less aggressively
        bcachefs: Split out btree_key_cache_types.h
        bcachefs: Guard against insufficient devices to create stripes
        bcachefs: Fix null ptr deref in bch2_backpointer_get_node()
        bcachefs: Fix multiple -Warray-bounds warnings
        bcachefs: Use DECLARE_FLEX_ARRAY() helper and fix multiple -Warray-bounds warnings
        ...
      791c8ab0