Skip to content

Commit 5b4236e

Browse files
mhiramatrichardweinberger
authored andcommitted
um: Fix to call read_initrd after init_bootmem
Since read_initrd() invokes alloc_bootmem() for allocating memory to load initrd image, it must be called after init_bootmem. This makes read_initrd() called directly from setup_arch() after init_bootmem() and mem_total_pages(). Cc: <[email protected]> Fixes: b632369 ("um: Setup physical memory in setup_arch()") Signed-off-by: Masami Hiramatsu <[email protected]> Signed-off-by: Richard Weinberger <[email protected]>
1 parent 601b7b9 commit 5b4236e

File tree

2 files changed

+7
-3
lines changed

2 files changed

+7
-3
lines changed

arch/um/kernel/initrd.c

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@
1414
static char *initrd __initdata = NULL;
1515
static int load_initrd(char *filename, void *buf, int size);
1616

17-
static int __init read_initrd(void)
17+
int __init read_initrd(void)
1818
{
1919
void *area;
2020
long long size;
@@ -46,8 +46,6 @@ static int __init read_initrd(void)
4646
return 0;
4747
}
4848

49-
__uml_postsetup(read_initrd);
50-
5149
static int __init uml_initrd_setup(char *line, int *add)
5250
{
5351
initrd = line;

arch/um/kernel/um_arch.c

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -338,11 +338,17 @@ int __init linux_main(int argc, char **argv)
338338
return start_uml();
339339
}
340340

341+
int __init __weak read_initrd(void)
342+
{
343+
return 0;
344+
}
345+
341346
void __init setup_arch(char **cmdline_p)
342347
{
343348
stack_protections((unsigned long) &init_thread_info);
344349
setup_physmem(uml_physmem, uml_reserved, physmem_size, highmem);
345350
mem_total_pages(physmem_size, iomem_size, highmem);
351+
read_initrd();
346352

347353
paging_init();
348354
strlcpy(boot_command_line, command_line, COMMAND_LINE_SIZE);

0 commit comments

Comments
 (0)