Page MenuHomeFreeBSD

Don't kill pid -1 on overflow from strtol(3).
ClosedPublic

Authored by bdrewery on Mar 4 2017, 9:24 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Dec 23, 3:32 AM
Unknown Object (File)
Mon, Dec 23, 2:18 AM
Unknown Object (File)
Sun, Dec 22, 10:28 PM
Unknown Object (File)
Sun, Dec 22, 10:54 AM
Unknown Object (File)
Dec 2 2024, 4:37 PM
Unknown Object (File)
Dec 2 2024, 4:37 PM
Unknown Object (File)
Dec 2 2024, 4:37 PM
Unknown Object (File)
Dec 2 2024, 4:37 PM
Subscribers
None

Details

Summary

Store the result in a proper long and then compare to the proper pid_t
for overflow, so that no MD assumptions are made.

MFC after: 2 weeks

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

bdrewery retitled this revision from to Don't kill pid -1 on overflow from strtol(3)..
bdrewery updated this object.
bdrewery edited the test plan for this revision. (Show Details)
bdrewery added a reviewer: jilles.
jilles requested changes to this revision.Mar 4 2017, 9:57 PM
jilles edited edge metadata.

This is correct for architectures where int and long are the same size, but otherwise there may still be surprising behaviour with strings like 4294967295.

The return value of strtol() should be stored into a variable of type long (or a type with at least that range). With the current code's use of int for pid, it is easy to check the range.

With pid_t, the alternative (in improper style)

long parsed = strtol(...);
pid_t pid = (pid_t)parsed;
if (... || pid != parsed)
    errx(...);

may raise an implementation-defined signal in case of overflow, per C11. GCC and Clang work as expected, though.

This revision now requires changes to proceed.Mar 4 2017, 9:57 PM
bdrewery edited edge metadata.

Store strtol() result in long and compare to pid_t.

bdrewery edited edge metadata.
jilles edited edge metadata.
This revision is now accepted and ready to land.Mar 5 2017, 9:51 PM
This revision was automatically updated to reflect the committed changes.