Page MenuHomeFreeBSD

syscalls.master: align with sigfastblock declaration
ClosedPublic

Authored by brooks on Mar 15 2024, 10:45 PM.
Tags
None
Referenced Files
Unknown Object (File)
Nov 28 2024, 11:55 AM
Unknown Object (File)
Nov 28 2024, 11:55 AM
Unknown Object (File)
Nov 28 2024, 11:51 AM
Unknown Object (File)
Nov 28 2024, 11:40 AM
Unknown Object (File)
Nov 14 2024, 10:22 PM
Unknown Object (File)
Oct 8 2024, 9:20 AM
Unknown Object (File)
Sep 19 2024, 2:23 AM
Unknown Object (File)
Sep 18 2024, 5:20 PM
Subscribers

Details

Summary

sigfastblock is declared to take a void * argument in the manpage in
headers so declare it that way and use SAL annotations to say it
interacts with a 32-bit word.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 56633
Build 53521: arc lint + arc unit

Event Timeline

What exactly does the 'updates_bytes_opt' mean? Note that the intent is not that the syscall updates *ptr, but that *ptr is updated async by kernel after the syscall.

In D44379#1012168, @kib wrote:

What exactly does the 'updates_bytes_opt' mean? Note that the intent is not that the syscall updates *ptr, but that *ptr is updated async by kernel after the syscall.

In this context _updates_ means both reads and writes. Given the operations seem it be casueword32, that's correct. In this case I mostly want to express that the pointer is 4 bytes after losing the type. Any consumer of the annotations is almost certainly going to have to add special handing for this case so I'm not worried about the fact that it's async. The alternative would be to update the declaration to be uint32_t *ptr.

This revision is now accepted and ready to land.Mar 18 2024, 7:52 PM