diff --git a/commands/bootm.c b/commands/bootm.c index afb9e06..f11138a 100644 --- a/commands/bootm.c +++ b/commands/bootm.c @@ -191,7 +191,18 @@ static int initrd_handler_parse_options(struct image_data *data, int opt, char *optarg) { + uint32_t initrd_start; + switch(opt) { + case 'L': + if (!data->initrd) { + eprintf("Warning -L ingnored. Specify the initrd first\n"); + break; + } + initrd_start = simple_strtoul(optarg, NULL, 0); + printf("initrd_start=0x%x\n", initrd_start); + data->initrd->header.ih_load = cpu_to_uimage(initrd_start); + break; case 'r': printf("use initrd %s\n", optarg); /* check for multi image @ */ @@ -204,16 +215,19 @@ } if (!data->initrd) return -1; - return 0; + break; default: return 1; } + + return 0; } static struct image_handler initrd_handler = { - .cmdline_options = "r:", + .cmdline_options = "r:L:", .cmdline_parse = initrd_handler_parse_options, - .help_string = " -r specify an initrd image", + .help_string = " -r specify an initrd image\n" + " -L specify initrd load address", }; static int initrd_register_image_handler(void)