diff options
author | Miklos Szeredi <miklos@szeredi.hu> | 2001-11-16 21:40:00 +0000 |
---|---|---|
committer | Miklos Szeredi <miklos@szeredi.hu> | 2001-11-16 21:40:00 +0000 |
commit | 4c749295c233ceaa91b53c816eb4ad3ccfee4748 (patch) | |
tree | 116ecf0a75643e389440dff9ee97c062b588aa7b /kernel/dev.c | |
parent | 66aeb510efbf3d6d46e5848be53162c156ee27a6 (diff) | |
download | libfuse-4c749295c233ceaa91b53c816eb4ad3ccfee4748.tar.gz |
fixes in kernel module
Diffstat (limited to 'kernel/dev.c')
-rw-r--r-- | kernel/dev.c | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/kernel/dev.c b/kernel/dev.c index 1cc12a2..d4206e1 100644 --- a/kernel/dev.c +++ b/kernel/dev.c @@ -18,6 +18,26 @@ static struct proc_dir_entry *proc_fs_fuse; struct proc_dir_entry *proc_fuse_dev; +static int interrupt_error(enum fuse_opcode opcode) +{ + switch(opcode) { + case FUSE_LOOKUP: + case FUSE_GETATTR: + case FUSE_READLINK: + case FUSE_GETDIR: + case FUSE_OPEN: + case FUSE_READ: + case FUSE_WRITE: + return -ERESTARTSYS; + + default: + /* Operations which modify the filesystem cannot be safely + restarted, because it is uncertain whether the + operation has completed or not... */ + return -EINTR; + } +} + static int request_wait_answer(struct fuse_req *req) { int ret = 0; @@ -27,7 +47,7 @@ static int request_wait_answer(struct fuse_req *req) while(!list_empty(&req->list)) { set_current_state(TASK_INTERRUPTIBLE); if(signal_pending(current)) { - ret = -EINTR; + ret = interrupt_error(req->opcode); break; } spin_unlock(&fuse_lock); |