_user_set_area_protection() did not set any B_KERNEL_*_AREA protection.

_user_create_area() and _user_clone_area() now inherit the read/write protection
for the kernel, too - before, it was always mapped read/write in the kernel,
but there is no reason to do that.


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@10214 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2004-11-24 18:57:20 +00:00
parent 4bc2682135
commit f19955303e

View File

@ -2992,7 +2992,9 @@ _user_set_area_protection(area_id area, uint32 newProtection)
if ((newProtection & ~B_USER_PROTECTION) != 0) if ((newProtection & ~B_USER_PROTECTION) != 0)
return B_BAD_VALUE; return B_BAD_VALUE;
return vm_set_area_protection(vm_get_current_user_aspace_id(), area, newProtection); return vm_set_area_protection(vm_get_current_user_aspace_id(), area,
newProtection | B_KERNEL_READ_AREA
| (newProtection & B_WRITE_AREA ? B_KERNEL_WRITE_AREA : 0));
} }
@ -3027,7 +3029,7 @@ _user_clone_area(const char *userName, void **userAddress, uint32 addressSpec,
return B_BAD_ADDRESS; return B_BAD_ADDRESS;
clonedArea = vm_clone_area(vm_get_current_user_aspace_id(), name, &address, clonedArea = vm_clone_area(vm_get_current_user_aspace_id(), name, &address,
addressSpec, protection | B_KERNEL_READ_AREA | B_KERNEL_WRITE_AREA, addressSpec, protection | B_KERNEL_READ_AREA | (protection & B_WRITE_AREA ? B_KERNEL_WRITE_AREA : 0),
REGION_NO_PRIVATE_MAP, sourceArea); REGION_NO_PRIVATE_MAP, sourceArea);
if (clonedArea < B_OK) if (clonedArea < B_OK)
return clonedArea; return clonedArea;
@ -3069,7 +3071,8 @@ _user_create_area(const char *userName, void **userAddress, uint32 addressSpec,
return B_BAD_VALUE; return B_BAD_VALUE;
area = vm_create_anonymous_area(vm_get_current_user_aspace_id(), (char *)name, &address, area = vm_create_anonymous_area(vm_get_current_user_aspace_id(), (char *)name, &address,
addressSpec, size, lock, protection | B_KERNEL_READ_AREA | B_KERNEL_WRITE_AREA); addressSpec, size, lock, protection | B_KERNEL_READ_AREA
| (protection & B_WRITE_AREA ? B_KERNEL_WRITE_AREA : 0));
if (area >= B_OK && user_memcpy(userAddress, &address, sizeof(address)) < B_OK) { if (area >= B_OK && user_memcpy(userAddress, &address, sizeof(address)) < B_OK) {
delete_area(area); delete_area(area);