diff options
| -rw-r--r-- | util/nvmutil/nvmutil.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/util/nvmutil/nvmutil.c b/util/nvmutil/nvmutil.c index f938d2cb..89e4461b 100644 --- a/util/nvmutil/nvmutil.c +++ b/util/nvmutil/nvmutil.c @@ -225,7 +225,7 @@ main(int argc, char *argv[]) cmd = &nv->cmd[*i]; #ifdef NVMUTIL_UNVEIL - if (cmd->flags == O_RDONLY) { + if ((cmd->flags & O_ACCMODE) == O_RDONLY) { if (unveil(f->fname, "r") == -1) err(errno, "%s: unveil r", f->fname); } else { @@ -256,7 +256,7 @@ main(int argc, char *argv[]) run_cmd(); - if (cmd->flags == O_RDWR) + if ((cmd->flags & O_ACCMODE) == O_RDWR) write_to_gbe_bin(); if (exit_cleanup() == -1) @@ -294,6 +294,8 @@ sanitize_command_index(unsigned long c) struct commands *cmd = &nv->cmd[c]; + int _flag; + check_command_num(c); if (cmd->argc < 3) @@ -337,8 +339,10 @@ sanitize_command_index(unsigned long c) err(EINVAL, "rw_size larger than GbE part: %lu", (unsigned long)gbe_rw_size); - if (cmd->flags != O_RDONLY && - cmd->flags != O_RDWR) + _flag = (cmd->flags & O_ACCMODE); + + if (_flag != O_RDONLY && + _flag != O_RDWR) err(EINVAL, "invalid cmd.flags setting"); } @@ -1206,7 +1210,7 @@ write_gbe_file(void) struct commands *cmd = &nv->cmd[nv->i]; struct xfile *f = &nv->f; - if (cmd->flags == O_RDONLY) + if ((cmd->flags & O_ACCMODE) == O_RDONLY) return; if (fstat(f->gbe_fd, &_gbe_st) == -1) @@ -1374,7 +1378,7 @@ write_to_gbe_bin(void) struct commands *cmd = &nv->cmd[nv->i]; - if (cmd->flags != O_RDWR) + if ((cmd->flags & O_ACCMODE) != O_RDWR) return; write_gbe_file(); |
