Skip to content

Commit df8ee57

Browse files
Pavel Tatashintorvalds
authored andcommitted
sparc64: simplify vmemmap_populate
Remove duplicating code by using common functions vmemmap_pud_populate and vmemmap_pgd_populate. Link: http://lkml.kernel.org/r/20171013173214.27300-5-pasha.tatashin@oracle.com Signed-off-by: Pavel Tatashin <pasha.tatashin@oracle.com> Reviewed-by: Steven Sistare <steven.sistare@oracle.com> Reviewed-by: Daniel Jordan <daniel.m.jordan@oracle.com> Reviewed-by: Bob Picco <bob.picco@oracle.com> Acked-by: David S. Miller <davem@davemloft.net> Acked-by: Michal Hocko <mhocko@suse.com> Cc: Alexander Potapenko <glider@google.com> Cc: Andrey Ryabinin <aryabinin@virtuozzo.com> Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Christian Borntraeger <borntraeger@de.ibm.com> Cc: Dmitry Vyukov <dvyukov@google.com> Cc: Heiko Carstens <heiko.carstens@de.ibm.com> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Matthew Wilcox <willy@infradead.org> Cc: Mel Gorman <mgorman@techsingularity.net> Cc: Michal Hocko <mhocko@kernel.org> Cc: Sam Ravnborg <sam@ravnborg.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Will Deacon <will.deacon@arm.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
1 parent 2a20aa1 commit df8ee57

File tree

1 file changed

+6
-17
lines changed

1 file changed

+6
-17
lines changed

arch/sparc/mm/init_64.c

Lines changed: 6 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -2644,30 +2644,19 @@ int __meminit vmemmap_populate(unsigned long vstart, unsigned long vend,
26442644
vstart = vstart & PMD_MASK;
26452645
vend = ALIGN(vend, PMD_SIZE);
26462646
for (; vstart < vend; vstart += PMD_SIZE) {
2647-
pgd_t *pgd = pgd_offset_k(vstart);
2647+
pgd_t *pgd = vmemmap_pgd_populate(vstart, node);
26482648
unsigned long pte;
26492649
pud_t *pud;
26502650
pmd_t *pmd;
26512651

2652-
if (pgd_none(*pgd)) {
2653-
pud_t *new = vmemmap_alloc_block(PAGE_SIZE, node);
2652+
if (!pgd)
2653+
return -ENOMEM;
26542654

2655-
if (!new)
2656-
return -ENOMEM;
2657-
pgd_populate(&init_mm, pgd, new);
2658-
}
2659-
2660-
pud = pud_offset(pgd, vstart);
2661-
if (pud_none(*pud)) {
2662-
pmd_t *new = vmemmap_alloc_block(PAGE_SIZE, node);
2663-
2664-
if (!new)
2665-
return -ENOMEM;
2666-
pud_populate(&init_mm, pud, new);
2667-
}
2655+
pud = vmemmap_pud_populate(pgd, vstart, node);
2656+
if (!pud)
2657+
return -ENOMEM;
26682658

26692659
pmd = pmd_offset(pud, vstart);
2670-
26712660
pte = pmd_val(*pmd);
26722661
if (!(pte & _PAGE_VALID)) {
26732662
void *block = vmemmap_alloc_block(PMD_SIZE, node);

0 commit comments

Comments
 (0)