[PATCH v3 0/5] Fix bugs in extract_iter_to_sg()

Christian A. Ehrhardt posted 5 patches 6 days, 19 hours ago
lib/scatterlist.c          |   8 +-
lib/tests/kunit_iov_iter.c | 224 +++++++++++++++++++++++++++++++++++--
2 files changed, 221 insertions(+), 11 deletions(-)
[PATCH v3 0/5] Fix bugs in extract_iter_to_sg()
Posted by Christian A. Ehrhardt 6 days, 19 hours ago
Fix bugs in the kvec and user variants of extract_iter_to_sg.
This series is growing due to useful remarks made by sashiko.dev.

The main bugs are:
- The length for an sglist entry when extracting from
  a kvec can exceed the number of bytes in the page. This
  is obviously not intended.
- When extracting a user buffer the sglist is temporarily
  used as a scratch buffer for extracted page pointers.
  If the sglist already contains some elements this scratch
  buffer could overlap with existing entries in the sglist.

The series adds test cases to the kunit_iov_iter test that
demonstrate all of these bugs. Additionally, there is a
memory leak fix for the test itself.

The bugs were orignally introduced into kernel v6.3 where the
function lived in fs/netfs/iterator.c. It was later moved
to lib/scatterlist.c in v6.5. Thus the actual fix is only
marked for backports to v6.5+.

---
Changes in v2:
Addresss valid issues raised by AI review
https://sashiko.dev/#/patchset/20260323212350.807118-1-lk@c--e.de:
- Add kunit assertions for OOM conditions in the test
- Reorder commits.
- Fix sg_max == 0 case.
- Fix return value if we run out of sg entries.
- Adjust tests to catch these cases, too.

Changes in v3:
- Add fix and test for extract_user_to_sg()
- Fix memory leak in the unit test.
- Re-order commits: Code fixes first, then tests.
---

Christian A. Ehrhardt (5):
  lib/scatterlist: Fix length calculations in extract_kvec_to_sg
  lib/scatterlist: Fix temp buffer in extract_user_to_sg()
  lib: kunit_iov_iter: Fix memory leaks
  lib: kunit_iov_iter: Improve error detection
  lib: kunit_iov_iter: Add tests for extract_iter_to_sg

 lib/scatterlist.c          |   8 +-
 lib/tests/kunit_iov_iter.c | 224 +++++++++++++++++++++++++++++++++++--
 2 files changed, 221 insertions(+), 11 deletions(-)

-- 
2.43.0
Re: [PATCH v3 0/5] Fix bugs in extract_iter_to_sg()
Posted by Andrew Morton 6 days, 18 hours ago
On Thu, 26 Mar 2026 22:49:00 +0100 "Christian A. Ehrhardt" <lk@c--e.de> wrote:

> Fix bugs in the kvec and user variants of extract_iter_to_sg.
> This series is growing due to useful remarks made by sashiko.dev.
> 
> The main bugs are:
> - The length for an sglist entry when extracting from
>   a kvec can exceed the number of bytes in the page. This
>   is obviously not intended.
> - When extracting a user buffer the sglist is temporarily
>   used as a scratch buffer for extracted page pointers.
>   If the sglist already contains some elements this scratch
>   buffer could overlap with existing entries in the sglist.
> 
> The series adds test cases to the kunit_iov_iter test that
> demonstrate all of these bugs. Additionally, there is a
> memory leak fix for the test itself.
> 
> The bugs were orignally introduced into kernel v6.3 where the
> function lived in fs/netfs/iterator.c. It was later moved
> to lib/scatterlist.c in v6.5. Thus the actual fix is only
> marked for backports to v6.5+.

Great.  I'll add this to mm.git's mm-unstable branch, targetting an
upstream merge into 7.1-rc1.

As far as I understand, this means that the cc:stable patches will be
presented to the -stable maintainers some time after that upstreaming. 
I don't believe that more urgency is needed.

DavidH, please review the sg changes?

DavidG, please check the kunit changes?

Thanks all.