diff options
| author | Leah Rowe <leah@libreboot.org> | 2026-03-16 15:15:53 +0000 |
|---|---|---|
| committer | Leah Rowe <leah@libreboot.org> | 2026-03-26 06:59:41 +0000 |
| commit | e9d90e8acae1147481c54ea5efb969ccb24a7fa8 (patch) | |
| tree | 668f5bcbe6a279d18987dd99519513150bced0b2 /util/nvmutil | |
| parent | 2a6a63fef3820804149c6e95c843cc29d99de969 (diff) | |
util/nvmutil: use portable mkstemp
Signed-off-by: Leah Rowe <leah@libreboot.org>
Diffstat (limited to 'util/nvmutil')
| -rw-r--r-- | util/nvmutil/nvmutil.c | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/util/nvmutil/nvmutil.c b/util/nvmutil/nvmutil.c index 4d7c7dbb..12a6cf5a 100644 --- a/util/nvmutil/nvmutil.c +++ b/util/nvmutil/nvmutil.c @@ -466,6 +466,7 @@ static const char *getnvmprogname(void); * a special kind of hell */ static char *new_tmpfile(int *fd, int local, const char *path); +static int x_i_mkstemp(char *template); /* * Sizes in bytes: @@ -693,7 +694,6 @@ static ino_t tmp_ino; * prototypes. Should be safe * on most Unices and compilers */ -int mkstemp(char *template); int fchmod(int fd, mode_t mode); static int tmp_fd = -1; @@ -2910,7 +2910,7 @@ new_tmpfile(int *fd, int local, const char *path) dest[tmppath_len] = '\0'; - fd_tmp = mkstemp(dest); + fd_tmp = x_i_mkstemp(dest); if (fd_tmp == -1) goto err_new_tmpfile; @@ -2975,3 +2975,18 @@ err_new_tmpfile: return NULL; } + +/* + * portable mkstemp + */ +static int +x_i_mkstemp(char *template) +{ + int fd; + + if (mktemp(template) == NULL) + return -1; + + fd = open(template, O_RDWR | O_CREAT | O_EXCL, 0600); + return fd; +} |
