mkimage: Show item lists for all categories

Update the error-handling code for -A, -C and -O to show a list of valid
options when an invalid one is provided.

Signed-off-by: Simon Glass <sjg@chromium.org>
Reported-by: Vinoth Eswaran <evinoth1206@gmail.com>
Reviewed-by: Tom Rini <trini@konsulko.com>
This commit is contained in:
Simon Glass 2016-06-30 10:52:19 -06:00 committed by Tom Rini
parent f24e10500f
commit 51f03e6a75

View File

@ -152,8 +152,10 @@ static void process_args(int argc, char **argv)
break; break;
case 'A': case 'A':
params.arch = genimg_get_arch_id(optarg); params.arch = genimg_get_arch_id(optarg);
if (params.arch < 0) if (params.arch < 0) {
show_valid_options(IH_ARCH);
usage("Invalid architecture"); usage("Invalid architecture");
}
break; break;
case 'b': case 'b':
if (add_content(IH_TYPE_FLATDT, optarg)) { if (add_content(IH_TYPE_FLATDT, optarg)) {
@ -168,8 +170,10 @@ static void process_args(int argc, char **argv)
break; break;
case 'C': case 'C':
params.comp = genimg_get_comp_id(optarg); params.comp = genimg_get_comp_id(optarg);
if (params.comp < 0) if (params.comp < 0) {
show_valid_options(IH_COMP);
usage("Invalid compression type"); usage("Invalid compression type");
}
break; break;
case 'd': case 'd':
params.datafile = optarg; params.datafile = optarg;
@ -216,8 +220,10 @@ static void process_args(int argc, char **argv)
break; break;
case 'O': case 'O':
params.os = genimg_get_os_id(optarg); params.os = genimg_get_os_id(optarg);
if (params.os < 0) if (params.os < 0) {
show_valid_options(IH_OS);
usage("Invalid operating system"); usage("Invalid operating system");
}
break; break;
case 'p': case 'p':
params.external_offset = strtoull(optarg, &ptr, 16); params.external_offset = strtoull(optarg, &ptr, 16);