Page MenuHomeFreeBSD

MAC/do: Better parsing for IDs (strtoui_strict())
ClosedPublic

Authored by olce on Nov 15 2024, 5:08 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Dec 30, 11:00 AM
Unknown Object (File)
Sun, Dec 29, 5:44 PM
Unknown Object (File)
Sat, Dec 28, 7:36 AM
Unknown Object (File)
Fri, Dec 27, 6:36 AM
Unknown Object (File)
Fri, Dec 27, 6:18 AM
Unknown Object (File)
Thu, Dec 26, 12:42 PM
Unknown Object (File)
Fri, Dec 13, 3:32 AM
Unknown Object (File)
Dec 12 2024, 7:52 AM

Details

Summary

This revision is part of a series. Click on the Stack tab below to see the context.
This series has also been squeezed into D47633 to provide an overall view.

Commit message:
Introduce strtoui_strict(), which signals an error on overflow contrary
to the in-kernel strto*() family of functions which have no 'errno' to
set and thus do not allow callers to distinguish a genuine maximum value
on input and overflow.

It is built on top of strtoq() and the 'quad_t' type in order to achieve
this distinction and also to still support negative inputs with the
usual meaning for these functions. See the introduced comments for more
details.

Use strtoui_strict() to read IDs instead of strtol().

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 60809
Build 57693: arc lint + arc unit

Event Timeline

olce requested review of this revision.Nov 15 2024, 5:08 PM
This revision is now accepted and ready to land.Nov 19 2024, 8:06 AM
olce retitled this revision from MAC/do: Better parsing for IDs to MAC/do: Better parsing for IDs (strtoui_strict()).
olce edited the summary of this revision. (Show Details)

Replace strtonni with strotui_strict().

This is a followup to the change in D47613 (u_int used for IDs). Took the
occasion to provide a better implementation that supports negative number
specifications (as strtou*() standard functions do).

This revision now requires review to proceed.Nov 27 2024, 1:58 PM

Remove a redundant check that was forgotten in the previous update.

This revision is now accepted and ready to land.Dec 2 2024, 8:57 AM