_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:
parent
4bc2682135
commit
f19955303e
@ -1399,17 +1399,17 @@ vm_set_area_protection(aspace_id aspaceID, area_id areaID, uint32 newProtection)
|
|||||||
// Since this cache now lives from the pages in its source cache,
|
// Since this cache now lives from the pages in its source cache,
|
||||||
// we can change the cache's commitment to take only those pages
|
// we can change the cache's commitment to take only those pages
|
||||||
// into account that really are in this cache.
|
// into account that really are in this cache.
|
||||||
|
|
||||||
// count existing pages in this cache
|
// count existing pages in this cache
|
||||||
struct vm_page *page = cache->page_list;
|
struct vm_page *page = cache->page_list;
|
||||||
uint32 count = 0;
|
uint32 count = 0;
|
||||||
|
|
||||||
for (; page != NULL; page = page->cache_next) {
|
for (; page != NULL; page = page->cache_next) {
|
||||||
count++;
|
count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
status = cache->store->ops->commit(cache->store, count * B_PAGE_SIZE);
|
status = cache->store->ops->commit(cache->store, count * B_PAGE_SIZE);
|
||||||
|
|
||||||
// ToDo: we may be able to join with our source cache, if any
|
// ToDo: we may be able to join with our source cache, if any
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user