1
0
mirror of https://review.coreboot.org/flashrom.git synced 2025-10-24 11:08:19 +02:00

Postpone layout file reading

Layout file reading should happen after option parsing like all other
file accesses.
Guard against multiple --layout parameters.

Followup fix for r1483: Remove -m short option from getopt.

Corresponding to flashrom svn r1484.

Signed-off-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net>
Acked-by: Stefan Tauner <stefan.tauner@alumni.tuwien.ac.at>
This commit is contained in:
Carl-Daniel Hailfinger
2012-01-11 02:10:11 +00:00
parent 2d927fbd7b
commit 4628445ccb

View File

@@ -177,7 +177,7 @@ int main(int argc, char *argv[])
enum programmer prog = PROGRAMMER_INVALID; enum programmer prog = PROGRAMMER_INVALID;
int ret = 0; int ret = 0;
static const char optstring[] = "r:Rw:v:nVEfc:m:l:i:p:Lzh"; static const char optstring[] = "r:Rw:v:nVEfc:l:i:p:Lzh";
static const struct option long_options[] = { static const struct option long_options[] = {
{"read", 1, NULL, 'r'}, {"read", 1, NULL, 'r'},
{"write", 1, NULL, 'w'}, {"write", 1, NULL, 'w'},
@@ -198,6 +198,7 @@ int main(int argc, char *argv[])
}; };
char *filename = NULL; char *filename = NULL;
char *layoutfile = NULL;
char *tempstr = NULL; char *tempstr = NULL;
char *pparam = NULL; char *pparam = NULL;
@@ -273,9 +274,12 @@ int main(int argc, char *argv[])
force = 1; force = 1;
break; break;
case 'l': case 'l':
tempstr = strdup(optarg); if (layoutfile) {
if (read_romlayout(tempstr)) fprintf(stderr, "Error: --layout specified "
"more than once. Aborting.\n");
cli_classic_abort_usage(); cli_classic_abort_usage();
}
layoutfile = strdup(optarg);
break; break;
case 'i': case 'i':
tempstr = strdup(optarg); tempstr = strdup(optarg);
@@ -373,9 +377,6 @@ int main(int argc, char *argv[])
cli_classic_abort_usage(); cli_classic_abort_usage();
} }
if (process_include_args())
cli_classic_abort_usage();
/* FIXME: Print the actions flashrom will take. */ /* FIXME: Print the actions flashrom will take. */
if (list_supported) { if (list_supported) {
@@ -390,6 +391,11 @@ int main(int argc, char *argv[])
} }
#endif #endif
if (layoutfile && read_romlayout(layoutfile))
cli_classic_abort_usage();
if (process_include_args())
cli_classic_abort_usage();
/* Does a chip with the requested name exist in the flashchips array? */ /* Does a chip with the requested name exist in the flashchips array? */
if (chip_to_probe) { if (chip_to_probe) {
for (flash = flashchips; flash && flash->name; flash++) for (flash = flashchips; flash && flash->name; flash++)