Page MenuHomeFreeBSD

Return different error code for the guard page layout violation.
ClosedPublic

Authored by kib on Nov 21 2017, 10:01 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Dec 30, 4:34 AM
Unknown Object (File)
Dec 11 2025, 8:18 PM
Unknown Object (File)
Nov 20 2025, 9:45 PM
Unknown Object (File)
Nov 20 2025, 9:44 PM
Unknown Object (File)
Nov 20 2025, 9:44 PM
Unknown Object (File)
Nov 20 2025, 9:43 PM
Unknown Object (File)
Nov 20 2025, 9:35 PM
Unknown Object (File)
Oct 23 2025, 8:42 PM
Subscribers

Diff Detail

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

Event Timeline

sys/vm/vm_map.c
3619–3621 ↗(On Diff #35568)

vm_map_insert() returns KERN_INVALID_ARGUMENT for all of these errors. I would argue that this function should do the same, both for consistency with vm_map_insert() and because KERN_INVALID_ARGUMENT better describes these errors.

Also, vm_map_insert() has a slighyly different "max" check. The equivalent would be "addrbos + max_ssize > vm_map_max(map)".

sys/vm/vm_map.c
3619–3621 ↗(On Diff #35568)

vm_map_insert()'s address wrap check also uses <= rather than <.

Duplicate the vm_map_insert() behavior for error checking WRT the address range checking.

I've skimmed the code for both this function and vm_map_insert(), and I believe that both the error checks and their corresponding return values are now consistent.

This revision is now accepted and ready to land.Nov 22 2017, 4:19 PM
This revision was automatically updated to reflect the committed changes.