Page MenuHomeFreeBSD

getentropy(3): Fallback to kern.arandom sysctl on older kernels
ClosedPublic

Authored by cem on Mar 21 2018, 5:20 PM.
Tags
None
Referenced Files
F108645477: D14785.diff
Mon, Jan 27, 1:37 AM
F108598805: D14785.id40575.diff
Sun, Jan 26, 7:01 PM
Unknown Object (File)
Dec 26 2024, 7:20 AM
Unknown Object (File)
Dec 8 2024, 8:28 AM
Unknown Object (File)
Dec 6 2024, 10:40 PM
Unknown Object (File)
Dec 4 2024, 9:00 PM
Unknown Object (File)
Nov 23 2024, 7:56 PM
Unknown Object (File)
Nov 11 2024, 2:19 PM
Subscribers

Details

Summary

On older kernels, when userspace program disables SIGSYS, catch ENOSYS and
emulate getrandom(2) syscall with the kern.arandom sysctl (via existing
arc4_sysctl wrapper). Some special care is taken to faithfully emulate EFAULT
on NULL pointers, because sysctl(3) as used by kern.arandom ignores them.
(This was caught by getentropy(3) ATF tests.)

Test Plan

Run getentropy(3) ATF test suite against a new libc and old kernel. Observe
all tests pass.

Diff Detail

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

Event Timeline

lib/libc/gen/Symbol.map
549 ↗(On Diff #40553)

I do not understand why do you need this symbol exported.

Also, if you want to hide the symbol from static linking, put two '_' before the alphabetical symbol.

lib/libc/gen/Symbol.map
549 ↗(On Diff #40553)

If it is not needed for the symbol to have visibility in getentropy.c, I will just remove it. I am not very familiar with how we use linker maps in libc, sorry.

Since linker maps apply only to dynamic libraries, you are suggesting the function be renamed to have two underscores, in addition to removing the entry from Symbol.map — right? I will go ahead and make both changes.

cem marked 2 inline comments as done.

Per kib:

  • Remove exported arc4_sysctl symbol
  • Use double-underscore in libc-private arc4_sysctl
This revision is now accepted and ready to land.Mar 21 2018, 8:57 PM
This revision was automatically updated to reflect the committed changes.