Page MenuHomeFreeBSD

Fix up getlocalbase() implementation
Needs ReviewPublic

Authored by scottl on Nov 15 2020, 7:03 PM.
Tags
None
Referenced Files
F108230736: D27227.diff
Wed, Jan 22, 9:49 PM
Unknown Object (File)
Tue, Jan 14, 7:10 AM
Unknown Object (File)
Dec 4 2024, 9:21 AM
Unknown Object (File)
Nov 25 2024, 11:03 PM
Unknown Object (File)
Oct 10 2024, 11:45 AM
Unknown Object (File)
Oct 2 2024, 12:08 PM
Unknown Object (File)
Sep 27 2024, 3:09 AM
Unknown Object (File)
Sep 22 2024, 4:16 AM
Subscribers

Details

Reviewers
jrtc27
bapt
bdrewery
Group Reviewers
Restricted Owners Package(Owns No Changed Paths)
Summary

There are several problems with data types, casts, and checks in
getlocalbase(). This attempts to fix them

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 34808
Build 31850: arc lint + arc unit

Event Timeline

lib/libutil/getlocalbase.c
80

strlcpy doesn't include the NUL so this to stay >=.

lib/libutil/getlocalbase.c
54

This should probably be EINVAL (and could then be folded into the previous if).

Fix items suggested by Jessica, move to sysctlnametomib() to account for
inconsistencies in the user/kernel interface

Owners added a reviewer: Restricted Owners Package.Nov 15 2020, 7:54 PM
lib/libutil/getlocalbase.c
66

miblen is currently uninitialised before the call; presumably it works because it's reading random garbage on the stack that's most likely >= 2. You should probably also be checking the return value here.