kernel/vm: Do not assume "no user protection" means "kernel area".
It's entirely possible that we have a user area with a page that has protections of 0 (e.g. a guard page). In that case we should print the standard read/write fault message instead of "kernel" fault messages. This should not be a major behavioral change, only the syslog and tracing entries should be affected; such memory accesses should be caught by the read/write permissions checks immediately following.
This commit is contained in:
parent
3a81e9446d
commit
63664eaa21
@ -4725,7 +4725,8 @@ vm_soft_fault(VMAddressSpace* addressSpace, addr_t originalAddress,
|
|||||||
|
|
||||||
// check permissions
|
// check permissions
|
||||||
uint32 protection = get_area_page_protection(area, address);
|
uint32 protection = get_area_page_protection(area, address);
|
||||||
if (isUser && (protection & B_USER_PROTECTION) == 0) {
|
if (isUser && (protection & B_USER_PROTECTION) == 0
|
||||||
|
&& (area->protection & B_KERNEL_AREA) != 0) {
|
||||||
dprintf("user access on kernel area 0x%" B_PRIx32 " at %p\n",
|
dprintf("user access on kernel area 0x%" B_PRIx32 " at %p\n",
|
||||||
area->id, (void*)originalAddress);
|
area->id, (void*)originalAddress);
|
||||||
TPF(PageFaultError(area->id,
|
TPF(PageFaultError(area->id,
|
||||||
|
Loading…
Reference in New Issue
Block a user