process/vm: fix lookup_process_memory_range with small start address
Cherry-picked from 6370520e Conflicts: kernel/process.c
This commit is contained in:
committed by
Balazs Gerofi
parent
ce4eb0d409
commit
5c11ff0950
@@ -1293,7 +1293,7 @@ struct vm_range *lookup_process_memory_range(
|
|||||||
int i;
|
int i;
|
||||||
struct vm_range *range = NULL, *match = NULL;
|
struct vm_range *range = NULL, *match = NULL;
|
||||||
struct rb_root *root = &vm->vm_range_tree;
|
struct rb_root *root = &vm->vm_range_tree;
|
||||||
struct rb_node *node = root->rb_node;
|
struct rb_node *node = root->rb_node, *prev = NULL;
|
||||||
|
|
||||||
dkprintf("lookup_process_memory_range(%p,%lx,%lx)\n", vm, start, end);
|
dkprintf("lookup_process_memory_range(%p,%lx,%lx)\n", vm, start, end);
|
||||||
|
|
||||||
@@ -1312,6 +1312,7 @@ struct vm_range *lookup_process_memory_range(
|
|||||||
}
|
}
|
||||||
|
|
||||||
while (node) {
|
while (node) {
|
||||||
|
prev = node;
|
||||||
range = rb_entry(node, struct vm_range, vm_rb_node);
|
range = rb_entry(node, struct vm_range, vm_rb_node);
|
||||||
if (end <= range->start) {
|
if (end <= range->start) {
|
||||||
node = node->rb_left;
|
node = node->rb_left;
|
||||||
@@ -1328,6 +1329,10 @@ struct vm_range *lookup_process_memory_range(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* We optimistically try to go left, go back if we went too far */
|
||||||
|
if (!node && range && start < range->end)
|
||||||
|
node = prev;
|
||||||
|
|
||||||
if (match && end > match->start) {
|
if (match && end > match->start) {
|
||||||
vm->range_cache_ind = (vm->range_cache_ind - 1 + VM_RANGE_CACHE_SIZE)
|
vm->range_cache_ind = (vm->range_cache_ind - 1 + VM_RANGE_CACHE_SIZE)
|
||||||
% VM_RANGE_CACHE_SIZE;
|
% VM_RANGE_CACHE_SIZE;
|
||||||
|
|||||||
Reference in New Issue
Block a user