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:
@@ -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++)
|
||||||
|
Reference in New Issue
Block a user