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, Apr 16, 5:00 PM
Unknown Object (File)
Sun, Mar 31, 8:35 AM
Unknown Object (File)
Mar 5 2024, 2:04 PM
Unknown Object (File)
Dec 20 2023, 7:08 AM
Unknown Object (File)
Nov 27 2023, 12:47 AM
Unknown Object (File)
Nov 23 2023, 8:14 AM
Unknown Object (File)
Nov 22 2023, 1:46 PM
Unknown Object (File)
Nov 21 2023, 8:15 AM
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.