Page MenuHomeFreeBSD

libc: Add missing size check to qsort_s(3)
ClosedPublic

Authored by hselasky on Apr 19 2023, 10:24 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Dec 13, 1:01 AM
Unknown Object (File)
Dec 9 2024, 9:57 AM
Unknown Object (File)
Nov 28 2024, 5:03 AM
Unknown Object (File)
Nov 19 2024, 8:07 PM
Unknown Object (File)
Nov 17 2024, 6:04 AM
Unknown Object (File)
Nov 17 2024, 3:11 AM
Unknown Object (File)
Nov 13 2024, 10:12 AM
Unknown Object (File)
Oct 28 2024, 8:13 AM
Subscribers
None

Details

Summary

I find it very strange both the C11 standard
(ISO/IEC 9899:2011, K.3.6.3.2) and the ISO/IEC JTC1 SC22 WG14 N1172 standard,
does not define sorting an array having objects of zero size,
as undefined behaviour.

Add proper checks for this. Found while working on bsort(3).

MFC after: 1 week
Sponsored by: NVIDIA Networking

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

hselasky created this revision.

Can I have a quick go on this one?

The qsort code actually use the object size for advancing for loops, so clearly we should catch this regardless of ISO definitions.

Interesting, https://en.cppreference.com/w/c/algorithm/qsort

Unlike other bounds-checked functions, qsort_s does not treat arrays of zero size as a runtime constraint violation and instead returns successfully without altering the array

I'd take this to mean n == 0 but I think it's ambiguous; their previous use of size is in reference to element size.

But Microsoft's docs https://github.com/MicrosoftDocs/cpp-docs/blob/main/docs/c-runtime-library/reference/qsort-s.md explicitly show width <= 0 as EINVAL.

I think your change is good.

kib added inline comments.
lib/libc/stdlib/qsort.3
273
This revision is now accepted and ready to land.Apr 19 2023, 1:18 PM

@emaste : "<= 0" is for the future, in case the type changes to be signed.

@emaste : "<= 0" is for the future, in case the type changes to be signed.

Yep, my point is just that the MS docs already have exactly this case.

hselasky marked an inline comment as done.

Thank you for your reviews!