-2005-01-13 Miklos Szeredi <miklos@szeredi.hu>
+2005-01-15 Miklos Szeredi <miklos@szeredi.hu>
+
+ * fix compilation on 2.4 kernels (reported by Valient Gough)
+ * fix failure to unmount bug (found by David Shaw)
+
* fusermount: improve parsing of /etc/fuse.conf
2005-01-13 Miklos Szeredi <miklos@szeredi.hu>
kernel_autoconf=$kernelsrc/include/linux/autoconf.h
AC_MSG_CHECKING([if FUSE is configured in the kernel])
if test -f $kernel_autoconf; then
- if grep -q "^#define CONFIG_FUSE 1" $kernel_autoconf || grep -q "^#define CONFIG_FUSE_MODULE 1" $kernel_autoconf; then
+ if grep -q "^#define CONFIG_FUSE_FS 1" $kernel_autoconf || grep -q "^#define CONFIG_FUSE_FS_MODULE 1" $kernel_autoconf; then
fuse_configured=yes
fi
fi
AC_MSG_RESULT([$fuse_configured])
if test -z "$enable_kernel_module" -a "$fuse_configured" = yes; then
ENABLE_FUSE_MODULE=n
- AC_MSG_WARN([FUSE is configured in the kernel, not building kernel])
- AC_MSG_WARN([module. To force building of kernel module use the])
- AC_MSG_WARN(['--enable-kernel-module' option.])
+ AC_MSG_NOTICE([NOTE: Detected that FUSE is already present in the kernel, so])
+ AC_MSG_NOTICE([NOTE: building of kernel module is disabled. To force building])
+ AC_MSG_NOTICE([NOTE: of kernel module use the '--enable-kernel-module' option.])
fi
fi
if test "$enable_kernel_module" = no; then
fuse_put_request(fc, req);
if (!err) {
if ((inode->i_mode ^ arg.attr.mode) & S_IFMT) {
- make_bad_inode(inode);
+ if (get_node_id(inode) != FUSE_ROOT_ID)
+ make_bad_inode(inode);
err = -EIO;
} else {
struct fuse_inode *fi = get_fuse_inode(inode);
fuse_put_request(fc, req);
if (!err) {
if ((inode->i_mode ^ outarg.attr.mode) & S_IFMT) {
- make_bad_inode(inode);
+ if (get_node_id(inode) != FUSE_ROOT_ID)
+ make_bad_inode(inode);
err = -EIO;
} else {
if (is_truncate) {
#ifndef BUG_ON
#define BUG_ON(x)
#endif
+#ifndef container_of
+#define container_of(ptr, type, member) ({ \
+ const typeof( ((type *)0)->member ) *__mptr = (ptr); \
+ (type *)( (char *)__mptr - offsetof(type,member) );})
+#endif
#ifndef __user
#define __user
#endif