04 Aug, 2020

7 commits

  • Instead of waiting in a loop for the userfaultfd condition to become
    true, just wait once and return VM_FAULT_RETRY.

    We've already dropped the mmap lock, we know we can't really
    successfully handle the fault at this point and the caller will have to
    retry anyway. So there's no point in making the wait any more
    complicated than it needs to be - just schedule away.

    And once you don't have that complexity with explicit looping, you can
    also just lose all the 'userfaultfd_signal_pending()' complexity,
    because once we've set the correct process sleeping state, and don't
    loop, the act of scheduling itself will be checking if there are any
    pending signals before going to sleep.

    We can also drop the VM_FAULT_MAJOR games, since we'll be treating all
    retried faults as major soon anyway (series to regularize and share more
    of fault handling across architectures in a separate series by Peter Xu,
    and in the meantime we won't worry about the possible minor - I'll be
    here all week, try the veal - accounting difference).

    Cc: Andrea Arcangeli
    Cc: Peter Xu
    Signed-off-by: Linus Torvalds

    Linus Torvalds
     
  • Pull file locking fix from Jeff Layton:
    "Just a single, one-line patch to fix an inefficiency in the posix
    locking code that can lead to it doing more wakeups than necessary"

    * tag 'filelock-v5.9-1' of git://git.kernel.org/pub/scm/linux/kernel/git/jlayton/linux:
    locks: add locks_move_blocks in posix_lock_inode

    Linus Torvalds
     
  • Pull crypto updates from Herbert Xu:
    "API:
    - Add support for allocating transforms on a specific NUMA Node
    - Introduce the flag CRYPTO_ALG_ALLOCATES_MEMORY for storage users

    Algorithms:
    - Drop PMULL based ghash on arm64
    - Fixes for building with clang on x86
    - Add sha256 helper that does the digest in one go
    - Add SP800-56A rev 3 validation checks to dh

    Drivers:
    - Permit users to specify NUMA node in hisilicon/zip
    - Add support for i.MX6 in imx-rngc
    - Add sa2ul crypto driver
    - Add BA431 hwrng driver
    - Add Ingenic JZ4780 and X1000 hwrng driver
    - Spread IRQ affinity in inside-secure and marvell/cesa"

    * 'linus' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6: (157 commits)
    crypto: sa2ul - Fix inconsistent IS_ERR and PTR_ERR
    hwrng: core - remove redundant initialization of variable ret
    crypto: x86/curve25519 - Remove unused carry variables
    crypto: ingenic - Add hardware RNG for Ingenic JZ4780 and X1000
    dt-bindings: RNG: Add Ingenic RNG bindings.
    crypto: caam/qi2 - add module alias
    crypto: caam - add more RNG hw error codes
    crypto: caam/jr - remove incorrect reference to caam_jr_register()
    crypto: caam - silence .setkey in case of bad key length
    crypto: caam/qi2 - create ahash shared descriptors only once
    crypto: caam/qi2 - fix error reporting for caam_hash_alloc
    crypto: caam - remove deadcode on 32-bit platforms
    crypto: ccp - use generic power management
    crypto: xts - Replace memcpy() invocation with simple assignment
    crypto: marvell/cesa - irq balance
    crypto: inside-secure - irq balance
    crypto: ecc - SP800-56A rev 3 local public key validation
    crypto: dh - SP800-56A rev 3 local public key validation
    crypto: dh - check validity of Z before export
    lib/mpi: Add mpi_sub_ui()
    ...

    Linus Torvalds
     
  • Pull fsverity update from Eric Biggers:
    "One fix for fs/verity/ to strengthen a memory barrier which might be
    too weak. This mirrors a similar fix in fs/crypto/"

    * tag 'fsverity-for-linus' of git://git.kernel.org/pub/scm/fs/fscrypt/fscrypt:
    fs-verity: use smp_load_acquire() for ->i_verity_info

    Linus Torvalds
     
  • Pull fscrypt updates from Eric Biggers:
    "This release, we add support for inline encryption via the blk-crypto
    framework which was added in 5.8.

    Now when an ext4 or f2fs filesystem is mounted with '-o inlinecrypt',
    the contents of encrypted files will be encrypted/decrypted via
    blk-crypto, instead of directly using the crypto API. This model
    allows taking advantage of the inline encryption hardware that is
    integrated into the UFS or eMMC host controllers on most mobile SoCs.

    Note that this is just an alternate implementation; the ciphertext
    written to disk stays the same.

    (This pull request does *not* include support for direct I/O on
    encrypted files, which blk-crypto makes possible, since that part is
    still being discussed.)

    Besides the above feature update, there are also a few fixes and
    cleanups, e.g. strengthening some memory barriers that may be too
    weak.

    All these patches have been in linux-next with no reported issues.
    I've also tested them with the fscrypt xfstests, as usual. It's also
    been tested that the inline encryption support works with the support
    for Qualcomm and Mediatek inline encryption hardware that will be in
    the scsi pull request for 5.9. Also, several SoC vendors are already
    using a previous, functionally equivalent version of these patches"

    * tag 'fscrypt-for-linus' of git://git.kernel.org/pub/scm/fs/fscrypt/fscrypt:
    fscrypt: don't load ->i_crypt_info before it's known to be valid
    fscrypt: document inline encryption support
    fscrypt: use smp_load_acquire() for ->i_crypt_info
    fscrypt: use smp_load_acquire() for ->s_master_keys
    fscrypt: use smp_load_acquire() for fscrypt_prepared_key
    fscrypt: switch fscrypt_do_sha256() to use the SHA-256 library
    fscrypt: restrict IV_INO_LBLK_* to AES-256-XTS
    fscrypt: rename FS_KEY_DERIVATION_NONCE_SIZE
    fscrypt: add comments that describe the HKDF info strings
    ext4: add inline encryption support
    f2fs: add inline encryption support
    fscrypt: add inline encryption support
    fs: introduce SB_INLINECRYPT

    Linus Torvalds
     
  • Pull btrfs updates from David Sterba:
    "We don't have any big feature updates this time, there are lots of
    small enhacements or fixes. A highlight perhaps is the parallel fsync
    performance improvements, numbers below.

    Regarding the dio/iomap that was reverted last time, the required API
    changes are likely to land in the upcoming cycle, the btrfs part will
    be updated afterwards.

    User visible changes:

    - new mount option rescue= to group all recovery-related mount
    options so we don't have many specific options, currently
    introducing only aliases for existing options, future extensions
    are in development to allow read-only mount with partially damaged
    structures:
    - usebackuproot is an alias for rescue=usebackuproot
    - nologreplay is an alias for rescue=nologreplay

    - start deprecation of mount option inode_cache, removal scheduled to
    v5.11

    - removed deprecated mount options alloc_start and subvolrootid

    - device stats corruption counter gets incremented when a checksum
    mismatch is found

    - qgroup information exported in /sys/fs/btrfs//qgroups/
    using sysfs

    - add link /sys/fs/btrfs//bdi pointing to the associated
    backing dev info

    - FS_INFO ioctl enhancements:
    - add flags to request/describe newly added items
    - new item: numeric checksum type and checksum size
    - new item: generation
    - new item: metadata_uuid

    - seed device: with one new read-write device added, print the new
    device information in /proc/mounts

    - balance: detect cancellation by Ctrl-C in existing cancellation
    points

    Performance improvements:

    - optimized versions of various helpers on little-endian
    architectures, where we don't have to do LE/BE conversion from
    on-disk format

    - tree-log/fsync optimizations leading to lower max latency reported
    by dbench, reduced by about 12%

    - all chunk tree leaves are prefetched at mount time, can improve
    mount time on large (terabyte-sized) filesystems

    - speed up parallel fsync of files with reflinked/deduped extents,
    with jobs 16 to 1024 the throughput gets improved roughly by 50% on
    average and runtime decreased roughly by 30% on average, notable
    outlier is 128 jobs with +121.2% on throughput and -54.6% runtime

    - another speed up of parallel fsync, reduce number of checksum tree
    lookups and contention, the improvements start to show up with 2
    tasks with +20% throughput and -16% runtime up to 64 with +200%
    throughput and -66% runtime

    Core:

    - umount-time qgroup leak checker

    - qgroups
    - add a way to unreserve partial range after failure, avoiding
    some EDQUOT errors
    - improved flushing logic when EDQUOT is hit

    - possible EINTR interruption caused by failed reservations after
    transaction start is better handled and documented

    - transaction abort errors are unified to EROFS in case it's not the
    original reason of abort or we don't have other way to determine
    the reason

    Fixes:

    - make truncate succeed on a NOCOW file even if data space is
    exhausted

    - fix cancelling balance on filesystem with exhausted metadata space

    - anon block device:
    - preallocate anon bdev when subvolume is created to report
    failure early
    - shorten time the anon bdev id is allocated
    - don't allocate anon bdev for internal roots

    - minor memory leak in ref-verify

    - refuse invalid combinations of compression and NOCOW file flags

    - lockdep fixes, updating the device locks

    - remove obsolete fallback logic for block group profile adjustments
    when switching from 1 to more devices, causing allocation of
    unwanted block groups

    Other cleanups, refactoring, simplifications:

    - conversions from struct inode to struct btrfs_inode in internal
    functions

    - removal of unused struct members"

    * tag 'for-5.9-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux: (151 commits)
    btrfs: do not set the full sync flag on the inode during page release
    btrfs: release old extent maps during page release
    btrfs: fix race between page release and a fast fsync
    btrfs: open-code remount flag setting in btrfs_remount
    btrfs: if we're restriping, use the target restripe profile
    btrfs: don't adjust bg flags and use default allocation profiles
    btrfs: fix lockdep splat from btrfs_dump_space_info
    btrfs: move the chunk_mutex in btrfs_read_chunk_tree
    btrfs: open device without device_list_mutex
    btrfs: sysfs: use NOFS for device creation
    btrfs: return EROFS for BTRFS_FS_STATE_ERROR cases
    btrfs: document special case error codes for fs errors
    btrfs: don't WARN if we abort a transaction with EROFS
    btrfs: reduce contention on log trees when logging checksums
    btrfs: remove done label in writepage_delalloc
    btrfs: add comments for btrfs_reserve_flush_enum
    btrfs: relocation: review the call sites which can be interrupted by signal
    btrfs: avoid possible signal interruption of btrfs_drop_snapshot() on relocation tree
    btrfs: relocation: allow signal to cancel balance
    btrfs: raid56: remove out label in __raid56_parity_recover
    ...

    Linus Torvalds
     
  • Pull tpm updates from Jarkko Sakkinen:
    "An issue was fixed with the TPM space buffer size. The buffer is used
    to store in-TPM objects while swapped out of the TPM for a /dev/tpmrm0
    session. The code incorrectly used PAGE_SIZE, which obviously can
    vary. With these changes the buffer has a fixed size of 16 kB.

    In addition, this contains support for acquiring TPM even log from
    TPM2 ACPI table. This method is used by QEMU in particular"

    * tag 'tpmdd-next-v5.9' of git://git.infradead.org/users/jjs/linux-tpmdd:
    tpm: Add support for event log pointer found in TPM2 ACPI table
    acpi: Extend TPM2 ACPI table with missing log fields
    tpm: Unify the mismatching TPM space buffer sizes
    tpm: Require that all digests are present in TCG_PCR_EVENT2 structures

    Linus Torvalds
     

03 Aug, 2020

6 commits

  • That gives us ordering guarantees around the pair.

    Signed-off-by: Linus Torvalds

    Linus Torvalds
     
  • It turns out that wait_on_page_bit_common() had several problems,
    ranging from just unfair behavioe due to re-queueing at the end of the
    wait queue when re-trying, and an outright bug that could result in
    missed wakeups (but probably never happened in practice).

    This rewrites the whole logic to avoid both issues, by simply moving the
    logic to check (and possibly take) the bit lock into the wakeup path
    instead.

    That makes everything much more straightforward, and means that we never
    need to re-queue the wait entry: if we get woken up, we'll be notified
    through WQ_FLAG_WOKEN, and the wait queue entry will have been removed,
    and everything will have been done for us.

    Link: https://lore.kernel.org/lkml/CAHk-=wjJA2Z3kUFb-5s=6+n0qbTs8ELqKFt9B3pH85a8fGD73w@mail.gmail.com/
    Link: https://lore.kernel.org/lkml/alpine.LSU.2.11.2007221359450.1017@eggly.anvils/
    Reported-by: Oleg Nesterov
    Reported-by: Hugh Dickins
    Cc: Michal Hocko
    Reviewed-by: Oleg Nesterov
    Signed-off-by: Linus Torvalds

    Linus Torvalds
     
  • Linus Torvalds
     
  • Pull x86 fix from Ingo Molnar:
    "A single fix for a potential deadlock when printing a message about
    spurious interrupts"

    * tag 'x86-urgent-2020-08-02' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
    x86/i8259: Use printk_deferred() to prevent deadlock

    Linus Torvalds
     
  • …/masahiroy/linux-kbuild

    Pull Kbuild fixes from Masahiro Yamada:

    - clean the generated moc file for xconfig

    - fix xconfig bugs, and revert some bad commits

    * tag 'kbuild-fixes-v5.8-4' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild:
    kbuild: remove redundant FORCE definition in scripts/Makefile.modpost
    kconfig: qconf: remove wrong ConfigList::firstChild()
    Revert "kconfig: qconf: don't show goback button on splitMode"
    Revert "kconfig: qconf: Change title for the item window"
    kconfig: qconf: remove "goBack" debug message
    kconfig: qconf: use delete[] instead of delete to free array
    kconfig: qconf: compile moc object separately
    kconfig: qconf: use if_changed for qconf.moc rule
    modpost: explain why we can't use strsep

    Linus Torvalds
     
  • Pull KVM fixes from Paolo Bonzini:
    "Bugfixes and strengthening the validity checks on inputs from new
    userspace APIs.

    Now I know why I shouldn't prepare pull requests on the weekend, it's
    hard to concentrate if your son is shouting about his latest Minecraft
    builds in your ear. Fortunately all the patches were ready and I just
    had to check the test results..."

    * tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm:
    KVM: SVM: Fix disable pause loop exit/pause filtering capability on SVM
    KVM: LAPIC: Prevent setting the tscdeadline timer if the lapic is hw disabled
    KVM: arm64: Don't inherit exec permission across page-table levels
    KVM: arm64: Prevent vcpu_has_ptrauth from generating OOL functions
    KVM: nVMX: check for invalid hdr.vmx.flags
    KVM: nVMX: check for required but missing VMCS12 in KVM_SET_NESTED_STATE
    selftests: kvm: do not set guest mode flag

    Linus Torvalds
     

02 Aug, 2020

7 commits

  • The same code exists a few lines above.

    Fixes: 436b2ac603d5 ("modpost: invoke modpost only when input files are updated")
    Signed-off-by: Masahiro Yamada

    Masahiro Yamada
     
  • This function returns the first child object, but the returned pointer
    is not compatible with (ConfigItem *).

    Commit cc1c08edccaf ("kconfig: qconf: don't show goback button on
    splitMode") uncovered this issue because using the pointer from this
    function would make qconf crash. (https://lkml.org/lkml/2020/7/18/411)

    This function does not work. Remove.

    Signed-off-by: Masahiro Yamada

    Masahiro Yamada
     
  • Pull networking fixes from David Miller:

    1) Encap offset calculation is incorrect in esp6, from Sabrina Dubroca.

    2) Better parameter validation in pfkey_dump(), from Mark Salyzyn.

    3) Fix several clang issues on powerpc in selftests, from Tanner Love.

    4) cmsghdr_from_user_compat_to_kern() uses the wrong length, from Al
    Viro.

    5) Out of bounds access in mlx5e driver, from Raed Salem.

    6) Fix transfer buffer memleak in lan78xx, from Johan Havold.

    7) RCU fixups in rhashtable, from Herbert Xu.

    8) Fix ipv6 nexthop refcnt leak, from Xiyu Yang.

    9) vxlan FDB dump must be done under RCU, from Ido Schimmel.

    10) Fix use after free in mlxsw, from Ido Schimmel.

    11) Fix map leak in HASH_OF_MAPS bpf code, from Andrii Nakryiko.

    12) Fix bug in mac80211 Tx ack status reporting, from Vasanthakumar
    Thiagarajan.

    13) Fix memory leaks in IPV6_ADDRFORM code, from Cong Wang.

    14) Fix bpf program reference count leaks in mlx5 during
    mlx5e_alloc_rq(), from Xin Xiong.

    * git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net: (86 commits)
    vxlan: fix memleak of fdb
    rds: Prevent kernel-infoleak in rds_notify_queue_get()
    net/sched: The error lable position is corrected in ct_init_module
    net/mlx5e: fix bpf_prog reference count leaks in mlx5e_alloc_rq
    net/mlx5e: E-Switch, Specify flow_source for rule with no in_port
    net/mlx5e: E-Switch, Add misc bit when misc fields changed for mirroring
    net/mlx5e: CT: Support restore ipv6 tunnel
    net: gemini: Fix missing clk_disable_unprepare() in error path of gemini_ethernet_port_probe()
    ionic: unlock queue mutex in error path
    atm: fix atm_dev refcnt leaks in atmtcp_remove_persistent
    net: ethernet: mtk_eth_soc: fix MTU warnings
    net: nixge: fix potential memory leak in nixge_probe()
    devlink: ignore -EOPNOTSUPP errors on dumpit
    rxrpc: Fix race between recvmsg and sendmsg on immediate call failure
    MAINTAINERS: Replace Thor Thayer as Altera Triple Speed Ethernet maintainer
    selftests/bpf: fix netdevsim trap_flow_action_cookie read
    ipv6: fix memory leaks on IPV6_ADDRFORM path
    net/bpfilter: Initialize pos in __bpfilter_process_sockopt
    igb: reinit_locked() should be called with rtnl_lock
    e1000e: continue to init PHY even when failed to disable ULP
    ...

    Linus Torvalds
     
  • Pull thread fix from Christian Brauner:
    "A simple spelling fix for dequeue_synchronous_signal()"

    * tag 'for-linus-2020-08-01' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux:
    signal: fix typo in dequeue_synchronous_signal()

    Linus Torvalds
     
  • Pull perf tooling fixes from Arnaldo Carvalho de Melo:

    - Fix libtraceevent build with binutils 2.35

    - Fix memory leak in process_dynamic_array_len in libtraceevent

    - Fix 'perf test 68' zstd compression for s390

    - Fix record failure when mixed with ARM SPE event

    * tag 'perf-tools-fixes-2020-08-01' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux:
    libtraceevent: Fix build with binutils 2.35
    perf tools: Fix record failure when mixed with ARM SPE event
    perf tests: Fix test 68 zstd compression for s390
    tools lib traceevent: Fix memory leak in process_dynamic_array_len

    Linus Torvalds
     
  • When vxlan interface is deleted, all fdbs are deleted by vxlan_flush().
    vxlan_flush() flushes fdbs but it doesn't delete fdb, which contains
    all-zeros-mac because it is deleted by vxlan_uninit().
    But vxlan_uninit() deletes only the fdb, which contains both all-zeros-mac
    and default vni.
    So, the fdb, which contains both all-zeros-mac and non-default vni
    will not be deleted.

    Test commands:
    ip link add vxlan0 type vxlan dstport 4789 external
    ip link set vxlan0 up
    bridge fdb add to 00:00:00:00:00:00 dst 172.0.0.1 dev vxlan0 via lo \
    src_vni 10000 self permanent
    ip link del vxlan0

    kmemleak reports as follows:
    unreferenced object 0xffff9486b25ced88 (size 96):
    comm "bridge", pid 2151, jiffies 4294701712 (age 35506.901s)
    hex dump (first 32 bytes):
    02 00 00 00 ac 00 00 01 40 00 09 b1 86 94 ff ff ........@.......
    46 02 00 00 00 00 00 00 a7 03 00 00 12 b5 6a 6b F.............jk
    backtrace:
    [] vxlan_fdb_append.part.51+0x3c/0xf0 [vxlan]
    [] vxlan_fdb_create+0x184/0x1a0 [vxlan]
    [] vxlan_fdb_update+0x12f/0x220 [vxlan]
    [] vxlan_fdb_add+0x12a/0x1b0 [vxlan]
    [] rtnl_fdb_add+0x187/0x270
    [] rtnetlink_rcv_msg+0x264/0x490
    [] netlink_rcv_skb+0x4a/0x110
    [] netlink_unicast+0x18e/0x250
    [] netlink_sendmsg+0x2e9/0x400
    [] ____sys_sendmsg+0x237/0x260
    [] ___sys_sendmsg+0x88/0xd0
    [] __sys_sendmsg+0x4e/0x80
    [] do_syscall_64+0x56/0xe0
    [] entry_SYSCALL_64_after_hwframe+0x44/0xa9
    unreferenced object 0xffff9486b1c40080 (size 128):
    comm "bridge", pid 2157, jiffies 4294701754 (age 35506.866s)
    hex dump (first 32 bytes):
    00 00 00 00 00 00 00 00 f8 dc 42 b2 86 94 ff ff ..........B.....
    6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk
    backtrace:
    [] vxlan_fdb_create+0x67/0x1a0 [vxlan]
    [] vxlan_fdb_update+0x12f/0x220 [vxlan]
    [] vxlan_fdb_add+0x12a/0x1b0 [vxlan]
    [] rtnl_fdb_add+0x187/0x270
    [] rtnetlink_rcv_msg+0x264/0x490
    [] netlink_rcv_skb+0x4a/0x110
    [] netlink_unicast+0x18e/0x250
    [] netlink_sendmsg+0x2e9/0x400
    [] ____sys_sendmsg+0x237/0x260
    [] ___sys_sendmsg+0x88/0xd0
    [] __sys_sendmsg+0x4e/0x80
    [] do_syscall_64+0x56/0xe0
    [] entry_SYSCALL_64_after_hwframe+0x44/0xa9

    Fixes: 3ad7a4b141eb ("vxlan: support fdb and learning in COLLECT_METADATA mode")
    Signed-off-by: Taehee Yoo
    Acked-by: Roopa Prabhu
    Signed-off-by: David S. Miller

    Taehee Yoo
     
  • Pull pin control fix from Linus Walleij:
    "A single last minute pin control fix to the Qualcomm driver fixing
    missing dual edge PCH interrupts"

    * tag 'pinctrl-v5.8-4' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl:
    pinctrl: qcom: Handle broken/missing PDC dual edge IRQs on sc7180

    Linus Torvalds
     

01 Aug, 2020

18 commits

  • This reverts commit cc1c08edccaf5317d99a17a3231fe06381044e83.

    Maxim Levitsky reports 'make xconfig' crashes since that commit
    (https://lkml.org/lkml/2020/7/18/411)

    Or, the following is simple test code that makes it crash:

    menu "Menu"

    config FOO
    bool "foo"
    default y

    menuconfig BAR
    bool "bar"
    depends on FOO

    endmenu

    Select the Split View mode, and double-click "bar" in the right
    window, then you will see Segmentation fault.

    When 'last' is not set for symbolMode, the following code in
    ConfigList::updateList() calls firstChild().

    item = last ? last->nextSibling() : firstChild();

    However, the pointer returned by ConfigList::firstChild() does not
    seem to be compatible with (ConfigItem *), which seems another bug.

    I'd rather want to reconsider whether hiding the goback icon is the
    right thing to do.

    In the following test code, the Split View shows "Menu2" and "Menu3"
    in the right window. You can descend into "Menu3", but there is no way
    to ascend back to "Menu2" from "Menu3".

    menu "Menu1"

    config FOO
    bool "foo"
    default y

    menu "Menu2"
    depends on FOO

    menu "Menu3"

    config BAZ
    bool "baz"

    endmenu

    endmenu

    endmenu

    It is true that the goback button is currently not functional due to
    yet another bug, but hiding the problem is not the right way to go.

    Anyway, Segmentation fault is fatal. Revert the offending commit for
    now, and we should find the right solution.

    Reported-by: Maxim Levitsky
    Signed-off-by: Masahiro Yamada

    Masahiro Yamada
     
  • This reverts commit 5752ff07fd90d764d96e3c586cc95c09598abfdd.

    It added dead code to ConfigList:ConfigList().

    The constructor of ConfigList has the initializer, mode(singleMode).

    if (mode == symbolMode)
    setHeaderLabels(QStringList() << "Item" << "Name" << "N" << "M" << "Y" << "Value");
    else
    setHeaderLabels(QStringList() << "Option" << "Name" << "N" << "M" << "Y" << "Value");

    ... always takes the else part.

    The change to ConfigList::updateSelection() is strange too.
    When you click the split view icon for the first time, the titles in
    both windows show "Option". After you click something in the right
    window, the title suddenly changes to "Item".

    ConfigList::updateSelection() is not the right place to do this,
    at least. It was not a good idea, I think.

    Signed-off-by: Masahiro Yamada

    Masahiro Yamada
     
  • Every time the goback icon is clicked, the annoying message "goBack"
    is displayed on the console.

    I guess this line is the left-over debug code of commit af737b4defe1
    ("kconfig: qconf: simplify the goBack() logic").

    Signed-off-by: Masahiro Yamada

    Masahiro Yamada
     
  • cppcheck reports "Mismatching allocation and deallocation".

    $ cppcheck scripts/kconfig/qconf.cc
    Checking scripts/kconfig/qconf.cc ...
    scripts/kconfig/qconf.cc:1242:10: error: Mismatching allocation and deallocation: data [mismatchAllocDealloc]
    delete data;
    ^
    scripts/kconfig/qconf.cc:1236:15: note: Mismatching allocation and deallocation: data
    char *data = new char[count + 1];
    ^
    scripts/kconfig/qconf.cc:1242:10: note: Mismatching allocation and deallocation: data
    delete data;
    ^
    scripts/kconfig/qconf.cc:1255:10: error: Mismatching allocation and deallocation: data [mismatchAllocDealloc]
    delete data;
    ^
    scripts/kconfig/qconf.cc:1236:15: note: Mismatching allocation and deallocation: data
    char *data = new char[count + 1];
    ^
    scripts/kconfig/qconf.cc:1255:10: note: Mismatching allocation and deallocation: data
    delete data;
    ^

    Fixes: c4f7398bee9c ("kconfig: qconf: make debug links work again")
    Reported-by: David Binderman
    Signed-off-by: Masahiro Yamada

    Masahiro Yamada
     
  • Currently, qconf.moc is included from qconf.cc but they can be compiled
    independently.

    When you modify qconf.cc, qconf.moc does not need recompiling.

    Rename qconf.moc to qconf-moc.cc, and split it out as an independent
    compilation unit.

    Signed-off-by: Masahiro Yamada

    Masahiro Yamada
     
  • Regenerate qconf.moc when the moc command is changed.

    This also allows 'make mrproper' to clean it up. Previously, it was
    not cleaned up because 'clean-files += qconf.moc' was missing.
    Now 'make mrproper' correctly cleans it up because files listed in
    'targets' are cleaned.

    Signed-off-by: Masahiro Yamada

    Masahiro Yamada
     
  • Daniel Borkmann says:

    ====================
    pull-request: bpf 2020-07-31

    The following pull-request contains BPF updates for your *net* tree.

    We've added 5 non-merge commits during the last 21 day(s) which contain
    a total of 5 files changed, 126 insertions(+), 18 deletions(-).

    The main changes are:

    1) Fix a map element leak in HASH_OF_MAPS map type, from Andrii Nakryiko.

    2) Fix a NULL pointer dereference in __btf_resolve_helper_id() when no
    btf_vmlinux is available, from Peilin Ye.

    3) Init pos variable in __bpfilter_process_sockopt(), from Christoph Hellwig.

    4) Fix a cgroup sockopt verifier test by specifying expected attach type,
    from Jean-Philippe Brucker.

    Note that when net gets merged into net-next later on, there is a small
    merge conflict in kernel/bpf/btf.c between commit 5b801dfb7feb ("bpf: Fix
    NULL pointer dereference in __btf_resolve_helper_id()") from the bpf tree
    and commit 138b9a0511c7 ("bpf: Remove btf_id helpers resolving") from the
    net-next tree.

    Resolve as follows: remove the old hunk with the __btf_resolve_helper_id()
    function. Change the btf_resolve_helper_id() so it actually tests for a
    NULL btf_vmlinux and bails out:

    int btf_resolve_helper_id(struct bpf_verifier_log *log,
    const struct bpf_func_proto *fn, int arg)
    {
    int id;

    if (fn->arg_type[arg] != ARG_PTR_TO_BTF_ID || !btf_vmlinux)
    return -EINVAL;
    id = fn->btf_id[arg];
    if (!id || id > btf_vmlinux->nr_types)
    return -EINVAL;
    return id;
    }

    Let me know if you run into any others issues (CC'ing Jiri Olsa so he's in
    the loop with regards to merge conflict resolution).
    ====================

    Signed-off-by: David S. Miller

    David S. Miller
     
  • Steffen Klassert says:

    ====================
    pull request (net): ipsec 2020-07-31

    1) Fix policy matching with mark and mask on userspace interfaces.
    From Xin Long.

    2) Several fixes for the new ESP in TCP encapsulation.
    From Sabrina Dubroca.

    3) Fix crash when the hold queue is used. The assumption that
    xdst->path and dst->child are not a NULL pointer only if dst->xfrm
    is not a NULL pointer is true with the exception of using the
    hold queue. Fix this by checking for hold queue usage before
    dereferencing xdst->path or dst->child.

    4) Validate pfkey_dump parameter before sending them.
    From Mark Salyzyn.

    5) Fix the location of the transport header with ESP in UDPv6
    encapsulation. From Sabrina Dubroca.
    ====================

    Signed-off-by: David S. Miller

    David S. Miller
     
  • Saeed Mahameed says:

    ====================
    Mellanox, mlx5 fixes 2020-07-30

    This small patchset introduces some fixes to mlx5 driver.

    Please pull and let me know if there is any problem.

    For -stable v4.18:
    ('net/mlx5e: fix bpf_prog reference count leaks in mlx5e_alloc_rq')

    For -stable v5.7:
    ('net/mlx5e: E-Switch, Add misc bit when misc fields changed for mirroring')
    ====================

    Signed-off-by: David S. Miller

    David S. Miller
     
  • rds_notify_queue_get() is potentially copying uninitialized kernel stack
    memory to userspace since the compiler may leave a 4-byte hole at the end
    of `cmsg`.

    In 2016 we tried to fix this issue by doing `= { 0 };` on `cmsg`, which
    unfortunately does not always initialize that 4-byte hole. Fix it by using
    memset() instead.

    Cc: stable@vger.kernel.org
    Fixes: f037590fff30 ("rds: fix a leak of kernel memory")
    Fixes: bdbe6fbc6a2f ("RDS: recv.c")
    Suggested-by: Dan Carpenter
    Signed-off-by: Peilin Ye
    Acked-by: Santosh Shilimkar
    Signed-off-by: David S. Miller

    Peilin Ye
     
  • Tony Nguyen says:

    ====================
    Intel Wired LAN Driver Updates 2020-07-30

    This series contains updates to the e1000e and igb drivers.

    Aaron Ma allows PHY initialization to continue if ULP disable failed for
    e1000e.

    Francesco Ruggeri fixes race conditions in igb reset that could cause panics.
    ====================

    Signed-off-by: David S. Miller

    David S. Miller
     
  • Exchange the positions of the err_tbl_init and err_register labels in
    ct_init_module function.

    Fixes: c34b961a2492 ("net/sched: act_ct: Create nf flow table per zone")
    Signed-off-by: liujian
    Signed-off-by: David S. Miller

    liujian
     
  • Pull i2c fixes from Wolfram Sang:
    "Some I2C core improvements to prevent NULL pointer usage and a
    MAINTAINERS update"

    * 'i2c/for-current' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux:
    i2c: slave: add sanity check when unregistering
    i2c: slave: improve sanity check when registering
    MAINTAINERS: Update GENI I2C maintainers list
    i2c: also convert placeholder function to return errno

    Linus Torvalds
     
  • Pull powerpc fix from Michael Ellerman:
    "Fix a bug introduced by the changes we made to lockless page table
    walking this cycle.

    When using the hash MMU, and perf with callchain recording, we can
    deadlock if the PMI interrupts a hash fault, and the callchain
    recording then takes a hash fault on the same page.

    Thanks to Nicholas Piggin, Aneesh Kumar K.V, Anton Blanchard, and
    Athira Rajeev"

    * tag 'powerpc-5.8-8' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux:
    powerpc/64s/hash: Fix hash_preload running with interrupts enabled

    Linus Torvalds
     
  • Pull arm64 fixes from Will Deacon:
    "The main one is to fix the build after Willy's per-cpu entropy changes
    this week. Although that was already resolved elsewhere, the arm64 fix
    here is useful cleanup anyway.

    Other than that, we've got a fix for building with Clang's integrated
    assembler and a fix to make our IPv4 checksumming robust against
    invalid header lengths (this only seems to be triggerable by injected
    errors).

    - Fix build breakage due to circular headers

    - Fix build regression when using Clang's integrated assembler

    - Fix IPv4 header checksum code to deal with invalid length field

    - Fix broken path for Arm PMU entry in MAINTAINERS"

    * tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux:
    MAINTAINERS: Include drivers subdirs for ARM PMU PROFILING AND DEBUGGING entry
    arm64: csum: Fix handling of bad packets
    arm64: Drop unnecessary include from asm/smp.h
    arm64/alternatives: move length validation inside the subsection

    Linus Torvalds
     
  • Pull ARM fixes from Russell King:

    - avoid invoking overflow handler for uaccess watchpoints

    - fix incorrect clock_gettime64 availability

    - fix EFI crash in create_mapping_late()

    * tag 'for-linus' of git://git.armlinux.org.uk/~rmk/linux-arm:
    ARM: 8988/1: mmu: fix crash in EFI calls due to p4d typo in create_mapping_late()
    ARM: 8987/1: VDSO: Fix incorrect clock_gettime64
    ARM: 8986/1: hw_breakpoint: Don't invoke overflow handler on uaccess watchpoints

    Linus Torvalds
     
  • Pull rdma fixes from Jason Gunthorpe:
    "Two more merge window regressions, a corruption bug in hfi1 and a few
    other small fixes.

    - Missing user input validation regression in ucma

    - Disallowing a previously allowed user combination regression in
    mlx5

    - ODP prefetch memory leaking triggerable by userspace

    - Memory corruption in hf1 due to faulty ring buffer logic

    - Missed mutex initialization crash in mlx5

    - Two small defects with RDMA DIM"

    * tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/rdma/rdma:
    RDMA/core: Free DIM memory in error unwind
    RDMA/core: Stop DIM before destroying CQ
    RDMA/mlx5: Initialize QP mutex for the debug kernels
    IB/rdmavt: Fix RQ counting issues causing use of an invalid RWQE
    RDMA/mlx5: Allow providing extra scatter CQE QP flag
    RDMA/mlx5: Fix prefetch memory leak if get_prefetchable_mr fails
    RDMA/cm: Add min length checks to user structure copies

    Linus Torvalds
     
  • Pull sound fixes from Takashi Iwai:
    "A few wrap-up small fixes for the usual HD-audio and USB-audio stuff:

    - A regression fix for S3 suspend on old Intel platforms

    - A fix for possible Oops in ASoC HD-audio binding

    - Trivial quirks for various devices"

    * tag 'sound-5.8' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound:
    ALSA: hda/realtek - Fixed HP right speaker no sound
    ALSA: hda: fix NULL pointer dereference during suspend
    ALSA: hda/hdmi: Fix keep_power assignment for non-component devices
    ALSA: hda: Workaround for spurious wakeups on some Intel platforms
    ALSA: hda/realtek: Fix add a "ultra_low_power" function for intel reference board (alc256)
    ALSA: hda/realtek: typo_fix: enable headset mic of ASUS ROG Zephyrus G14(GA401) series with ALC289
    ALSA: hda/realtek: enable headset mic of ASUS ROG Zephyrus G15(GA502) series with ALC289
    ALSA: usb-audio: Add implicit feedback quirk for SSL2

    Linus Torvalds
     

31 Jul, 2020

2 commits

  • In binutils 2.35, 'nm -D' changed to show symbol versions along with
    symbol names, with the usual @@ separator. When generating
    libtraceevent-dynamic-list we need just the names, so strip off the
    version suffix if present.

    Signed-off-by: Ben Hutchings
    Tested-by: Salvatore Bonaccorso
    Reviewed-by: Steven Rostedt
    Cc: linux-trace-devel@vger.kernel.org
    Cc: stable@vger.kernel.org
    Signed-off-by: Arnaldo Carvalho de Melo

    Ben Hutchings
     
  • When recording with cache-misses and arm_spe_x event, I found that it
    will just fail without showing any error info if i put cache-misses
    after 'arm_spe_x' event.

    [root@localhost 0620]# perf record -e cache-misses \
    -e arm_spe_0/ts_enable=1,pct_enable=1,pa_enable=1,load_filter=1,jitter=1,store_filter=1,min_latency=0/ sleep 1
    [ perf record: Woken up 1 times to write data ]
    [ perf record: Captured and wrote 0.067 MB perf.data ]
    [root@localhost 0620]#
    [root@localhost 0620]# perf record -e arm_spe_0/ts_enable=1,pct_enable=1,pa_enable=1,load_filter=1,jitter=1,store_filter=1,min_latency=0/ \
    -e cache-misses sleep 1
    [root@localhost 0620]#

    The current code can only work if the only event to be traced is an
    'arm_spe_x', or if it is the last event to be specified. Otherwise the
    last event type will be checked against all the arm_spe_pmus[i]->types,
    none will match and an out of bound 'i' index will be used in
    arm_spe_recording_init().

    We don't support concurrent multiple arm_spe_x events currently, that
    is checked in arm_spe_recording_options(), and it will show the relevant
    info. So add the check and record of the first found 'arm_spe_pmu' to
    fix this issue here.

    Fixes: ffd3d18c20b8 ("perf tools: Add ARM Statistical Profiling Extensions (SPE) support")
    Signed-off-by: Wei Li
    Reviewed-by: Mathieu Poirier
    Tested-by-by: Leo Yan
    Cc: Alexander Shishkin
    Cc: Hanjun Guo
    Cc: Jiri Olsa
    Cc: Kim Phillips
    Cc: Mark Rutland
    Cc: Mike Leach
    Cc: Namhyung Kim
    Cc: Peter Zijlstra
    Cc: Suzuki Poulouse
    Cc: linux-arm-kernel@lists.infradead.org
    Link: http://lore.kernel.org/lkml/20200724071111.35593-2-liwei391@huawei.com
    Signed-off-by: Arnaldo Carvalho de Melo

    Wei Li