1. 21 Aug, 2023 1 commit
  2. 18 Aug, 2023 1 commit
    • Georg Ottinger's avatar
      ext2: improve consistency of ext2_fsblk_t datatype usage · 2ebc736c
      Georg Ottinger authored
      The ext2 block allocation/deallocation functions and their respective
      calls use a mixture of unsigned long and ext2_fsblk_t datatypes to
      index the desired ext2 block. This commit replaces occurrences of
      unsigned long with ext2_fsblk_t, covering the functions
      ext2_new_block(), ext2_new_blocks(), ext2_free_blocks(),
      ext2_free_data() and ext2_free_branches(). This commit is rather
      conservative, and only replaces unsigned long with ext2_fsblk_t if
      the variable is used to index a specific ext2 block.
      Signed-off-by: default avatarGeorg Ottinger <g.ottinger@gmx.at>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <20230817195925.10268-1-g.ottinger@gmx.at>
      2ebc736c
  3. 16 Aug, 2023 5 commits
    • Ye Bin's avatar
      ext2: dump current reservation window info · 9bc6fc33
      Ye Bin authored
      There's report BUG in 'ext2_try_to_allocate_with_rsv()', although there's
      now dump of all reservation windows information. But there's unknown which
      window is being processed.So this is not helpful for locating the issue.
      To better analyze the problem, dump the information about reservation window
      that is being processed. And just bail with error instead of BUG here.
      Signed-off-by: default avatarYe Bin <yebin10@huawei.com>
      Message-Id: <20230815112612.221145-5-yebin10@huawei.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      9bc6fc33
    • Ye Bin's avatar
      ext2: fix race between setxattr and write back · 83f99de1
      Ye Bin authored
      There's an issue when allocating xattrs as follows:
      Block Allocation Reservation Windows Map (ext2_try_to_allocate_with_rsv):
      reservation window 0x000000006f105382 start: 0, end: 0
      reservation window 0x000000008fd1a555 start: 1044, end: 1059
      Window map complete.
      kernel BUG at fs/ext2/balloc.c:1158!
      invalid opcode: 0000 [#1] PREEMPT SMP KASAN
      RIP: 0010:ext2_try_to_allocate_with_rsv.isra.0+0x15c4/0x1800
      Call Trace:
       <TASK>
       ext2_new_blocks+0x935/0x1690
       ext2_new_block+0x73/0xa0
       ext2_xattr_set2+0x74f/0x1730
       ext2_xattr_set+0x12b6/0x2260
       ext2_xattr_user_set+0x9c/0x110
       __vfs_setxattr+0x139/0x1d0
       __vfs_setxattr_noperm+0xfc/0x370
       __vfs_setxattr_locked+0x205/0x2c0
       vfs_setxattr+0x19d/0x3b0
       do_setxattr+0xff/0x220
       setxattr+0x123/0x150
       path_setxattr+0x193/0x1e0
       __x64_sys_setxattr+0xc8/0x170
       do_syscall_64+0x35/0x80
       entry_SYSCALL_64_after_hwframe+0x63/0xcd
      
      Above issue may happens as follows:
              setxattr                             write back
      ext2_xattr_set
        ext2_xattr_set2
          ext2_new_block
            ext2_new_blocks
              ext2_try_to_allocate_with_rsv
                alloc_new_reservation
                --> group=0 [0, 1023] rsv [1016, 1023]
                                              do_writepages
                                                mpage_writepages
                                                  write_cache_pages
                                                    __mpage_writepage
                                                      ext2_get_block
                                                        ext2_get_blocks
                                                         ext2_alloc_branch
                                                          ext2_new_blocks
                                                           ext2_try_to_allocate_with_rsv
                                                             alloc_new_reservation
                                           -->group=1 [1024, 2047] rsv [1044, 1059]
                if ((my_rsv->rsv_start > group_last_block) ||
                    (my_rsv->rsv_end < group_first_block)
                    rsv_window_dump
                    BUG();
      
      Now ext2 mkwrite doesn't allocate new blocks so for these cases we may
      be allocating blocks during writeback. However, there is no protection
      between ext2_xattr_set() and do_writepages() so these two functions can
      conflict on handling the reservation window.  To solve about issue don't
      use the reservation window when allocating block for xattr.
      Signed-off-by: default avatarYe Bin <yebin10@huawei.com>
      Message-Id: <20230815112612.221145-4-yebin10@huawei.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      83f99de1
    • Ye Bin's avatar
      ext2: introduce new flags argument for ext2_new_blocks() · b450159d
      Ye Bin authored
      This patch introduces a new flags argument for ext2_new_blocks() and also
      a new EXT2_ALLOC_NORESERVE flag.
      Signed-off-by: default avatarYe Bin <yebin10@huawei.com>
      Message-Id: <20230815112612.221145-3-yebin10@huawei.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      b450159d
    • Ye Bin's avatar
      ext2: remove ext2_new_block() · 2445a8a1
      Ye Bin authored
      Now, only xattr allocate block use ext2_new_block(), so just opencode it in
      the xattr code.
      Signed-off-by: default avatarYe Bin <yebin10@huawei.com>
      Message-Id: <20230815112612.221145-2-yebin10@huawei.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      2445a8a1
    • Georg Ottinger's avatar
      ext2: fix datatype of block number in ext2_xattr_set2() · e8807634
      Georg Ottinger authored
      I run a small server that uses external hard drives for backups. The
      backup software I use uses ext2 filesystems with 4KiB block size and
      the server is running SELinux and therefore relies on xattr. I recently
      upgraded the hard drives from 4TB to 12TB models. I noticed that after
      transferring some TBs I got a filesystem error "Freeing blocks not in
      datazone - block = 18446744071529317386, count = 1" and the backup
      process stopped. Trying to fix the fs with e2fsck resulted in a
      completely corrupted fs. The error probably came from ext2_free_blocks(),
      and because of the large number 18e19 this problem immediately looked
      like some kind of integer overflow. Whereas the 4TB fs was about 1e9
      blocks, the new 12TB is about 3e9 blocks. So, searching the ext2 code,
      I came across the line in fs/ext2/xattr.c:745 where ext2_new_block()
      is called and the resulting block number is stored in the variable block
      as an int datatype. If a block with a block number greater than
      INT32_MAX is returned, this variable overflows and the call to
      sb_getblk() at line fs/ext2/xattr.c:750 fails, then the call to
      ext2_free_blocks() produces the error.
      Signed-off-by: default avatarGeorg Ottinger <g.ottinger@gmx.at>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <20230815100340.22121-1-g.ottinger@gmx.at>
      e8807634
  4. 09 Aug, 2023 1 commit
  5. 03 Aug, 2023 1 commit
  6. 31 Jul, 2023 2 commits
    • Piotr Siminski's avatar
      MAINTAINERS: change reiserfs status to obsolete · 2363650b
      Piotr Siminski authored
      Reiserfs file system is no longer supported and is going to be removed
      in 2025 as stated in commit eb103a51 ("reiserfs: Deprecate reiserfs").
      Signed-off-by: default avatarPiotr Siminski <piotr.siminski@globallogic.com>
      Reviewed-by: default avatarLukas Bulwahn <lukas.bulwahn@gmail.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <20230720115445.15583-1-piotr.siminski@globallogic.com>
      2363650b
    • Gustavo A. R. Silva's avatar
      udf: Fix -Wstringop-overflow warnings · ca97f7e5
      Gustavo A. R. Silva authored
      Use unsigned type in call to macro mint_t(). This avoids confusing the
      compiler about possible negative values that would cause the value in
      _len_ to wrap around.
      
      Fixes the following -Wstringop-warnings seen when building ARM
      architecture with allyesconfig (GCC 13):
      fs/udf/directory.c: In function 'udf_copy_fi':
      include/linux/fortify-string.h:57:33: warning: '__builtin_memcpy' specified bound between 2147483648 and 4294967295 exceeds maximum object size 2147483647 [-Wstringop-overflow=]
         57 | #define __underlying_memcpy     __builtin_memcpy
            |                                 ^
      include/linux/fortify-string.h:648:9: note: in expansion of macro '__underlying_memcpy'
        648 |         __underlying_##op(p, q, __fortify_size);                        \
            |         ^~~~~~~~~~~~~
      include/linux/fortify-string.h:693:26: note: in expansion of macro '__fortify_memcpy_chk'
        693 | #define memcpy(p, q, s)  __fortify_memcpy_chk(p, q, s,                  \
            |                          ^~~~~~~~~~~~~~~~~~~~
      fs/udf/directory.c:99:9: note: in expansion of macro 'memcpy'
         99 |         memcpy(&iter->fi, iter->bh[0]->b_data + off, len);
            |         ^~~~~~
      include/linux/fortify-string.h:57:33: warning: '__builtin_memcpy' specified bound between 2147483648 and 4294967295 exceeds maximum object size 2147483647 [-Wstringop-overflow=]
         57 | #define __underlying_memcpy     __builtin_memcpy
            |                                 ^
      include/linux/fortify-string.h:648:9: note: in expansion of macro '__underlying_memcpy'
        648 |         __underlying_##op(p, q, __fortify_size);                        \
            |         ^~~~~~~~~~~~~
      include/linux/fortify-string.h:693:26: note: in expansion of macro '__fortify_memcpy_chk'
        693 | #define memcpy(p, q, s)  __fortify_memcpy_chk(p, q, s,                  \
            |                          ^~~~~~~~~~~~~~~~~~~~
      fs/udf/directory.c:99:9: note: in expansion of macro 'memcpy'
         99 |         memcpy(&iter->fi, iter->bh[0]->b_data + off, len);
            |         ^~~~~~
        AR      fs/udf/built-in.a
      
      This helps with the ongoing efforts to globally enable
      -Wstringop-overflow.
      
      Link: https://github.com/KSPP/linux/issues/329Signed-off-by: default avatarGustavo A. R. Silva <gustavoars@kernel.org>
      Reviewed-by: default avatarKees Cook <keescook@chromium.org>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <ZK7wKS0NgZPfqrZu@work>
      ca97f7e5
  7. 03 Jul, 2023 6 commits
    • Baokun Li's avatar
      quota: simplify drop_dquot_ref() · 7bce48f0
      Baokun Li authored
      As Honza said, remove_inode_dquot_ref() currently does not release the
      last dquot reference but instead adds the dquot to tofree_head list. This
      is because dqput() can sleep while dropping of the last dquot reference
      (writing back the dquot and calling ->release_dquot()) and that must not
      happen under dq_list_lock. Now that dqput() queues the final dquot cleanup
      into a workqueue, remove_inode_dquot_ref() can call dqput() unconditionally
      and we can significantly simplify it.
      
      Here we open code the simplified code of remove_inode_dquot_ref() into
      remove_dquot_ref() and remove the function put_dquot_list() which is no
      longer used.
      Signed-off-by: default avatarBaokun Li <libaokun1@huawei.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <20230630110822.3881712-6-libaokun1@huawei.com>
      7bce48f0
    • Baokun Li's avatar
      quota: fix dqput() to follow the guarantees dquot_srcu should provide · dabc8b20
      Baokun Li authored
      The dquot_mark_dquot_dirty() using dquot references from the inode
      should be protected by dquot_srcu. quota_off code takes care to call
      synchronize_srcu(&dquot_srcu) to not drop dquot references while they
      are used by other users. But dquot_transfer() breaks this assumption.
      We call dquot_transfer() to drop the last reference of dquot and add
      it to free_dquots, but there may still be other users using the dquot
      at this time, as shown in the function graph below:
      
             cpu1              cpu2
      _________________|_________________
      wb_do_writeback         CHOWN(1)
       ...
        ext4_da_update_reserve_space
         dquot_claim_block
          ...
           dquot_mark_dquot_dirty // try to dirty old quota
            test_bit(DQ_ACTIVE_B, &dquot->dq_flags) // still ACTIVE
            if (test_bit(DQ_MOD_B, &dquot->dq_flags))
            // test no dirty, wait dq_list_lock
                          ...
                           dquot_transfer
                            __dquot_transfer
                            dqput_all(transfer_from) // rls old dquot
                             dqput // last dqput
                              dquot_release
                               clear_bit(DQ_ACTIVE_B, &dquot->dq_flags)
                              atomic_dec(&dquot->dq_count)
                              put_dquot_last(dquot)
                               list_add_tail(&dquot->dq_free, &free_dquots)
                               // add the dquot to free_dquots
            if (!test_and_set_bit(DQ_MOD_B, &dquot->dq_flags))
              add dqi_dirty_list // add released dquot to dirty_list
      
      This can cause various issues, such as dquot being destroyed by
      dqcache_shrink_scan() after being added to free_dquots, which can trigger
      a UAF in dquot_mark_dquot_dirty(); or after dquot is added to free_dquots
      and then to dirty_list, it is added to free_dquots again after
      dquot_writeback_dquots() is executed, which causes the free_dquots list to
      be corrupted and triggers a UAF when dqcache_shrink_scan() is called for
      freeing dquot twice.
      
      As Honza said, we need to fix dquot_transfer() to follow the guarantees
      dquot_srcu should provide. But calling synchronize_srcu() directly from
      dquot_transfer() is too expensive (and mostly unnecessary). So we add
      dquot whose last reference should be dropped to the new global dquot
      list releasing_dquots, and then queue work item which would call
      synchronize_srcu() and after that perform the final cleanup of all the
      dquots on releasing_dquots.
      
      Fixes: 4580b30e ("quota: Do not dirty bad dquots")
      Suggested-by: default avatarJan Kara <jack@suse.cz>
      Signed-off-by: default avatarBaokun Li <libaokun1@huawei.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <20230630110822.3881712-5-libaokun1@huawei.com>
      dabc8b20
    • Baokun Li's avatar
      quota: add new helper dquot_active() · 33bcfafc
      Baokun Li authored
      Add new helper function dquot_active() to make the code more concise.
      Signed-off-by: default avatarBaokun Li <libaokun1@huawei.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <20230630110822.3881712-4-libaokun1@huawei.com>
      33bcfafc
    • Baokun Li's avatar
      quota: rename dquot_active() to inode_quota_active() · 4b9bdfa1
      Baokun Li authored
      Now we have a helper function dquot_dirty() to determine if dquot has
      DQ_MOD_B bit. dquot_active() can easily be misunderstood as a helper
      function to determine if dquot has DQ_ACTIVE_B bit. So we avoid this by
      renaming it to inode_quota_active() and later on we will add the helper
      function dquot_active() to determine if dquot has DQ_ACTIVE_B bit.
      Signed-off-by: default avatarBaokun Li <libaokun1@huawei.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <20230630110822.3881712-3-libaokun1@huawei.com>
      4b9bdfa1
    • Baokun Li's avatar
      quota: factor out dquot_write_dquot() · 02412847
      Baokun Li authored
      Refactor out dquot_write_dquot() to reduce duplicate code.
      Signed-off-by: default avatarBaokun Li <libaokun1@huawei.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <20230630110822.3881712-2-libaokun1@huawei.com>
      02412847
    • Colin Ian King's avatar
      ext2: remove redundant assignment to variable desc and variable best_desc · 50607b51
      Colin Ian King authored
      Variable desc is being assigned a value that is never read, the exit
      via label found immeditely returns with no access to desc. The
      assignment is redundant and can be removed. Also remove variable best_desc
      since this is not used. Cleans up clang scan muild warning:
      
      fs/ext2/ialloc.c:297:4: warning: Value stored to 'desc' is never
      read [deadcode.DeadStores]
      Signed-off-by: default avatarColin Ian King <colin.i.king@gmail.com>
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Message-Id: <20230630165458.166238-1-colin.i.king@gmail.com>
      50607b51
  8. 02 Jul, 2023 6 commits
    • Linus Torvalds's avatar
      Merge tag 'iomap-6.5-merge-1' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux · a901a356
      Linus Torvalds authored
      Pull iomap updates from Darrick Wong:
      
       - Fix a type signature mismatch
      
       - Drop Christoph as maintainer
      
      * tag 'iomap-6.5-merge-1' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux:
        iomap: drop me [hch] from MAINTAINERS for iomap
        fs: iomap: Change the type of blocksize from 'int' to 'unsigned int' in iomap_file_buffered_write_punch_delalloc
      a901a356
    • Linus Torvalds's avatar
      Merge tag 'v6.5/vfs.fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/vfs/vfs · 28c7980f
      Linus Torvalds authored
      Pull vfs fix from Christian Brauner:
       "A fix for the backing file work from this cycle.
      
        When init_file() failed it would call file_free_rcu() on the file
        allocated by the caller of init_file(). It naively assumed that the
        correct cleanup operation would be called depending on whether it is a
        regular file or a backing file. However, that presupposes that the
        FMODE_BACKING flag would already be set which it won't be as that is
        done in the caller of init_file().
      
        Fix that bug by moving the cleanup of the allocated file into the
        caller where it belongs in the first place. There's no good reason for
        init_file() to consume resources it didn't allocate. This is a
        mainline only fix and was reported by syzbot. The fix was validated by
        syzbot against the provided reproducer"
      
      * tag 'v6.5/vfs.fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/vfs/vfs:
        fs: move cleanup from init_file() into its callers
      28c7980f
    • Linus Torvalds's avatar
      Merge tag 'i2c-for-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux · 5def00ca
      Linus Torvalds authored
      Pull i2c updates from Wolfram Sang:
      
       - I2C has now a co-maintainer taking care of the host drivers. Welcome
         Andi Shyti and have fun!
      
       - platform remove callback converted to return void in drivers
      
       - simplify drivers by using devm_clk_get_enabled()
      
       - introduce i2c_get_match_data() to avoid more boilerplate code
         (especially since the core stopped delivering an i2c_device_id)
      
       - and the usual bunch of driver updates
      
      * tag 'i2c-for-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux: (38 commits)
        i2c: uniphier: Use devm_clk_get_enabled()
        i2c: uniphier-f: Use devm_clk_get_enabled()
        i2c: owl: Use devm_clk_get_enabled()
        i2c: lpc2k: Use devm_clk_get_enabled()
        i2c: hix5hd2: Use devm_clk_get_enabled()
        i2c: sun6i-p2wi: Use devm_clk_get_enabled()
        i2c: pasemi-platform: Use devm_clk_get_enabled()
        i2c: mt7621: Use devm_clk_get_enabled()
        i2c: xiic: Use devm_clk_get_enabled()
        i2c: davinci: Use platform table macro over module_alias
        i2c: ocores: use devm_ managed clks
        i2c: nomadik: Use dev_err_probe() whenever possible
        i2c: nomadik: Use devm_clk_get_enabled()
        i2c: nomadik: Remove unnecessary goto label
        usb: typec: ucsi: Mark dGPUs as DEVICE scope
        i2c: wmt: Use devm_platform_get_and_ioremap_resource()
        i2c: versatile: Use devm_platform_get_and_ioremap_resource()
        i2c: hix5hd2: Add I2C_M_STOP flag support for i2c-hix5hd2 driver.
        i2c: mpc: Use of_property_read_reg() to parse "reg"
        i2c: imx-lpi2c: Don't open-code DIV_ROUND_UP
        ...
      5def00ca
    • Linus Torvalds's avatar
      Merge tag 'parisc-for-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/parisc-linux · ed77ac92
      Linus Torvalds authored
      Pull parisc updates from Helge Deller:
      
       - Add missing cacheflush() syscall
      
       - Fix STI console on 64-bit-only machines
      
       - Move kernel debug options to Kconfig.debug
      
       - Lots of warning fixes in arch/parisc/ and drivers/parisc/ when
         compiled with W=1
      
       - Enable some more graphics drivers in refreshed defconfigs
      
      * tag 'parisc-for-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/parisc-linux: (29 commits)
        parisc: Refresh defconfigs
        parisc: irq: Add irq-related function declarations
        parisc: Move init function declarations into header file
        parisc: dino: Make dino_init() returning void
        parisc: lba_pci: Mark two variables __maybe_unused
        parisc: unaligned: Include header file to avoid missing prototype warnings
        parisc: signal: Mark do_notify_resume() and sys_rt_sigreturn() asmlinkage
        parisc: unwind: Mark start and stop variables __maybe_unused
        parisc: init: Drop unused variable end_paddr
        parisc: traps: Mark functions static
        parisc: processor: Fix kdoc for init_cpu_profiler()
        parisc: sys_parisc: parisc_personality() is called from asm code
        parisc: ccio-dma: Fix kdoc and compiler warnings
        parisc: pdc_stable: Fix kdoc and compiler warnings
        parisc: pci-dma: Make pcxl_alloc_range() static
        parisc: Mark image_size __maybe_unused in perf_write()
        parisc: module: Mark symindex __maybe_unused
        parisc: pdc_chassis: Fix kdoc warnings
        parisc: firmware: Fix kdoc warnings
        parisc: drivers: Fix kdoc warnings
        ...
      ed77ac92
    • Amir Goldstein's avatar
      fs: move cleanup from init_file() into its callers · dff745c1
      Amir Goldstein authored
      The use of file_free_rcu() in init_file() to free the struct that was
      allocated by the caller was hacky and we got what we deserved.
      
      Let init_file() and its callers take care of cleaning up each after
      their own allocated resources on error.
      
      Fixes: 62d53c4a ("fs: use backing_file container for internal files with "fake" f_path") # mainline only
      Reported-and-tested-by: syzbot+ada42aab05cf51b00e98@syzkaller.appspotmail.com
      Signed-off-by: default avatarAmir Goldstein <amir73il@gmail.com>
      Message-Id: <20230701171134.239409-1-amir73il@gmail.com>
      Signed-off-by: default avatarChristian Brauner <brauner@kernel.org>
      dff745c1
    • Linus Torvalds's avatar
      Merge tag 'csky-for-linus-6.5' of https://github.com/c-sky/csky-linux · 995b406c
      Linus Torvalds authored
      Pull arch/csky update from Guo Ren:
      
       - Correct thread.trap_no restore of uprobe
      
      * tag 'csky-for-linus-6.5' of https://github.com/c-sky/csky-linux:
        csky: uprobes: Restore thread.trap_no
      995b406c
  9. 01 Jul, 2023 17 commits
    • Linus Torvalds's avatar
      Merge tag 'nfs-for-6.5-1' of git://git.linux-nfs.org/projects/trondmy/linux-nfs · dfab92f2
      Linus Torvalds authored
      Pull NFS client updates from Trond Myklebust:
      "Stable fixes and other bugfixes:
      
         - nfs: don't report STATX_BTIME in ->getattr
      
         - Revert 'NFSv4: Retry LOCK on OLD_STATEID during delegation return'
           since it breaks NFSv4 state recovery.
      
         - NFSv4.1: freeze the session table upon receiving NFS4ERR_BADSESSION
      
         - Fix the NFSv4.2 xattr cache shrinker_id
      
         - Force a ctime update after a NFSv4.2 SETXATTR call
      
        Features and cleanups:
      
         - NFS and RPC over TLS client code from Chuck Lever
      
         - Support for use of abstract unix socket addresses with the rpcbind
           daemon
      
         - Sysfs API to allow shutdown of the kernel RPC client and prevent
           umount() hangs if the server is known to be permanently down
      
         - XDR cleanups from Anna"
      
      * tag 'nfs-for-6.5-1' of git://git.linux-nfs.org/projects/trondmy/linux-nfs: (33 commits)
        Revert "NFSv4: Retry LOCK on OLD_STATEID during delegation return"
        NFS: Don't cleanup sysfs superblock entry if uninitialized
        nfs: don't report STATX_BTIME in ->getattr
        NFSv4.1: freeze the session table upon receiving NFS4ERR_BADSESSION
        NFSv4.2: fix wrong shrinker_id
        NFSv4: Clean up some shutdown loops
        NFS: Cancel all existing RPC tasks when shutdown
        NFS: add sysfs shutdown knob
        NFS: add a sysfs link to the acl rpc_client
        NFS: add a sysfs link to the lockd rpc_client
        NFS: Add sysfs links to sunrpc clients for nfs_clients
        NFS: add superblock sysfs entries
        NFS: Make all of /sys/fs/nfs network-namespace unique
        NFS: Open-code the nfs_kset kset_create_and_add()
        NFS: rename nfs_client_kobj to nfs_net_kobj
        NFS: rename nfs_client_kset to nfs_kset
        NFS: Add an "xprtsec=" NFS mount option
        NFS: Have struct nfs_client carry a TLS policy field
        SUNRPC: Add a TCP-with-TLS RPC transport class
        SUNRPC: Capture CMSG metadata on client-side receive
        ...
      dfab92f2
    • Linus Torvalds's avatar
      Merge tag 'x86-urgent-2023-07-01' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · f8566aa4
      Linus Torvalds authored
      Pull x86 fix from Thomas Gleixner:
       "A single regression fix for x86:
      
        Moving the invocation of arch_cpu_finalize_init() earlier in the boot
        process caused a boot regression on IBT enabled system.
      
        The root cause is not the move of arch_cpu_finalize_init() itself. The
        system fails to boot because the subsequent efi_enter_virtual_mode()
        code has a non-IBT safe EFI call inside. This was not noticed before
        because IBT was enabled after the EFI initialization.
      
        Switching the EFI call to use the IBT safe wrapper cures the problem"
      
      * tag 'x86-urgent-2023-07-01' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/efi: Make efi_set_virtual_address_map IBT safe
      f8566aa4
    • Linus Torvalds's avatar
      Merge tag 'kbuild-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild · ad288597
      Linus Torvalds authored
      Pull Kbuild updates from Masahiro Yamada:
      
       - Remove the deprecated rule to build *.dtbo from *.dts
      
       - Refactor section mismatch detection in modpost
      
       - Fix bogus ARM section mismatch detections
      
       - Fix error of 'make gtags' with O= option
      
       - Add Clang's target triple to KBUILD_CPPFLAGS to fix a build error
         with the latest LLVM version
      
       - Rebuild the built-in initrd when KBUILD_BUILD_TIMESTAMP is changed
      
       - Ignore more compiler-generated symbols for kallsyms
      
       - Fix 'make local*config' to handle the ${CONFIG_FOO} form in Makefiles
      
       - Enable more kernel-doc warnings with W=2
      
       - Refactor <linux/export.h> by generating KSYMTAB data by modpost
      
       - Deprecate <asm/export.h> and <asm-generic/export.h>
      
       - Remove the EXPORT_DATA_SYMBOL macro
      
       - Move the check for static EXPORT_SYMBOL back to modpost, which makes
         the build faster
      
       - Re-implement CONFIG_TRIM_UNUSED_KSYMS with one-pass algorithm
      
       - Warn missing MODULE_DESCRIPTION when building modules with W=1
      
       - Make 'make clean' robust against too long argument error
      
       - Exclude more objects from GCOV to fix CFI failures with GCOV
      
       - Allow 'make modules_install' to install modules.builtin and
         modules.builtin.modinfo even when CONFIG_MODULES is disabled
      
       - Include modules.builtin and modules.builtin.modinfo in the
         linux-image Debian package even when CONFIG_MODULES is disabled
      
       - Revive "Entering directory" logging for the latest Make version
      
      * tag 'kbuild-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild: (72 commits)
        modpost: define more R_ARM_* for old distributions
        kbuild: revive "Entering directory" for Make >= 4.4.1
        kbuild: set correct abs_srctree and abs_objtree for package builds
        scripts/mksysmap: Ignore prefixed KCFI symbols
        kbuild: deb-pkg: remove the CONFIG_MODULES check in buildeb
        kbuild: builddeb: always make modules_install, to install modules.builtin*
        modpost: continue even with unknown relocation type
        modpost: factor out Elf_Sym pointer calculation to section_rel()
        modpost: factor out inst location calculation to section_rel()
        kbuild: Disable GCOV for *.mod.o
        kbuild: Fix CFI failures with GCOV
        kbuild: make clean rule robust against too long argument error
        script: modpost: emit a warning when the description is missing
        kbuild: make modules_install copy modules.builtin(.modinfo)
        linux/export.h: rename 'sec' argument to 'license'
        modpost: show offset from symbol for section mismatch warnings
        modpost: merge two similar section mismatch warnings
        kbuild: implement CONFIG_TRIM_UNUSED_KSYMS without recursion
        modpost: use null string instead of NULL pointer for default namespace
        modpost: squash sym_update_namespace() into sym_add_exported()
        ...
      ad288597
    • Linus Torvalds's avatar
      Merge tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux · e3c2b10d
      Linus Torvalds authored
      Pull arm64 fix from Catalin Marinas:
       "Fix memory corruption (overwriting the kmalloc redzone) when saving
        the SVE state while in SVE streaming mode"
      
      * tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux:
        arm64: sme: Use STR P to clear FFR context field in streaming SVE mode
      e3c2b10d
    • Linus Torvalds's avatar
      Merge tag 'cxl-for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/cxl/cxl · d25f0025
      Linus Torvalds authored
      Pull CXL updates from Dan Williams:
       "The highlights in terms of new functionality are support for the
        standard CXL Performance Monitor definition that appeared in CXL 3.0,
        support for device sanitization (wiping all data from a device),
        secure-erase (re-keying encryption of user data), and support for
        firmware update. The firmware update support is notable as it reuses
        the simple sysfs_upload interface to just cat(1) a blob to a sysfs
        file and pipe that to the device.
      
        Additionally there are a substantial number of cleanups and
        reorganizations to get ready for RCH error handling (RCH == Restricted
        CXL Host == current shipping hardware generation / pre CXL-2.0
        topologies) and type-2 (accelerator / vendor specific) devices.
      
        For vendor specific devices they implement a subset of what the
        generic type-3 (generic memory expander) driver expects. As a result
        the rework decouples optional infrastructure from the core driver
        context.
      
        For RCH topologies, where the specification working group did not want
        to confuse pre-CXL-aware operating systems, many of the standard
        registers are hidden which makes support standard bus features like
        AER (PCIe Advanced Error Reporting) difficult. The rework arranges for
        the driver to help the PCI-AER core. Bjorn is on board with this
        direction but a late regression disocvery means the completion of this
        functionality needs to cook a bit longer, so it is code
        reorganizations only for now.
      
        Summary:
      
         - Add infrastructure for supporting background commands along with
           support for device sanitization and firmware update
      
         - Introduce a CXL performance monitoring unit driver based on the
           common definition in the specification.
      
         - Land some preparatory cleanup and refactoring for the anticipated
           arrival of CXL type-2 (accelerator devices) and CXL RCH (CXL-v1.1
           topology) error handling.
      
         - Rework CPU cache management with respect to region configuration
           (device hotplug or other dynamic changes to memory interleaving)
      
         - Fix region reconfiguration vs CXL decoder ordering rules"
      
      * tag 'cxl-for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/cxl/cxl: (51 commits)
        cxl: Fix one kernel-doc comment
        cxl/pci: Use correct flag for sanitize polling
        docs: perf: Minimal introduction the the CXL PMU device and driver
        perf: CXL Performance Monitoring Unit driver
        tools/testing/cxl: add firmware update emulation to CXL memdevs
        tools/testing/cxl: Use named effects for the Command Effect Log
        tools/testing/cxl: Fix command effects for inject/clear poison
        cxl: add a firmware update mechanism using the sysfs firmware loader
        cxl/test: Add Secure Erase opcode support
        cxl/mem: Support Secure Erase
        cxl/test: Add Sanitize opcode support
        cxl/mem: Wire up Sanitization support
        cxl/mbox: Add sanitization handling machinery
        cxl/mem: Introduce security state sysfs file
        cxl/mbox: Allow for IRQ_NONE case in the isr
        Revert "cxl/port: Enable the HDM decoder capability for switch ports"
        cxl/memdev: Formalize endpoint port linkage
        cxl/pci: Unconditionally unmask 256B Flit errors
        cxl/region: Manage decoder target_type at decoder-attach time
        cxl/hdm: Default CXL_DEVTYPE_DEVMEM decoders to CXL_DECODER_DEVMEM
        ...
      d25f0025
    • Linus Torvalds's avatar
      Merge tag 'libnvdimm-for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm · 0a1c979c
      Linus Torvalds authored
      Pull nvdimm and DAX updates from Vishal Verma:
       "This is mostly small cleanups and fixes, with the biggest change being
        the change to the DAX fault handler allowing it to return
        VM_FAULT_HWPOISON.
      
        Summary:
      
         - DAX fixes and cleanups including a use after free, extra
           references, and device unregistration, and a redundant variable.
      
         - Allow the DAX fault handler to return VM_FAULT_HWPOISON
      
         - A few libnvdimm cleanups such as making some functions and
           variables static where sufficient.
      
         - Add a few missing prototypes for wrapped functions in
           tools/testing/nvdimm"
      
      * tag 'libnvdimm-for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm:
        dax: enable dax fault handler to report VM_FAULT_HWPOISON
        nvdimm: make security_show static
        nvdimm: make nd_class variable static
        dax/kmem: Pass valid argument to memory_group_register_static
        fsdax: remove redundant variable 'error'
        dax: Cleanup extra dax_region references
        dax: Introduce alloc_dev_dax_id()
        dax: Use device_unregister() in unregister_dax_mapping()
        dax: Fix dax_mapping_release() use after free
        tools/testing/nvdimm: Drop empty platform remove function
        libnvdimm: mark 'security_show' static again
        testing: nvdimm: add missing prototypes for wrapped functions
        dax: fix missing-prototype warnings
      0a1c979c
    • Linus Torvalds's avatar
      Merge tag 'sysctl-fixes-v2-v6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux · be21a73e
      Linus Torvalds authored
      Pull another sysctl fix from Luis Chamberlain:
       "Just one minor nit I forgot to merge"
      
      * tag 'sysctl-fixes-v2-v6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux:
        sysctl: set variable sysctl_mount_point storage-class-specifier to static
      be21a73e
    • Linus Torvalds's avatar
      Merge tag 'flex-array-transformations-6.5-rc1' of... · 170ab6c5
      Linus Torvalds authored
      Merge tag 'flex-array-transformations-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gustavoars/linux
      
      Pull flexible-array update from Gustavo Silva:
       "Transform a zero-length array into a C99 flexible-array member.
      
        This addresses a build failure with Clang by fixing multiple
        '-Warray-bounds' warnings in drivers/staging/ks7010/ks_wlan_net.c"
      
      * tag 'flex-array-transformations-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gustavoars/linux:
        uapi: wireless: Replace zero-length array with flexible-array member
      170ab6c5
    • Christian Brauner's avatar
      pid: use struct_size_t() helper · dd546618
      Christian Brauner authored
      Before commit d67790dd ("overflow: Add struct_size_t() helper") only
      struct_size() existed, which expects a valid pointer instance containing
      the flexible array.
      
      However, when we determine the default struct pid allocation size for
      the associated kmem cache of a pid namespace we need to take the nesting
      depth of the pid namespace into account without an variable instance
      necessarily being available.
      
      In commit b69f0aeb ("pid: Replace struct pid 1-element array with
      flex-array") we used to handle this the old fashioned way and cast NULL
      to a struct pid pointer type. However, we do apparently have a dedicated
      struct_size_t() helper for exactly this case. So switch to that.
      Suggested-by: default avatarKees Cook <keescook@chromium.org>
      Suggested-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      Signed-off-by: default avatarChristian Brauner <brauner@kernel.org>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      dd546618
    • Liam R. Howlett's avatar
      mm: Update do_vmi_align_munmap() return semantics · 408579cd
      Liam R. Howlett authored
      Since do_vmi_align_munmap() will always honor the downgrade request on
      the success, the callers no longer have to deal with confusing return
      codes.  Since all callers that request downgrade actually want the lock
      to be dropped, change the downgrade to an unlock request.
      
      Note that the lock still needs to be held in read mode during the page
      table clean up to avoid races with a map request.
      
      Update do_vmi_align_munmap() to return 0 for success.  Clean up the
      callers and comments to always expect the unlock to be honored on the
      success path.  The error path will always leave the lock untouched.
      
      As part of the cleanup, the wrapper function do_vmi_munmap() and callers
      to the wrapper are also updated.
      Suggested-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      Link: https://lore.kernel.org/linux-mm/20230629191414.1215929-1-willy@infradead.org/Signed-off-by: default avatarLiam R. Howlett <Liam.Howlett@oracle.com>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      408579cd
    • Matthew Wilcox (Oracle)'s avatar
      mm: Always downgrade mmap_lock if requested · e4bd84c0
      Matthew Wilcox (Oracle) authored
      Now that stack growth must always hold the mmap_lock for write, we can
      always downgrade the mmap_lock to read and safely unmap pages from the
      page table, even if we're next to a stack.
      Signed-off-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      e4bd84c0
    • Max Filippov's avatar
      xtensa: fix lock_mm_and_find_vma in case VMA not found · 03f88937
      Max Filippov authored
      MMU version of lock_mm_and_find_vma releases the mm lock before
      returning when VMA is not found. Do the same in noMMU version.
      This fixes hang on an attempt to handle protection fault.
      
      Fixes: d85a143b ("xtensa: fix NOMMU build with lock_mm_and_find_vma() conversion")
      Signed-off-by: default avatarMax Filippov <jcmvbkbc@gmail.com>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      03f88937
    • Linus Torvalds's avatar
      Merge tag '6.5-rc-smb3-client-fixes-part1' of git://git.samba.org/sfrench/cifs-2.6 · a507db1d
      Linus Torvalds authored
      Pull smb client updates from Steve French:
      
       - Deferred close fix
      
       - Debugging improvements: display missing mount option, dump rc on
         invalidate inode failures, print client_guid in DebugData, log
         session id when matching session not found in reconnect, new dynamic
         tracepoint for session not found
      
       - Mount fixes including: potential null dereference, and possible
         memory leak and path name parsing when double slashes
      
       - Fix potential use after free in compounding
      
       - Two crediting (flow control) fixes: fix for crediting leak (stress
         scenario with excess lease credits) and better locking around
         updating credits
      
       - Three cleanups from issues pointed out by the kernel test robot
      
       - Session state check improvements (including for potential use after
         free)
      
       - DFS fixes: Fix for getattr on link when DFS disabled, fix for DFS
         mounts to same share with different prefix paths, DFS mount error
         checking improvement
      
      * tag '6.5-rc-smb3-client-fixes-part1' of git://git.samba.org/sfrench/cifs-2.6:
        cifs: new dynamic tracepoint to track ses not found errors
        cifs: log session id when a matching ses is not found
        smb: client: improve DFS mount check
        smb: client: fix shared DFS root mounts with different prefixes
        smb: client: fix parsing of source mount option
        smb: client: fix broken file attrs with nodfs mounts
        cifs: print client_guid in DebugData
        cifs: fix session state check in smb2_find_smb_ses
        cifs: fix session state check in reconnect to avoid use-after-free issue
        cifs: do all necessary checks for credits within or before locking
        cifs: prevent use-after-free by freeing the cfile later
        smb: client: fix warning in generic_ip_connect()
        smb: client: fix warning in CIFSFindNext()
        smb: client: fix warning in CIFSFindFirst()
        smb3: do not reserve too many oplock credits
        cifs: print more detail when invalidate_inode_mapping fails
        smb: client: fix warning in cifs_smb3_do_mount()
        smb: client: fix warning in cifs_match_super()
        cifs: print nosharesock value while dumping mount options
        SMB3: Do not send lease break acknowledgment if all file handles have been closed
      a507db1d
    • Linus Torvalds's avatar
      Merge tag '6.5-rc-ksmbd-server-fixes-part1' of git://git.samba.org/ksmbd · 8976e9d0
      Linus Torvalds authored
      Pull ksmbd server updates from Steve French:
      
       - two fixes for compounding bugs (make sure no out of bound reads with
         less common combinations of commands in the compound)
      
       - eight minor cleanup patches (e.g. simplifying return values, replace
         one element array, use of kzalloc where simpler)
      
       - fix for clang warning on possible overflow in filename conversion
      
      * tag '6.5-rc-ksmbd-server-fixes-part1' of git://git.samba.org/ksmbd:
        ksmbd: avoid field overflow warning
        ksmbd: Replace one-element array with flexible-array member
        ksmbd: Use struct_size() helper in ksmbd_negotiate_smb_dialect()
        ksmbd: add missing compound request handing in some commands
        ksmbd: fix out of bounds read in smb2_sess_setup
        ksmbd: Replace the ternary conditional operator with min()
        ksmbd: use kvzalloc instead of kvmalloc
        ksmbd: Change the return value of ksmbd_vfs_query_maximal_access to void
        ksmbd: return a literal instead of 'err' in ksmbd_vfs_kern_path_locked()
        ksmbd: use kzalloc() instead of __GFP_ZERO
        ksmbd: remove unused ksmbd_tree_conn_share function
      8976e9d0
    • Linus Torvalds's avatar
      Merge tag 'nfsd-6.5-1' of git://git.kernel.org/pub/scm/linux/kernel/git/cel/linux · ee152be1
      Linus Torvalds authored
      Pull nfsd fix from Chuck Lever:
      
       - Fix ordering of attributes in NFSv4 GETATTR replies
      
      * tag 'nfsd-6.5-1' of git://git.kernel.org/pub/scm/linux/kernel/git/cel/linux:
        nfsd: Fix creation time serialization order
      ee152be1
    • Linus Torvalds's avatar
      Merge tag 'livepatching-for-6.5' of... · f4ce392b
      Linus Torvalds authored
      Merge tag 'livepatching-for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/livepatching/livepatching
      
      Pull livepatching update from Petr Mladek:
      
       - Make a variable static to fix a sparse warning
      
      * tag 'livepatching-for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/livepatching/livepatching:
        livepatch: Make 'klp_stack_entries' static
      f4ce392b
    • Linus Torvalds's avatar
      Merge tag 'efi-next-for-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/efi/efi · 937d96d2
      Linus Torvalds authored
      Pull EFI updates from Ard Biesheuvel:
       "Although some more stuff is brewing, the EFI changes that are ready
        for mainline are few this cycle:
      
         - improve the PCI DMA paranoia logic in the EFI stub
      
         - some constification changes
      
         - add statfs support to efivarfs
      
         - allow user space to enumerate updatable firmware resources without
           CAP_SYS_ADMIN"
      
      * tag 'efi-next-for-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/efi/efi:
        efi/libstub: Disable PCI DMA before grabbing the EFI memory map
        efi/esrt: Allow ESRT access without CAP_SYS_ADMIN
        efivarfs: expose used and total size
        efi: make kobj_type structure constant
        efi: x86: make kobj_type structure constant
      937d96d2