# git rev-parse -q --verify 683b783c2093e0172738f899ba188bc406b0595f^{commit} 683b783c2093e0172738f899ba188bc406b0595f already have revision, skipping fetch # git checkout -q -f -B kisskb 683b783c2093e0172738f899ba188bc406b0595f # git clean -qxdf # < git log -1 # commit 683b783c2093e0172738f899ba188bc406b0595f # Merge: 4b6f7c624e70 9895ceeb5cd6 # Author: Linus Torvalds # Date: Fri Feb 16 10:48:14 2024 -0800 # # Merge tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm # # Pull KVM fixes from Paolo Bonzini: # "ARM: # # - Avoid dropping the page refcount twice when freeing an unlinked # page-table subtree. # # - Don't source the VFIO Kconfig twice # # - Fix protected-mode locking order between kvm and vcpus # # RISC-V: # # - Fix steal-time related sparse warnings # # x86: # # - Cleanup gtod_is_based_on_tsc() to return "bool" instead of an "int" # # - Make a KVM_REQ_NMI request while handling KVM_SET_VCPU_EVENTS if # and only if the incoming events->nmi.pending is non-zero. If the # target vCPU is in the UNITIALIZED state, the spurious request will # result in KVM exiting to userspace, which in turn causes QEMU to # constantly acquire and release QEMU's global mutex, to the point # where the BSP is unable to make forward progress. # # - Fix a type (u8 versus u64) goof that results in pmu->fixed_ctr_ctrl # being incorrectly truncated, and ultimately causes KVM to think a # fixed counter has already been disabled (KVM thinks the old value # is '0'). # # - Fix a stack leak in KVM_GET_MSRS where a failed MSR read from # userspace that is ultimately ignored due to ignore_msrs=true # doesn't zero the output as intended. # # Selftests cleanups and fixes: # # - Remove redundant newlines from error messages. # # - Delete an unused variable in the AMX test (which causes build # failures when compiling with -Werror). # # - Fail instead of skipping tests if open(), e.g. of /dev/kvm, fails # with an error code other than ENOENT (a Hyper-V selftest bug # resulted in an EMFILE, and the test eventually got skipped). # # - Fix TSC related bugs in several Hyper-V selftests. # # - Fix a bug in the dirty ring logging test where a sem_post() could # be left pending across multiple runs, resulting in incorrect # synchronization between the main thread and the vCPU worker thread. # # - Relax the dirty log split test's assertions on 4KiB mappings to fix # false positives due to the number of mappings for memslot 0 (used # for code and data that is NOT being dirty logged) changing, e.g. # due to NUMA balancing" # # * tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm: (25 commits) # KVM: arm64: Fix double-free following kvm_pgtable_stage2_free_unlinked() # RISC-V: KVM: Use correct restricted types # RISC-V: paravirt: Use correct restricted types # RISC-V: paravirt: steal_time should be static # KVM: selftests: Don't assert on exact number of 4KiB in dirty log split test # KVM: selftests: Fix a semaphore imbalance in the dirty ring logging test # KVM: x86: Fix KVM_GET_MSRS stack info leak # KVM: arm64: Do not source virt/lib/Kconfig twice # KVM: x86/pmu: Fix type length error when reading pmu->fixed_ctr_ctrl # KVM: x86: Make gtod_is_based_on_tsc() return 'bool' # KVM: selftests: Make hyperv_clock require TSC based system clocksource # KVM: selftests: Run clocksource dependent tests with hyperv_clocksource_tsc_page too # KVM: selftests: Use generic sys_clocksource_is_tsc() in vmx_nested_tsc_scaling_test # KVM: selftests: Generalize check_clocksource() from kvm_clock_test # KVM: x86: make KVM_REQ_NMI request iff NMI pending for vcpu # KVM: arm64: Fix circular locking dependency # KVM: selftests: Fail tests when open() fails with !ENOENT # KVM: selftests: Avoid infinite loop in hyperv_features when invtsc is missing # KVM: selftests: Delete superfluous, unused "stage" variable in AMX test # KVM: selftests: x86_64: Remove redundant newlines # ... # < /opt/cross/kisskb/korg/gcc-8.5.0-nolibc/mips-linux/bin/mips-linux-gcc --version # < /opt/cross/kisskb/korg/gcc-8.5.0-nolibc/mips-linux/bin/mips-linux-ld --version # < git log --format=%s --max-count=1 683b783c2093e0172738f899ba188bc406b0595f # make -s -j 160 ARCH=mips O=/kisskb/build/linus_ip22_defconfig_mips-gcc8 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-8.5.0-nolibc/mips-linux/bin/mips-linux- ip22_defconfig # < make -s -j 160 ARCH=mips O=/kisskb/build/linus_ip22_defconfig_mips-gcc8 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-8.5.0-nolibc/mips-linux/bin/mips-linux- help # make -s -j 160 ARCH=mips O=/kisskb/build/linus_ip22_defconfig_mips-gcc8 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-8.5.0-nolibc/mips-linux/bin/mips-linux- olddefconfig # make -s -j 160 ARCH=mips O=/kisskb/build/linus_ip22_defconfig_mips-gcc8 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-8.5.0-nolibc/mips-linux/bin/mips-linux- /kisskb/src/arch/mips/sgi-ip22/ip22-berr.c:89:6: warning: no previous prototype for 'ip22_be_interrupt' [-Wmissing-prototypes] void ip22_be_interrupt(int irq) ^~~~~~~~~~~~~~~~~ /kisskb/src/arch/mips/sgi-ip22/ip22-berr.c:113:13: warning: no previous prototype for 'ip22_be_init' [-Wmissing-prototypes] void __init ip22_be_init(void) ^~~~~~~~~~~~ /kisskb/src/arch/mips/sgi-ip22/ip22-gio.c:249:6: warning: no previous prototype for 'ip22_gio_set_64bit' [-Wmissing-prototypes] void ip22_gio_set_64bit(int slotno) ^~~~~~~~~~~~~~~~~~ /kisskb/src/arch/mips/sgi-ip22/ip22-gio.c:398:12: warning: no previous prototype for 'ip22_gio_init' [-Wmissing-prototypes] int __init ip22_gio_init(void) ^~~~~~~~~~~~~ /kisskb/src/arch/mips/sgi-ip22/ip22-time.c:119:18: warning: no previous prototype for 'indy_8254timer_irq' [-Wmissing-prototypes] void __irq_entry indy_8254timer_irq(void) ^~~~~~~~~~~~~~~~~~ /kisskb/src/drivers/scsi/sgiwd93.c:173:6: warning: no previous prototype for 'sgiwd93_reset' [-Wmissing-prototypes] void sgiwd93_reset(unsigned long base) ^~~~~~~~~~~~~ Completed OK # rm -rf /kisskb/build/linus_ip22_defconfig_mips-gcc8 # Build took: 0:01:19.451938