Use unique_fd
Also allow the state just before doMount() as a valid state for setting
fuse fd.
Test: manual
BUG:140173712
Change-Id: I012f8a83fef00e68f33010954fbc2ebc53cf8f1d
diff --git a/model/PublicVolume.cpp b/model/PublicVolume.cpp
index 2c0b4cc..ebcb91a 100644
--- a/model/PublicVolume.cpp
+++ b/model/PublicVolume.cpp
@@ -173,13 +173,13 @@
if (isFuse) {
LOG(INFO) << "Mounting public fuse volume";
- int fd = -1;
+ android::base::unique_fd fd;
int result = MountUserFuse(getMountUserId(), stableName, &fd);
if (result != 0) {
LOG(ERROR) << "Failed to mount public fuse volume";
return -result;
}
- setDeviceFd(fd);
+ setFuseFd(std::move(fd));
return OK;
}
@@ -265,7 +265,7 @@
}
rmdir(path.c_str());
- setDeviceFd(-1);
+ setFuseFd(android::base::unique_fd());
return OK;
}