Skip to content

Commit 4ac2aed

Browse files
tlendackyKAGA-KOKO
authored andcommitted
resource: Consolidate resource walking code
The walk_iomem_res_desc(), walk_system_ram_res() and walk_system_ram_range() functions each have much of the same code. Create a new function that consolidates the common code from these functions in one place to reduce the amount of duplicated code. Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com> Signed-off-by: Brijesh Singh <brijesh.singh@amd.com> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Borislav Petkov <bp@suse.de> Tested-by: Borislav Petkov <bp@suse.de> Cc: kvm@vger.kernel.org Cc: Borislav Petkov <bp@alien8.de> Link: https://lkml.kernel.org/r/20171020143059.3291-9-brijesh.singh@amd.com
1 parent 1379edd commit 4ac2aed

File tree

1 file changed

+25
-27
lines changed

1 file changed

+25
-27
lines changed

kernel/resource.c

Lines changed: 25 additions & 27 deletions
Original file line numberDiff line numberDiff line change
@@ -400,6 +400,26 @@ static int find_next_iomem_res(struct resource *res, unsigned long desc,
400400
return 0;
401401
}
402402

403+
static int __walk_iomem_res_desc(struct resource *res, unsigned long desc,
404+
bool first_level_children_only,
405+
void *arg, int (*func)(u64, u64, void *))
406+
{
407+
u64 orig_end = res->end;
408+
int ret = -1;
409+
410+
while ((res->start < res->end) &&
411+
!find_next_iomem_res(res, desc, first_level_children_only)) {
412+
ret = (*func)(res->start, res->end, arg);
413+
if (ret)
414+
break;
415+
416+
res->start = res->end + 1;
417+
res->end = orig_end;
418+
}
419+
420+
return ret;
421+
}
422+
403423
/*
404424
* Walks through iomem resources and calls func() with matching resource
405425
* ranges. This walks through whole tree and not just first level children.
@@ -418,26 +438,12 @@ int walk_iomem_res_desc(unsigned long desc, unsigned long flags, u64 start,
418438
u64 end, void *arg, int (*func)(u64, u64, void *))
419439
{
420440
struct resource res;
421-
u64 orig_end;
422-
int ret = -1;
423441

424442
res.start = start;
425443
res.end = end;
426444
res.flags = flags;
427-
orig_end = res.end;
428-
429-
while ((res.start < res.end) &&
430-
(!find_next_iomem_res(&res, desc, false))) {
431-
432-
ret = (*func)(res.start, res.end, arg);
433-
if (ret)
434-
break;
435-
436-
res.start = res.end + 1;
437-
res.end = orig_end;
438-
}
439445

440-
return ret;
446+
return __walk_iomem_res_desc(&res, desc, false, arg, func);
441447
}
442448

443449
/*
@@ -451,22 +457,13 @@ int walk_system_ram_res(u64 start, u64 end, void *arg,
451457
int (*func)(u64, u64, void *))
452458
{
453459
struct resource res;
454-
u64 orig_end;
455-
int ret = -1;
456460

457461
res.start = start;
458462
res.end = end;
459463
res.flags = IORESOURCE_SYSTEM_RAM | IORESOURCE_BUSY;
460-
orig_end = res.end;
461-
while ((res.start < res.end) &&
462-
(!find_next_iomem_res(&res, IORES_DESC_NONE, true))) {
463-
ret = (*func)(res.start, res.end, arg);
464-
if (ret)
465-
break;
466-
res.start = res.end + 1;
467-
res.end = orig_end;
468-
}
469-
return ret;
464+
465+
return __walk_iomem_res_desc(&res, IORES_DESC_NONE, true,
466+
arg, func);
470467
}
471468

472469
#if !defined(CONFIG_ARCH_HAS_WALK_MEMORY)
@@ -508,6 +505,7 @@ static int __is_ram(unsigned long pfn, unsigned long nr_pages, void *arg)
508505
{
509506
return 1;
510507
}
508+
511509
/*
512510
* This generic page_is_ram() returns true if specified address is
513511
* registered as System RAM in iomem_resource list.

0 commit comments

Comments
 (0)