Adding a mounted device is dangerous because it will destroy the filesystem on that mounted device. So we add mounted-checking for btrfs-vol. Signed-off-by: Miao Xie <miaox@cn.fujitsu.com> --- btrfs-vol.c | 16 +++++++++++++++- 1 files changed, 15 insertions(+), 1 deletions(-) diff --git a/btrfs-vol.c b/btrfs-vol.c index 8069778..f781c06 100644 --- a/btrfs-vol.c +++ b/btrfs-vol.c @@ -108,10 +108,24 @@ int main(int ac, char **av) if (device && strcmp(device, "missing") == 0 && cmd == BTRFS_IOC_RM_DEV) { fprintf(stderr, "removing missing devices from %s\n", mnt); - } else if (device) { + } else if (cmd != BTRFS_IOC_BALANCE) { + if (cmd == BTRFS_IOC_ADD_DEV) { + ret = check_mounted(device); + if (ret < 0) { + fprintf(stderr, + "error checking %s mount status\n", + device); + exit(1); + } + if (ret == 1) { + fprintf(stderr, "%s is mounted\n", device); + exit(1); + } + } devfd = open(device, O_RDWR); if (!devfd) { fprintf(stderr, "Unable to open device %s\n", device); + exit(1); } ret = fstat(devfd, &st); if (ret) { -- 1.6.5.2 -- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Wengang Wang
2010-Feb-02 09:08 UTC
Re: [PATCH] btrfs-progs: add mounted-checking for btrfs-vol
Hi, A problem that not in this patch. On 10-02-02 16:45, Miao Xie wrote:> Adding a mounted device is dangerous because it will destroy the filesystem > on that mounted device. So we add mounted-checking for btrfs-vol. > > Signed-off-by: Miao Xie <miaox@cn.fujitsu.com> > --- > btrfs-vol.c | 16 +++++++++++++++- > 1 files changed, 15 insertions(+), 1 deletions(-) > > diff --git a/btrfs-vol.c b/btrfs-vol.c > index 8069778..f781c06 100644 > --- a/btrfs-vol.c > +++ b/btrfs-vol.c > @@ -108,10 +108,24 @@ int main(int ac, char **av) > if (device && strcmp(device, "missing") == 0 && > cmd == BTRFS_IOC_RM_DEV) { > fprintf(stderr, "removing missing devices from %s\n", mnt); > - } else if (device) { > + } else if (cmd != BTRFS_IOC_BALANCE) { > + if (cmd == BTRFS_IOC_ADD_DEV) { > + ret = check_mounted(device); > + if (ret < 0) { > + fprintf(stderr, > + "error checking %s mount status\n", > + device); > + exit(1); > + } > + if (ret == 1) { > + fprintf(stderr, "%s is mounted\n", device); > + exit(1); > + } > + } > devfd = open(device, O_RDWR); > if (!devfd) {I think open() returning -1 means an error. So it should be if (devfd < 0) instead of if (!devfd) regards, wengang.> fprintf(stderr, "Unable to open device %s\n", device); > + exit(1); > } > ret = fstat(devfd, &st); > if (ret) {-- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Miao Xie
2010-Feb-03 02:11 UTC
Re: [PATCH] btrfs-progs: add mounted-checking for btrfs-vol
Hi, on 2010-2-2 17:08, Wengang Wang wrote: [snip]>> devfd = open(device, O_RDWR); >> if (!devfd) { > I think open() returning -1 means an error. So it should be > if (devfd < 0) > instead of > if (!devfd)Yes, you are right. Thanks for your comment. I''ll remake a patch. Regards Miao> > regards, > wengang. >> fprintf(stderr, "Unable to open device %s\n", device); >> + exit(1); >> } >> ret = fstat(devfd, &st); >> if (ret) { > > >-- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html