lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20240311105146.20399-B-hca@linux.ibm.com>
Date: Mon, 11 Mar 2024 11:51:46 +0100
From: Heiko Carstens <hca@...ux.ibm.com>
To: Linus Torvalds <torvalds@...ux-foundation.org>
Cc: Vasily Gorbik <gor@...ux.ibm.com>,
        Alexander Gordeev <agordeev@...ux.ibm.com>, linux-s390@...r.kernel.org,
        linux-kernel@...r.kernel.org
Subject: [GIT PULL] s390 updates for 6.9 merge window

Hi Linus,

please pull s390 updates for the 6.9 merge window.

Thanks,
Heiko

The following changes since commit 124468af7e769a52d27c3290007ac6e2ba346ccd:

  s390/configs: update default configurations (2024-02-09 13:57:29 +0100)

are available in the Git repository at:

  git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux.git tags/s390-6.9-1

for you to fetch changes up to fa9e3139e6c5ac756e1ab2a6c7eca99eb684a2fe:

  s390/tools: handle rela R_390_GOTPCDBL/R_390_GOTOFF64 (2024-03-07 17:02:05 +0100)

----------------------------------------------------------------
s390 updates for 6.9 merge window

- Various virtual vs physical address usage fixes

- Fix error handling in Processor Activity Instrumentation device driver, and
  export number of counters with a sysfs file

- Allow for multiple events when Processor Activity Instrumentation counters
  are monitored in system wide sampling

- Change multiplier and shift values of the Time-of-Day clock source to improve
  steering precision

- Remove a couple of unneeded GFP_DMA flags from allocations

- Disable mmap alignment if randomize_va_space is also disabled, to avoid a too
  small heap

- Various changes to allow s390 to be compiled with LLVM=1, since ld.lld and
  llvm-objcopy will have proper s390 support witch clang 19

- Add __uninitialized macro to Compiler Attributes. This is helpful with s390's
  FPU code where some users have up to 520 byte stack frames. Clearing such
  stack frames (if INIT_STACK_ALL_PATTERN or INIT_STACK_ALL_ZERO is enabled)
  before they are used contradicts the intention (performance improvement) of
  such code sections.

- Convert switch_to() to an out-of-line function, and use the generic switch_to
  header file

- Replace the usage of s390's debug feature with pr_debug() calls within the
  zcrypt device driver

- Improve hotplug support of the Adjunct Processor device driver

- Improve retry handling in the zcrypt device driver

- Various changes to the in-kernel FPU code:

  - Make in-kernel FPU sections preemptible

  - Convert various larger inline assemblies and assembler files to C, mainly
    by using singe instruction inline assemblies. This increases readability,
    but also allows makes it easier to add proper instrumentation hooks

  - Cleanup of the header files

- Provide fast variants of csum_partial() and csum_partial_copy_nocheck() based
  on vector instructions

- Introduce and use a lock to synchronize accesses to zpci device data
  structures to avoid inconsistent states caused by concurrent accesses

- Compile the kernel without -fPIE. This addresses the following problems if
  the kernel is compiled with -fPIE:

  - It uses dynamic symbols (.dynsym), for which the linker refuses to allow
    more than 64k sections. This can break features which use
    '-ffunction-sections' and '-fdata-sections', including kpatch-build and
    function granular KASLR

  - It unnecessarily uses GOT relocations, adding an extra layer of indirection
    for many memory accesses

- Fix shared_cpu_list for CPU private L2 caches, which incorrectly were
  reported as globally shared

----------------------------------------------------------------
Alexander Gordeev (7):
      s390/diag: fix diag26c() physical vs virtual address confusion
      s390/extmem: fix virtual vs physical address confusion
      s390/boot: simplify GOT handling
      s390/boot: sanitize kaslr_adjust_relocs() function prototype
      s390/boot: make type of __vmlinux_relocs_64_start|end consistent
      s390/boot: do not check for zero-termination relocation entry
      s390/boot: fix minor comment style damages

Eric Farman (2):
      KVM: s390: fix access register usage in ioctls
      KVM: s390: selftests: memop: add a simple AR test

Gerald Schaefer (2):
      s390/appldata: fix virtual vs physical address confusion
      s390/setup: fix virtual vs physical address confusion

Gerd Bayer (4):
      s390/pci: rename lock member in struct zpci_dev
      s390/pci: introduce lock to synchronize state of zpci_dev's
      s390/pci: remove hotplug slot when releasing the device
      s390/pci: fix three typos in comments

Harald Freudenberger (14):
      s390/zcrypt: harmonize debug feature calls and defines
      s390/zcrypt: introduce dynamic debugging for AP and zcrypt code
      s390/pkey: harmonize pkey s390 debug feature calls
      s390/pkey: introduce dynamic debugging for pkey
      s390/ap: add debug possibility for AP messages
      s390/zcrypt: add debug possibility for CCA and EP11 messages
      s390/ap: rearm APQNs bindings complete completion
      s390/ap: clarify AP scan bus related functions and variables
      s390/ap: rework ap_scan_bus() to return true on config change
      s390/ap: introduce mutex to lock the AP bus scan
      s390/zcrypt: introduce retries on in-kernel send CPRB functions
      s390/zcrypt: improve zcrypt retry behavior
      s390/pkey: improve pkey retry behavior
      s390/crypto: remove retry loop with sleep from PAES pkey invocation

Heiko Carstens (46):
      s390/hypfs_sprp: fix virtual vs physical address confusion
      s390/hypfs_diag0c: fix virtual vs physical address confusion
      s390/hypfs_sprp: remove unneeded DMA zone allocation
      s390/cmf: remove unneeded DMA zone allocation
      s390/cmf: fix virtual vs physical address confusion
      Compiler Attributes: Add __uninitialized macro
      s390/fpu: make use of __uninitialized macro
      s390/acrs: cleanup access register handling
      s390/switch_to: use generic header file
      s390/bug: remove entry size from __bug_table section
      s390/vdso: remove unused ENTRY in linker scripts
      s390/fpu: fix VLGV macro
      s390/fpu: improve description of RXB macro
      s390/nmi: remove register validation code
      s390/fpu: use KERNEL_VXR_LOW instead of KERNEL_VXR_V0V7
      s390/fpu: various coding style changes
      s390/fpu: move, rename, and merge header files
      s390/fpu: add documentation about fpu helper functions
      s390/fpu: use lfpc instead of sfpc instruction
      s390/fpu: provide and use ld and std inline assemblies
      s390/fpu: provide and use lfpc, sfpc, and stfpc inline assemblies
      s390/fpu: provide and use vlm and vstm inline assemblies
      s390/fpu: convert __kernel_fpu_begin()/__kernel_fpu_end() to C
      s390/fpu: convert FPU CIF flag to regular TIF flag
      s390/fpu: rename save_fpu_regs() to save_user_fpu_regs(), etc
      s390/fpu: change type of fpu mask from u32 to int
      s390/fpu: make kernel fpu context preemptible
      s390/kvm: convert to regular kernel fpu user
      s390/fpu: remove regs member from struct fpu
      s390/fpu: remove anonymous union from struct fpu
      s390/fpu: let fpu_vlm() and fpu_vstm() return number of registers
      s390/fpu: decrease stack usage for some cases
      s390/fpu: limit save and restore to used registers
      s390/fpu: remove TIF_FPU
      s390/checksum: call instrument_read() instead of kasan_check_read()
      s390/checksum: provide and use cksm() inline assembly
      s390/checksum: provide vector register variant of csum_partial()
      s390/checksum: provide csum_partial_copy_nocheck()
      s390/raid6: convert to use standard fpu_*() inline assemblies
      s390/sysinfo: convert bogomips calculation to C
      s390/fpu: add vector instruction inline assemblies for crc32
      s390/crc32be: convert to C
      s390/crc32le: convert to C
      s390: vmlinux.lds.S: fix .got.plt assertion
      s390/configs: increase number of LOCKDEP_BITS
      s390/cache: prevent rebuild of shared_cpu_list

Holger Dengler (1):
      s390/ap: explicitly include ultravisor header

Janosch Frank (1):
      KVM: s390: introduce kvm_s390_fpu_(store|load)

Jason J. Herne (1):
      s390/vfio-ap: handle hardware checkstop state on queue reset operation

Josh Poimboeuf (2):
      s390: add relocs tool
      s390: compile relocatable kernel without -fPIE

Nathan Chancellor (15):
      s390/vdso: drop '-fPIC' from LDFLAGS
      s390/boot: add support for CONFIG_LD_ORPHAN_WARN
      s390: vmlinux.lds.S: handle '.data.rel' sections explicitly
      s390: vmlinux.lds.S: explicitly handle '.got' and '.plt' sections
      s390: vmlinux.lds.S: explicitly keep various sections
      s390/boot: vmlinux.lds.S: handle '.init.text'
      s390/boot: vmlinux.lds.S: handle '.rela' sections
      s390/boot: vmlinux.lds.S: handle DWARF debug sections
      s390/boot: vmlinux.lds.S: handle ELF required sections
      s390/boot: vmlinux.lds.S: handle commonly discarded sections
      s390: select CONFIG_ARCH_WANT_LD_ORPHAN_WARN
      s390: link vmlinux with '-z notext'
      s390: don't allow CONFIG_COMPAT with LD=ld.lld
      s390/boot: add 'alloc' to info.bin .vmlinux.info section flags
      s390/boot: workaround current 'llvm-objdump -t -j ...' behavior

Peter Oberparleiter (1):
      s390/cio: remove unneeded DMA zone allocation

Ricardo B. Marliere (7):
      s390/time: make stp_subsys const
      s390/ccwgroup: make ccwgroup_bus_type const
      s390/cio: make css_bus_type const
      s390/cio: make ccw_bus_type const
      s390/cio: make scm_bus_type const
      s390/ap: make ap_bus_type const
      s390/vfio-ap: make matrix_bus const

Sumanth Korikkar (2):
      s390/vdso64: filter out munaligned-symbols flag for vdso
      s390/tools: handle rela R_390_GOTPCDBL/R_390_GOTOFF64

Sven Schnelle (2):
      s390/time: improve steering precision
      s390/mmap: disable mmap alignment when randomize_va_space = 0

Thomas Richter (10):
      s390/pai: fix attr_event_free upper limit for pai device drivers
      s390/pai_crypto: emit error on too many counters
      s390/pai: export number of sysfs attribute files
      s390/pai_crypto: return proper error code in paicrypt_init
      s390/vmur: fix virtual vs physical address confusion
      s390/diag: add missing virt_to_phys() translation to diag14()
      s390/pai: save PAI counter value page in event structure
      s390/pai: simplify event start function for perf stat
      s390/pai: adjust whitespace indentation
      s390/pai: change sampling event assignment for PMU device driver

 arch/s390/Kconfig                                  |  18 +-
 arch/s390/Makefile                                 |  10 +-
 arch/s390/boot/.gitignore                          |   1 +
 arch/s390/boot/Makefile                            |  25 +-
 arch/s390/boot/boot.h                              |   6 +
 arch/s390/boot/startup.c                           |  75 +++-
 arch/s390/boot/vmlinux.lds.S                       |  48 ++
 arch/s390/configs/debug_defconfig                  |   2 +
 arch/s390/crypto/chacha-glue.c                     |   4 +-
 arch/s390/crypto/chacha-s390.S                     |   2 +-
 arch/s390/crypto/crc32-vx.c                        |  11 +-
 arch/s390/crypto/crc32-vx.h                        |  12 +
 arch/s390/crypto/{crc32be-vx.S => crc32be-vx.c}    | 171 +++-----
 arch/s390/crypto/{crc32le-vx.S => crc32le-vx.c}    | 239 +++++-----
 arch/s390/crypto/paes_s390.c                       |  16 +-
 arch/s390/hypfs/hypfs_diag0c.c                     |   3 +-
 arch/s390/hypfs/hypfs_sprp.c                       |   4 +-
 arch/s390/include/asm/access-regs.h                |  38 ++
 arch/s390/include/asm/appldata.h                   |   4 +-
 arch/s390/include/asm/asm-prototypes.h             |   2 +-
 arch/s390/include/asm/bug.h                        |   4 +-
 arch/s390/include/asm/checksum.h                   |  29 +-
 arch/s390/include/asm/diag.h                       |  15 +-
 arch/s390/include/asm/entry-common.h               |   5 +-
 .../include/asm/{vx-insn-asm.h => fpu-insn-asm.h}  |  71 ++-
 arch/s390/include/asm/fpu-insn.h                   | 486 +++++++++++++++++++++
 arch/s390/include/asm/fpu-types.h                  |  51 +++
 arch/s390/include/asm/fpu.h                        | 295 +++++++++++++
 arch/s390/include/asm/fpu/api.h                    | 126 ------
 arch/s390/include/asm/fpu/internal.h               |  67 ---
 arch/s390/include/asm/fpu/types.h                  |  38 --
 arch/s390/include/asm/kvm_host.h                   |   5 +-
 arch/s390/include/asm/lowcore.h                    |   2 +-
 arch/s390/include/asm/pai.h                        |   3 +-
 arch/s390/include/asm/pci.h                        |   3 +-
 arch/s390/include/asm/physmem_info.h               |   1 +
 arch/s390/include/asm/processor.h                  |  11 +-
 arch/s390/include/asm/ptrace.h                     |   4 +
 arch/s390/include/asm/stacktrace.h                 |   1 -
 arch/s390/include/asm/switch_to.h                  |  49 ---
 arch/s390/include/asm/vx-insn.h                    |  19 -
 arch/s390/kernel/cache.c                           |   1 +
 arch/s390/kernel/compat_signal.c                   |  22 +-
 arch/s390/kernel/crash_dump.c                      |   2 +-
 arch/s390/kernel/diag.c                            |  31 +-
 arch/s390/kernel/early.c                           |   3 +-
 arch/s390/kernel/entry.S                           |  19 +-
 arch/s390/kernel/entry.h                           |   1 +
 arch/s390/kernel/fpu.c                             | 380 +++++++---------
 arch/s390/kernel/ipl.c                             |   3 +-
 arch/s390/kernel/machine_kexec.c                   |   3 +-
 arch/s390/kernel/nmi.c                             | 168 ++-----
 arch/s390/kernel/os_info.c                         |   6 +-
 arch/s390/kernel/perf_pai_crypto.c                 |  83 ++--
 arch/s390/kernel/perf_pai_ext.c                    |  52 ++-
 arch/s390/kernel/perf_regs.c                       |  10 +-
 arch/s390/kernel/process.c                         |  31 +-
 arch/s390/kernel/ptrace.c                          | 101 ++---
 arch/s390/kernel/setup.c                           |  12 +-
 arch/s390/kernel/signal.c                          |  20 +-
 arch/s390/kernel/smp.c                             |   3 +-
 arch/s390/kernel/sysinfo.c                         |  27 +-
 arch/s390/kernel/text_amode31.S                    |   2 +-
 arch/s390/kernel/time.c                            |   6 +-
 arch/s390/kernel/traps.c                           |  12 +-
 arch/s390/kernel/uprobes.c                         |   1 -
 arch/s390/kernel/vdso32/Makefile                   |   2 +-
 arch/s390/kernel/vdso32/vdso32.lds.S               |   1 -
 arch/s390/kernel/vdso64/Makefile                   |   3 +-
 arch/s390/kernel/vdso64/vdso64.lds.S               |   1 -
 arch/s390/kernel/vmlinux.lds.S                     |  54 +++
 arch/s390/kvm/gaccess.c                            |   5 +-
 arch/s390/kvm/interrupt.c                          |   6 +-
 arch/s390/kvm/kvm-s390.c                           |  33 +-
 arch/s390/kvm/kvm-s390.h                           |  18 +
 arch/s390/kvm/vsie.c                               |   3 -
 arch/s390/lib/Makefile                             |   1 +
 arch/s390/lib/csum-partial.c                       |  91 ++++
 arch/s390/mm/extmem.c                              |   4 +-
 arch/s390/mm/mmap.c                                |  19 +-
 arch/s390/pci/pci.c                                |  20 +-
 arch/s390/pci/pci_debug.c                          |  10 +-
 arch/s390/pci/pci_event.c                          |  15 +-
 arch/s390/pci/pci_sysfs.c                          |  70 +--
 arch/s390/tools/.gitignore                         |   1 +
 arch/s390/tools/Makefile                           |   5 +
 arch/s390/tools/relocs.c                           | 387 ++++++++++++++++
 drivers/pci/hotplug/s390_pci_hpc.c                 |  65 ++-
 drivers/s390/char/vmur.c                           |   4 +-
 drivers/s390/char/zcore.c                          |   1 -
 drivers/s390/cio/ccwgroup.c                        |   4 +-
 drivers/s390/cio/chsc.c                            |   4 +-
 drivers/s390/cio/chsc_sch.c                        |  20 +-
 drivers/s390/cio/cmf.c                             |   6 +-
 drivers/s390/cio/css.c                             |   4 +-
 drivers/s390/cio/device.c                          |   4 +-
 drivers/s390/cio/scm.c                             |   4 +-
 drivers/s390/crypto/ap_bus.c                       | 259 ++++++++---
 drivers/s390/crypto/ap_bus.h                       |   8 +-
 drivers/s390/crypto/ap_debug.h                     |   4 +-
 drivers/s390/crypto/ap_queue.c                     |  31 +-
 drivers/s390/crypto/pkey_api.c                     | 226 +++++-----
 drivers/s390/crypto/vfio_ap_drv.c                  |   2 +-
 drivers/s390/crypto/vfio_ap_ops.c                  |  35 +-
 drivers/s390/crypto/zcrypt_api.c                   | 226 +++++-----
 drivers/s390/crypto/zcrypt_api.h                   |   9 +
 drivers/s390/crypto/zcrypt_ccamisc.c               | 214 ++++-----
 drivers/s390/crypto/zcrypt_debug.h                 |   4 +-
 drivers/s390/crypto/zcrypt_ep11misc.c              | 127 +++---
 drivers/s390/crypto/zcrypt_error.h                 |   5 +-
 drivers/s390/crypto/zcrypt_msgtype50.c             |  14 +-
 drivers/s390/crypto/zcrypt_msgtype6.c              |  45 +-
 include/linux/compiler_attributes.h                |  12 +
 lib/raid6/s390vx.uc                                |  62 +--
 tools/testing/selftests/kvm/s390x/memop.c          |  31 ++
 115 files changed, 3242 insertions(+), 1912 deletions(-)
 create mode 100644 arch/s390/crypto/crc32-vx.h
 rename arch/s390/crypto/{crc32be-vx.S => crc32be-vx.c} (56%)
 rename arch/s390/crypto/{crc32le-vx.S => crc32le-vx.c} (52%)
 create mode 100644 arch/s390/include/asm/access-regs.h
 rename arch/s390/include/asm/{vx-insn-asm.h => fpu-insn-asm.h} (86%)
 create mode 100644 arch/s390/include/asm/fpu-insn.h
 create mode 100644 arch/s390/include/asm/fpu-types.h
 create mode 100644 arch/s390/include/asm/fpu.h
 delete mode 100644 arch/s390/include/asm/fpu/api.h
 delete mode 100644 arch/s390/include/asm/fpu/internal.h
 delete mode 100644 arch/s390/include/asm/fpu/types.h
 delete mode 100644 arch/s390/include/asm/switch_to.h
 delete mode 100644 arch/s390/include/asm/vx-insn.h
 create mode 100644 arch/s390/lib/csum-partial.c
 create mode 100644 arch/s390/tools/relocs.c

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ