+2004-11-14 Miklos Szeredi <miklos@szeredi.hu>
+
+ * Released 2.1-pre1
+
+2004-11-14 Miklos Szeredi <miklos@szeredi.hu>
+
+ * Fix bug in fuse_readpages() causing Oops in certain situations.
+ Bug found by Vincenzo Ciancia.
+
+ * Fix compilation with kernels versions > 2.6.9.
+
2004-11-11 Miklos Szeredi <miklos@szeredi.hu>
* Check kernel interface version in fusermount to prevent
* Check superblock of proc file in addition to inode number
- * Fix reace between request_send_noreply() and fuse_dev_release()
+ * Fix race between request_send_noreply() and fuse_dev_release()
2004-11-10 Miklos Szeredi <miklos@szeredi.hu>
-AC_INIT(fuse, 2.1-pre0)
+AC_INIT(fuse, 2.1-pre1)
AM_INIT_AUTOMAKE
AM_CONFIG_HEADER(include/config.h)
-AC_INIT(fuse-kernel, 2.1-pre0)
+AC_INIT(fuse-kernel, 2.1-pre1)
AC_CONFIG_HEADERS([config.h])
AC_PROG_INSTALL
struct fuse_req *fuse_get_request(struct fuse_conn *fc)
{
- struct fuse_req *req;
-
if (down_interruptible(&fc->unused_sem))
return NULL;
+ return do_get_request(fc);
+}
- req = do_get_request(fc);
- return req;
+struct fuse_req *fuse_get_request_nonint(struct fuse_conn *fc)
+{
+ down(&fc->unused_sem);
+ return do_get_request(fc);
}
struct fuse_req *fuse_get_request_nonblock(struct fuse_conn *fc)
{
- struct fuse_req *req;
-
if (down_trylock(&fc->unused_sem))
return NULL;
-
- req = do_get_request(fc);
- return req;
+ return do_get_request(fc);
}
void fuse_put_request(struct fuse_conn *fc, struct fuse_req *req)
(!(fc->flags & FUSE_ALLOW_ROOT) || current->fsuid != 0))
return -EACCES;
else if (fc->flags & FUSE_DEFAULT_PERMISSIONS) {
- int err = vfs_permission(inode, mask);
+ int err;
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)
+ err = vfs_permission(inode, mask);
+#else
+ err = generic_permission(inode, mask, NULL);
+#endif
/* If permission is denied, try to refresh file
attributes. This is also needed, because the root
if (err == -EACCES) {
err = fuse_do_getattr(inode);
- if (!err)
+ if (!err) {
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)
err = vfs_permission(inode, mask);
+#else
+ err = generic_permission(inode, mask, NULL);
+#endif
+ }
}
/* FIXME: Need some mechanism to revoke permissions:
if (attr->ia_valid & ATTR_SIZE) {
unsigned long limit;
is_truncate = 1;
-
+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,10)
limit = current->rlim[RLIMIT_FSIZE].rlim_cur;
- if (limit != RLIM_INFINITY && attr->ia_size > limit) {
+#else
+ limit = current->signal->rlim[RLIMIT_FSIZE].rlim_cur;
+#endif
+ if (limit != RLIM_INFINITY && attr->ia_size > (loff_t) limit) {
send_sig(SIGXFSZ, current, 0);
return -EFBIG;
}
req->pages[req->num_pages - 1]->index + 1 != page->index)) {
struct fuse_conn *fc = INO_FC(page->mapping->host);
fuse_send_readpages(req, data->file, inode);
- data->req = req = fuse_get_request(fc);
+ data->req = req = fuse_get_request_nonint(fc);
}
req->pages[req->num_pages] = page;
req->num_pages ++;
struct fuse_conn *fc = INO_FC(inode);
struct fuse_readpages_data data;
- data.req = fuse_get_request(fc);
+ data.req = fuse_get_request_nonint(fc);
data.file = file;
data.inode = inode;
*/
struct fuse_req *fuse_get_request(struct fuse_conn *fc);
+/**
+ * Reserve a preallocated request, non-interruptible
+ */
+struct fuse_req *fuse_get_request_nonint(struct fuse_conn *fc);
+
/**
* Reserve a preallocated request, non-blocking
*/
struct inode *ino;
ino = file->f_dentry->d_inode;
- if (!ino || !proc_fuse_dev ||
+ if (!ino || !proc_fuse_dev ||
strcmp(ino->i_sb->s_type->name, "proc") != 0 ||
proc_fuse_dev->low_ino != ino->i_ino) {
printk("FUSE: bad communication file descriptor\n");