Commit bf457be1 authored by Arvind Sankar's avatar Arvind Sankar Committed by Ingo Molnar

x86/kaslr: Drop some redundant checks from __process_mem_region()

Clip the start and end of the region to minimum and mem_limit prior to
the loop. region.start can only increase during the loop, so raising it
to minimum before the loop is enough.

A region that becomes empty due to this will get checked in
the first iteration of the loop.

Drop the check for overlap extending beyond the end of the region. This
will get checked in the next loop iteration anyway.

Rename end to region_end for symmetry with region.start.
Signed-off-by: default avatarArvind Sankar <nivedita@alum.mit.edu>
Signed-off-by: default avatarIngo Molnar <mingo@kernel.org>
Link: https://lore.kernel.org/r/20200728225722.67457-10-nivedita@alum.mit.edu
parent ef7b07d5
...@@ -623,34 +623,23 @@ static void __process_mem_region(struct mem_vector *entry, ...@@ -623,34 +623,23 @@ static void __process_mem_region(struct mem_vector *entry,
unsigned long image_size) unsigned long image_size)
{ {
struct mem_vector region, overlap; struct mem_vector region, overlap;
unsigned long end; unsigned long region_end;
/* Ignore entries entirely below our minimum. */ /* Enforce minimum and memory limit. */
if (entry->start + entry->size < minimum) region.start = max_t(unsigned long long, entry->start, minimum);
return; region_end = min(entry->start + entry->size, mem_limit);
/* Ignore entries above memory limit */
end = min(entry->size + entry->start, mem_limit);
if (entry->start >= end)
return;
region.start = entry->start;
/* Give up if slot area array is full. */ /* Give up if slot area array is full. */
while (slot_area_index < MAX_SLOT_AREA) { while (slot_area_index < MAX_SLOT_AREA) {
/* Potentially raise address to minimum location. */
if (region.start < minimum)
region.start = minimum;
/* Potentially raise address to meet alignment needs. */ /* Potentially raise address to meet alignment needs. */
region.start = ALIGN(region.start, CONFIG_PHYSICAL_ALIGN); region.start = ALIGN(region.start, CONFIG_PHYSICAL_ALIGN);
/* Did we raise the address above the passed in memory entry? */ /* Did we raise the address above the passed in memory entry? */
if (region.start > end) if (region.start > region_end)
return; return;
/* Reduce size by any delta from the original address. */ /* Reduce size by any delta from the original address. */
region.size = end - region.start; region.size = region_end - region.start;
/* Return if region can't contain decompressed kernel */ /* Return if region can't contain decompressed kernel */
if (region.size < image_size) if (region.size < image_size)
...@@ -668,10 +657,6 @@ static void __process_mem_region(struct mem_vector *entry, ...@@ -668,10 +657,6 @@ static void __process_mem_region(struct mem_vector *entry,
process_gb_huge_pages(&region, image_size); process_gb_huge_pages(&region, image_size);
} }
/* Return if overlap extends to or past end of region. */
if (overlap.start + overlap.size >= region.start + region.size)
return;
/* Clip off the overlapping region and start over. */ /* Clip off the overlapping region and start over. */
region.start = overlap.start + overlap.size; region.start = overlap.start + overlap.size;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment