The check on fd < 0 was recently removed. However, this check is important
as the content of FUSE_DEV_FD is passed as-is to mount_fusefs, and a string
beginning by '-' is treated as an option.
Additionally, add a proper include and type.
Signed-off-by: Vassili Tchersky <vt+git@vbcy.org>
#include "fuse_i.h"
#include "fuse_misc.h"
#include "fuse_opt.h"
+#include "util.h"
#include <sys/param.h>
#include "fuse_mount_compat.h"
static int fuse_mount_core(const char *mountpoint, const char *opts)
{
const char *mountprog = FUSERMOUNT_PROG;
- int fd;
+ long fd;
char *fdnam, *dev;
pid_t pid, cpid;
int status;
if (fdnam) {
err = libfuse_strtol(fdnam, &fd);
- if (err) {
+ if (err || fd < 0) {
fuse_log(FUSE_LOG_ERR, "invalid value given in FUSE_DEV_FD\n");
return -1;
}
if (! fdnam)
{
- ret = asprintf(&fdnam, "%d", fd);
+ ret = asprintf(&fdnam, "%ld", fd);
if(ret == -1)
{
perror("fuse: failed to assemble mount arguments");