mirror of
https://codeberg.org/libreboot/lbmk.git
synced 2026-03-25 13:29:03 +02:00
util/nvmutil: remove global variable x
make a singleton function instead now there are technically no global variables, so i can more easily start splitting this up into multiple linked programs Signed-off-by: Leah Rowe <leah@libreboot.org>
This commit is contained in:
@@ -42,9 +42,26 @@
|
||||
* is passed. The rest of the program
|
||||
* will manipulate this data.
|
||||
*/
|
||||
/*
|
||||
TODO:
|
||||
eventually, i will not have this return
|
||||
a pointer at all. instead, a similar key
|
||||
mechanism will be used for other access
|
||||
functions e.g. word/set_word, err(needs
|
||||
to clean up), and so on. then those
|
||||
would return values if already initialised,
|
||||
but would not permit additional init - will
|
||||
decide exactly how to implement this at a
|
||||
later state.
|
||||
|
||||
this is part of an ongoing effort to introduce
|
||||
extreme memory safety into this program.
|
||||
*/
|
||||
struct xstate *
|
||||
new_xstate(void)
|
||||
xstatus(void)
|
||||
{
|
||||
static int first_run = 1;
|
||||
|
||||
static struct xstate us = {
|
||||
/* .cmd (update cmd[] in the struct if adding to it)
|
||||
DO NOT FORGET. or C will init zeroes/NULLs */
|
||||
@@ -114,44 +131,27 @@ new_xstate(void)
|
||||
|
||||
};
|
||||
|
||||
struct xstate *xs_new;
|
||||
if (first_run) {
|
||||
us.xsize = sizeof(us);
|
||||
|
||||
us.xsize = sizeof(us);
|
||||
us.f.buf = us.f.real_buf;
|
||||
|
||||
xs_new = malloc(us.xsize);
|
||||
if (xs_new == NULL)
|
||||
err(ECANCELED, "Could not initialise new state");
|
||||
us.f.gbe_fd = -1;
|
||||
us.f.tmp_fd = -1;
|
||||
|
||||
memcpy(xs_new, &us, us.xsize);
|
||||
us.f.tname = NULL;
|
||||
us.f.fname = NULL;
|
||||
}
|
||||
|
||||
/*
|
||||
* Some pointers should be set
|
||||
* in the copy, not the template,
|
||||
* if they point to other items
|
||||
* in the struct, because if they
|
||||
* were set before copy, then copied,
|
||||
* the copied pointer would be invalid,
|
||||
* referring to the reference struct
|
||||
*
|
||||
* e.g. ->f.buf (gbe tmp file work memory):
|
||||
*/
|
||||
first_run = 0;
|
||||
|
||||
xs_new->f.buf = xs_new->f.real_buf;
|
||||
|
||||
xs_new->f.gbe_fd = -1;
|
||||
xs_new->f.tmp_fd = -1;
|
||||
|
||||
xs_new->f.tname = NULL;
|
||||
xs_new->f.fname = NULL;
|
||||
|
||||
return xs_new;
|
||||
return &us;
|
||||
}
|
||||
|
||||
static struct xstate *x = NULL;
|
||||
|
||||
int
|
||||
main(int argc, char *argv[])
|
||||
{
|
||||
struct xstate *x;
|
||||
struct commands *cmd;
|
||||
struct xfile *f;
|
||||
unsigned long i;
|
||||
@@ -203,7 +203,7 @@ main(int argc, char *argv[])
|
||||
#endif
|
||||
#endif
|
||||
|
||||
x = new_xstate();
|
||||
x = xstatus();
|
||||
|
||||
if (x == NULL)
|
||||
err(errno, NULL);
|
||||
@@ -282,11 +282,11 @@ main(int argc, char *argv[])
|
||||
void
|
||||
sanitize_command_list(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
|
||||
unsigned long c;
|
||||
unsigned long num_commands;
|
||||
|
||||
check_null_command("sanitize_command_list");
|
||||
|
||||
num_commands = items(x->cmd);
|
||||
|
||||
for (c = 0; c < num_commands; c++)
|
||||
@@ -299,13 +299,12 @@ sanitize_command_list(void)
|
||||
void
|
||||
sanitize_command_index(unsigned long c)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct commands *cmd;
|
||||
|
||||
int _flag;
|
||||
unsigned long gbe_rw_size;
|
||||
|
||||
check_null_command("sanitize_command_index");
|
||||
|
||||
cmd = &x->cmd[c];
|
||||
|
||||
check_command_num(c);
|
||||
@@ -361,12 +360,11 @@ sanitize_command_index(unsigned long c)
|
||||
void
|
||||
set_cmd(int argc, char *argv[])
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
const char *cmd;
|
||||
|
||||
unsigned long c;
|
||||
|
||||
check_null_command("set_cmd");
|
||||
|
||||
for (c = 0; c < items(x->cmd); c++) {
|
||||
|
||||
cmd = x->cmd[c].str;
|
||||
@@ -393,12 +391,11 @@ set_cmd(int argc, char *argv[])
|
||||
void
|
||||
set_cmd_args(int argc, char *argv[])
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct commands *cmd;
|
||||
struct xfile *f;
|
||||
unsigned long i;
|
||||
|
||||
check_null_command("set_cmd_args");
|
||||
|
||||
i = x->i;
|
||||
cmd = &x->cmd[i];
|
||||
f = &x->f;
|
||||
@@ -492,14 +489,13 @@ xstrxcmp(const char *a, const char *b, unsigned long maxlen)
|
||||
void
|
||||
open_gbe_file(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct commands *cmd;
|
||||
struct xfile *f;
|
||||
|
||||
struct stat _st;
|
||||
int _flags;
|
||||
|
||||
check_null_command("open_gbe_file");
|
||||
|
||||
cmd = &x->cmd[x->i];
|
||||
f = &x->f;
|
||||
|
||||
@@ -612,10 +608,9 @@ xopen(int *fd_ptr, const char *path, int flags, struct stat *st)
|
||||
void
|
||||
copy_gbe(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
check_null_command("copy_gbe");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
read_file();
|
||||
@@ -641,13 +636,12 @@ copy_gbe(void)
|
||||
void
|
||||
read_file(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
struct stat _st;
|
||||
long _r;
|
||||
|
||||
check_null_command("read_file");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
/* read main file */
|
||||
@@ -703,6 +697,7 @@ read_file(void)
|
||||
void
|
||||
read_checksums(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct commands *cmd;
|
||||
struct xfile *f;
|
||||
|
||||
@@ -712,8 +707,6 @@ read_checksums(void)
|
||||
unsigned char _num_invalid;
|
||||
unsigned char _max_invalid;
|
||||
|
||||
check_null_command("read_checksums");
|
||||
|
||||
cmd = &x->cmd[x->i];
|
||||
f = &x->f;
|
||||
|
||||
@@ -762,8 +755,6 @@ good_checksum(unsigned long partnum)
|
||||
unsigned short expected_checksum;
|
||||
unsigned short actual_checksum;
|
||||
|
||||
check_null_command("good_checksum");
|
||||
|
||||
expected_checksum =
|
||||
calculated_checksum(partnum);
|
||||
|
||||
@@ -780,11 +771,10 @@ good_checksum(unsigned long partnum)
|
||||
void
|
||||
run_cmd(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
unsigned long i;
|
||||
void (*run)(void);
|
||||
|
||||
check_null_command("run_cmd");
|
||||
|
||||
i = x->i;
|
||||
run = x->cmd[i].run;
|
||||
|
||||
@@ -802,8 +792,6 @@ run_cmd(void)
|
||||
void
|
||||
check_command_num(unsigned long c)
|
||||
{
|
||||
check_null_command("check_command_num");
|
||||
|
||||
if (!valid_command(c))
|
||||
err(EINVAL, "Invalid run_cmd arg: %lu",
|
||||
(unsigned long)c);
|
||||
@@ -812,10 +800,9 @@ check_command_num(unsigned long c)
|
||||
unsigned char
|
||||
valid_command(unsigned long c)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct commands *cmd;
|
||||
|
||||
check_null_command("valid_command");
|
||||
|
||||
if (c >= items(x->cmd))
|
||||
return 0;
|
||||
|
||||
@@ -832,11 +819,10 @@ valid_command(unsigned long c)
|
||||
void
|
||||
cmd_helper_setmac(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
unsigned long partnum;
|
||||
struct macaddr *mac;
|
||||
|
||||
check_null_command("cmd_helper_setmac");
|
||||
|
||||
mac = &x->mac;
|
||||
|
||||
check_cmd(cmd_helper_setmac, "setmac");
|
||||
@@ -851,12 +837,11 @@ cmd_helper_setmac(void)
|
||||
void
|
||||
parse_mac_string(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct macaddr *mac;
|
||||
|
||||
unsigned long mac_byte;
|
||||
|
||||
check_null_command("parse_mac_string");
|
||||
|
||||
mac = &x->mac;
|
||||
|
||||
if (xstrxlen(x->mac.str, 18) != 17)
|
||||
@@ -904,6 +889,7 @@ xstrxlen(const char *scmp, unsigned long maxlen)
|
||||
void
|
||||
set_mac_byte(unsigned long mac_byte_pos)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct macaddr *mac;
|
||||
|
||||
char separator;
|
||||
@@ -911,8 +897,6 @@ set_mac_byte(unsigned long mac_byte_pos)
|
||||
unsigned long mac_str_pos;
|
||||
unsigned long mac_nib_pos;
|
||||
|
||||
check_null_command("set_mac_byte");
|
||||
|
||||
mac = &x->mac;
|
||||
|
||||
mac_str_pos = mac_byte_pos * 3;
|
||||
@@ -931,13 +915,12 @@ void
|
||||
set_mac_nib(unsigned long mac_str_pos,
|
||||
unsigned long mac_byte_pos, unsigned long mac_nib_pos)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct macaddr *mac;
|
||||
|
||||
char mac_ch;
|
||||
unsigned short hex_num;
|
||||
|
||||
check_null_command("sanitize_command_list");
|
||||
|
||||
mac = &x->mac;
|
||||
|
||||
mac_ch = mac->str[mac_str_pos + mac_nib_pos];
|
||||
@@ -1032,13 +1015,12 @@ rlong(void)
|
||||
void
|
||||
write_mac_part(unsigned long partnum)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
struct macaddr *mac;
|
||||
|
||||
unsigned long w;
|
||||
|
||||
check_null_command("write_mac_part");
|
||||
|
||||
f = &x->f;
|
||||
mac = &x->mac;
|
||||
|
||||
@@ -1057,12 +1039,11 @@ write_mac_part(unsigned long partnum)
|
||||
void
|
||||
cmd_helper_dump(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
unsigned long p;
|
||||
|
||||
check_null_command("cmd_helper_dump");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
check_cmd(cmd_helper_dump, "dump");
|
||||
@@ -1096,8 +1077,6 @@ print_mac_from_nvm(unsigned long partnum)
|
||||
unsigned long c;
|
||||
unsigned short val16;
|
||||
|
||||
check_null_command("print_mac_from_nvm");
|
||||
|
||||
for (c = 0; c < 3; c++) {
|
||||
val16 = nvm_word(c, partnum);
|
||||
printf("%02x:%02x",
|
||||
@@ -1117,8 +1096,6 @@ hexdump(unsigned long partnum)
|
||||
unsigned long row;
|
||||
unsigned short val16;
|
||||
|
||||
check_null_command("hexdump");
|
||||
|
||||
for (row = 0; row < 8; row++) {
|
||||
|
||||
printf("%08lx ",
|
||||
@@ -1144,10 +1121,9 @@ hexdump(unsigned long partnum)
|
||||
void
|
||||
cmd_helper_swap(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
check_null_command("cmd_helper_swap");
|
||||
|
||||
check_cmd(cmd_helper_swap, "swap");
|
||||
|
||||
f = &x->f;
|
||||
@@ -1174,10 +1150,9 @@ cmd_helper_swap(void)
|
||||
void
|
||||
cmd_helper_copy(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
check_null_command("cmd_helper_copy");
|
||||
|
||||
check_cmd(cmd_helper_copy, "copy");
|
||||
|
||||
f = &x->f;
|
||||
@@ -1193,8 +1168,7 @@ cmd_helper_copy(void)
|
||||
void
|
||||
cmd_helper_cat(void)
|
||||
{
|
||||
check_null_command("cmd_helper_cat");
|
||||
|
||||
struct xstate *x = xstatus();
|
||||
check_cmd(cmd_helper_cat, "cat");
|
||||
|
||||
x->cat = 0;
|
||||
@@ -1204,8 +1178,7 @@ cmd_helper_cat(void)
|
||||
void
|
||||
cmd_helper_cat16(void)
|
||||
{
|
||||
check_null_command("cmd_helper_cat16");
|
||||
|
||||
struct xstate *x = xstatus();
|
||||
check_cmd(cmd_helper_cat16, "cat16");
|
||||
|
||||
x->cat = 1;
|
||||
@@ -1215,8 +1188,7 @@ cmd_helper_cat16(void)
|
||||
void
|
||||
cmd_helper_cat128(void)
|
||||
{
|
||||
check_null_command("cmd_helper_cat128");
|
||||
|
||||
struct xstate *x = xstatus();
|
||||
check_cmd(cmd_helper_cat128, "cat128");
|
||||
|
||||
x->cat = 15;
|
||||
@@ -1227,10 +1199,9 @@ void
|
||||
check_cmd(void (*fn)(void),
|
||||
const char *name)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
unsigned long i;
|
||||
|
||||
check_null_command("check_cmd");
|
||||
|
||||
if (x->cmd[x->i].run != fn)
|
||||
err(ECANCELED, "Running %s, but cmd %s is set",
|
||||
name, x->cmd[x->i].str);
|
||||
@@ -1258,13 +1229,12 @@ cmd_helper_err(void)
|
||||
void
|
||||
cat(unsigned long nff)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
unsigned long p;
|
||||
unsigned long ff;
|
||||
|
||||
check_null_command("cat");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
p = 0;
|
||||
@@ -1306,6 +1276,7 @@ cat_buf(unsigned char *b)
|
||||
void
|
||||
write_gbe_file(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct commands *cmd;
|
||||
struct xfile *f;
|
||||
|
||||
@@ -1315,8 +1286,6 @@ write_gbe_file(void)
|
||||
unsigned long p;
|
||||
unsigned char update_checksum;
|
||||
|
||||
check_null_command("write_gbe_file");
|
||||
|
||||
cmd = &x->cmd[x->i];
|
||||
f = &x->f;
|
||||
|
||||
@@ -1357,8 +1326,6 @@ write_gbe_file(void)
|
||||
void
|
||||
set_checksum(unsigned long p)
|
||||
{
|
||||
check_null_command("set_checksum");
|
||||
|
||||
check_bin(p, "part number");
|
||||
set_nvm_word(NVM_CHECKSUM_WORD, p, calculated_checksum(p));
|
||||
}
|
||||
@@ -1369,8 +1336,6 @@ calculated_checksum(unsigned long p)
|
||||
unsigned long c;
|
||||
unsigned int val16;
|
||||
|
||||
check_null_command("calculated_checksum");
|
||||
|
||||
val16 = 0;
|
||||
|
||||
for (c = 0; c < NVM_CHECKSUM_WORD; c++)
|
||||
@@ -1390,12 +1355,11 @@ calculated_checksum(unsigned long p)
|
||||
unsigned short
|
||||
nvm_word(unsigned long pos16, unsigned long p)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
unsigned long pos;
|
||||
|
||||
check_null_command("nvm_word");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
check_nvm_bound(pos16, p);
|
||||
@@ -1408,12 +1372,11 @@ nvm_word(unsigned long pos16, unsigned long p)
|
||||
void
|
||||
set_nvm_word(unsigned long pos16, unsigned long p, unsigned short val16)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
unsigned long pos;
|
||||
|
||||
check_null_command("set_nvm_word");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
check_nvm_bound(pos16, p);
|
||||
@@ -1428,10 +1391,9 @@ set_nvm_word(unsigned long pos16, unsigned long p, unsigned short val16)
|
||||
void
|
||||
set_part_modified(unsigned long p)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
check_null_command("set_part_modified");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
check_bin(p, "part number");
|
||||
@@ -1447,8 +1409,6 @@ check_nvm_bound(unsigned long c, unsigned long p)
|
||||
* ever modified the NVM area.
|
||||
*/
|
||||
|
||||
check_null_command("check_nvm_bound");
|
||||
|
||||
check_bin(p, "part number");
|
||||
|
||||
if (c >= NVM_WORDS)
|
||||
@@ -1468,6 +1428,7 @@ void
|
||||
rw_gbe_file_part(unsigned long p, int rw_type,
|
||||
const char *rw_type_str)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct commands *cmd;
|
||||
struct xfile *f;
|
||||
|
||||
@@ -1478,8 +1439,6 @@ rw_gbe_file_part(unsigned long p, int rw_type,
|
||||
unsigned long gbe_rw_size;
|
||||
unsigned char *mem_offset;
|
||||
|
||||
check_null_command("rw_gbe_file_part");
|
||||
|
||||
cmd = &x->cmd[x->i];
|
||||
f = &x->f;
|
||||
|
||||
@@ -1507,14 +1466,13 @@ rw_gbe_file_part(unsigned long p, int rw_type,
|
||||
void
|
||||
write_to_gbe_bin(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct commands *cmd;
|
||||
struct xfile *f;
|
||||
|
||||
int saved_errno;
|
||||
int mv;
|
||||
|
||||
check_null_command("write_to_gbe_bin");
|
||||
|
||||
cmd = &x->cmd[x->i];
|
||||
f = &x->f;
|
||||
|
||||
@@ -1603,6 +1561,7 @@ write_to_gbe_bin(void)
|
||||
void
|
||||
check_written_part(unsigned long p)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct commands *cmd;
|
||||
struct xfile *f;
|
||||
|
||||
@@ -1616,8 +1575,6 @@ check_written_part(unsigned long p)
|
||||
struct stat st;
|
||||
unsigned char *buf_restore;
|
||||
|
||||
check_null_command("check_written_part");
|
||||
|
||||
cmd = &x->cmd[x->i];
|
||||
f = &x->f;
|
||||
|
||||
@@ -1677,12 +1634,11 @@ check_written_part(unsigned long p)
|
||||
void
|
||||
report_io_err_rw(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
unsigned long p;
|
||||
|
||||
check_null_command("report_io_err_rw");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
if (!f->io_err_gbe)
|
||||
@@ -1736,6 +1692,7 @@ report_io_err_rw(void)
|
||||
int
|
||||
gbe_mv(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
int rval;
|
||||
@@ -1746,8 +1703,6 @@ gbe_mv(void)
|
||||
char *dest_tmp;
|
||||
int dest_fd;
|
||||
|
||||
check_null_command("gbe_mv");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
/* will be set 0 if it doesn't */
|
||||
@@ -1987,12 +1942,11 @@ err_fsync_dir:
|
||||
unsigned char *
|
||||
gbe_mem_offset(unsigned long p, const char *f_op)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
off_t gbe_off;
|
||||
|
||||
check_null_command("gbe_mem_offset");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
gbe_off = gbe_x_offset(p, f_op, "mem",
|
||||
@@ -2012,12 +1966,11 @@ gbe_mem_offset(unsigned long p, const char *f_op)
|
||||
off_t
|
||||
gbe_file_offset(unsigned long p, const char *f_op)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
off_t gbe_file_half_size;
|
||||
|
||||
check_null_command("gbe_file_offset");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
gbe_file_half_size = f->gbe_file_size >> 1;
|
||||
@@ -2030,12 +1983,11 @@ off_t
|
||||
gbe_x_offset(unsigned long p, const char *f_op, const char *d_type,
|
||||
off_t nsize, off_t ncmp)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
off_t off;
|
||||
|
||||
check_null_command("gbe_x_offset");
|
||||
|
||||
check_bin(p, "part number");
|
||||
|
||||
f = &x->f;
|
||||
@@ -2057,12 +2009,11 @@ long
|
||||
rw_gbe_file_exact(int fd, unsigned char *mem, unsigned long nrw,
|
||||
off_t off, int rw_type)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
long r;
|
||||
|
||||
check_null_command("rw_gbe_file_exact");
|
||||
|
||||
f = &x->f;
|
||||
|
||||
if (io_args(fd, mem, nrw, off, rw_type) == -1)
|
||||
@@ -2096,26 +2047,6 @@ err_rw_gbe_file_exact:
|
||||
return -1;
|
||||
}
|
||||
|
||||
void
|
||||
check_null_command(const char *c)
|
||||
{
|
||||
char msg[] = "undefined function name";
|
||||
char *func_name = msg;
|
||||
|
||||
if (c != NULL) {
|
||||
|
||||
if (*c != '\0') {
|
||||
|
||||
func_name = (char *)c;
|
||||
}
|
||||
}
|
||||
|
||||
if (x == NULL) {
|
||||
|
||||
err(ECANCELED, "%s: x ptr is null", func_name);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Safe I/O functions wrapping around
|
||||
* read(), write() and providing a portable
|
||||
@@ -2595,6 +2526,8 @@ usage(void)
|
||||
void
|
||||
err(int nvm_errval, const char *msg, ...)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
|
||||
va_list args;
|
||||
|
||||
if (errno == 0)
|
||||
@@ -2619,6 +2552,7 @@ err(int nvm_errval, const char *msg, ...)
|
||||
int
|
||||
exit_cleanup(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
struct xfile *f;
|
||||
|
||||
int close_err;
|
||||
@@ -2661,6 +2595,7 @@ exit_cleanup(void)
|
||||
const char *
|
||||
getnvmprogname(void)
|
||||
{
|
||||
struct xstate *x = xstatus();
|
||||
const char *p;
|
||||
static char fallback[] = "nvmutil";
|
||||
|
||||
|
||||
@@ -289,7 +289,7 @@ struct xfile {
|
||||
/*
|
||||
* BE CAREFUL when editing this
|
||||
* to ensure that you also update
|
||||
* the tables in new_xstate()
|
||||
* the tables in xstatus()
|
||||
*/
|
||||
struct xstate {
|
||||
struct commands cmd[7];
|
||||
@@ -313,7 +313,7 @@ struct xstate {
|
||||
|
||||
|
||||
|
||||
static struct xstate *new_xstate(void);
|
||||
static struct xstate *xstatus(void);
|
||||
|
||||
/*
|
||||
* Sanitize command tables.
|
||||
@@ -437,7 +437,6 @@ off_t gbe_x_offset(unsigned long part, const char *f_op,
|
||||
const char *d_type, off_t nsize, off_t ncmp);
|
||||
long rw_gbe_file_exact(int fd, unsigned char *mem, unsigned long nrw,
|
||||
off_t off, int rw_type);
|
||||
void check_null_command(const char *c);
|
||||
long rw_file_exact(int fd, unsigned char *mem, unsigned long len,
|
||||
off_t off, int rw_type, int loop_eagain, int loop_eintr,
|
||||
unsigned long max_retries, int off_reset);
|
||||
|
||||
Reference in New Issue
Block a user