Note: Upstream git repository: git://fuse.git.sourceforge.net/gitroot/fuse/fuse ----------------------------------------------------------------------------- shell> git format-patch --stdout \ --src-prefix=fuse-2.8.6/ \ --dst-prefix=fuse-2.8.6-bugfix/ \ fuse_2_8_6..origin/fuse_2_8_bugfix -----------------------------------------------------------------------------user/amery/next/luajit
@ -0,0 +1,201 @@ |
|||||
|
# --- SDE-COPYRIGHT-NOTE-BEGIN --- |
||||
|
# This copyright note is auto-generated by ./scripts/Create-CopyPatch. |
||||
|
# |
||||
|
# Filename: package/.../fuse/fuse-2.8.6-upstream-bugfixes.patch |
||||
|
# Copyright (C) 2011 The OpenSDE Project |
||||
|
# |
||||
|
# More information can be found in the files COPYING and README. |
||||
|
# |
||||
|
# This patch file is dual-licensed. It is available under the license the |
||||
|
# patched project is licensed under, as long as it is an OpenSource license |
||||
|
# as defined at http://www.opensource.org/ (e.g. BSD, X11) or under the terms |
||||
|
# of the GNU General Public License as published by the Free Software |
||||
|
# Foundation; either version 2 of the License, or (at your option) any later |
||||
|
# version. |
||||
|
# --- SDE-COPYRIGHT-NOTE-END --- |
||||
|
|
||||
|
From 9294657fb966c685cf6a99f4bbe73a91eb2b8f3c Mon Sep 17 00:00:00 2001 |
||||
|
From: Miklos Szeredi <mszeredi@suse.cz> |
||||
|
Date: Sun, 23 Oct 2011 10:07:20 +0200 |
||||
|
Subject: [PATCH 1/3] Reply with ENOMEM in case of failure to allocate request |
||||
|
|
||||
|
Reply to request with ENOMEM in case of failure to allocate request |
||||
|
structure. Otherwise the task issuing the request will just freeze up |
||||
|
until the filesystem daemon is killed. Reported by Stephan Kulow |
||||
|
---
|
||||
|
ChangeLog | 7 +++++++ |
||||
|
lib/fuse_lowlevel.c | 11 +++++++++++ |
||||
|
2 files changed, 18 insertions(+), 0 deletions(-) |
||||
|
|
||||
|
diff --git fuse-2.8.6/ChangeLog fuse-2.8.6-bugfix/ChangeLog
|
||||
|
index 4be41e3..77a9b9e 100644
|
||||
|
--- fuse-2.8.6/ChangeLog
|
||||
|
+++ fuse-2.8.6-bugfix/ChangeLog
|
||||
|
@@ -1,3 +1,10 @@
|
||||
|
+2011-10-13 Miklos Szeredi <miklos@szeredi.hu>
|
||||
|
+
|
||||
|
+ * Reply to request with ENOMEM in case of failure to allocate
|
||||
|
+ request structure. Otherwise the task issuing the request will
|
||||
|
+ just freeze up until the filesystem daemon is killed. Reported by
|
||||
|
+ Stephan Kulow
|
||||
|
+
|
||||
|
2011-09-13 Miklos Szeredi <miklos@szeredi.hu> |
||||
|
|
||||
|
* Released 2.8.6 |
||||
|
diff --git fuse-2.8.6/lib/fuse_lowlevel.c fuse-2.8.6-bugfix/lib/fuse_lowlevel.c
|
||||
|
index c519bfb..c86a910 100644
|
||||
|
--- fuse-2.8.6/lib/fuse_lowlevel.c
|
||||
|
+++ fuse-2.8.6-bugfix/lib/fuse_lowlevel.c
|
||||
|
@@ -1467,7 +1467,18 @@ static void fuse_ll_process(void *data, const char *buf, size_t len,
|
||||
|
|
||||
|
req = (struct fuse_req *) calloc(1, sizeof(struct fuse_req)); |
||||
|
if (req == NULL) { |
||||
|
+ struct fuse_out_header out = {
|
||||
|
+ .unique = in->unique,
|
||||
|
+ .error = -ENOMEM,
|
||||
|
+ .len = sizeof(struct fuse_out_header),
|
||||
|
+ };
|
||||
|
+ struct iovec iov = {
|
||||
|
+ .iov_base = &out,
|
||||
|
+ .iov_len = sizeof(struct fuse_out_header),
|
||||
|
+ };
|
||||
|
+
|
||||
|
fprintf(stderr, "fuse: failed to allocate request\n"); |
||||
|
+ fuse_chan_send(ch, &iov, 1);
|
||||
|
return; |
||||
|
} |
||||
|
|
||||
|
--
|
||||
|
1.7.2.3 |
||||
|
|
||||
|
|
||||
|
From 655794f4a1515f1eb5b00b2fcc32d3f31f56839b Mon Sep 17 00:00:00 2001 |
||||
|
From: Miklos Szeredi <mszeredi@suse.cz> |
||||
|
Date: Thu, 17 Nov 2011 12:36:38 +0100 |
||||
|
Subject: [PATCH 2/3] Fix the following compile error |
||||
|
|
||||
|
fusermount.c: In function 'clone_newns': |
||||
|
fusermount.c:315:2: warning: implicit declaration of function 'clone' [-Wimplicit-function-declaration] |
||||
|
fusermount.c:315:44: error: 'CLONE_NEWNS' undeclared (first use in this function) |
||||
|
fusermount.c:315:44: note: each undeclared identifier is reported only once for each function it appears in |
||||
|
fusermount.c:317:1: warning: control reaches end of non-void function [-Wreturn-type] |
||||
|
---
|
||||
|
util/fusermount.c | 1 + |
||||
|
1 files changed, 1 insertions(+), 0 deletions(-) |
||||
|
|
||||
|
diff --git fuse-2.8.6/util/fusermount.c fuse-2.8.6-bugfix/util/fusermount.c
|
||||
|
index 70c18b7..6855b7e 100644
|
||||
|
--- fuse-2.8.6/util/fusermount.c
|
||||
|
+++ fuse-2.8.6-bugfix/util/fusermount.c
|
||||
|
@@ -7,6 +7,7 @@
|
||||
|
*/ |
||||
|
/* This program does the mounting and unmounting of FUSE filesystems */ |
||||
|
|
||||
|
+#define _GNU_SOURCE /* for clone */
|
||||
|
#include <config.h> |
||||
|
|
||||
|
#include "mount_util.h" |
||||
|
--
|
||||
|
1.7.2.3 |
||||
|
|
||||
|
|
||||
|
From 3743f3fe52cfd52bb1d75bcb8324a00f153dc9f8 Mon Sep 17 00:00:00 2001 |
||||
|
From: Miklos Szeredi <mszeredi@suse.cz> |
||||
|
Date: Fri, 9 Dec 2011 16:07:55 +0100 |
||||
|
Subject: [PATCH 3/3] Fix hang in wait_on_path() |
||||
|
|
||||
|
Ville Silventoinen reported that fs_racer in LTP triggered a hang in |
||||
|
wait_on_path(). This bug was caused by try_get_path() not resetting "ticket" on |
||||
|
permanent failure. |
||||
|
---
|
||||
|
ChangeLog | 4 ++++ |
||||
|
lib/fuse.c | 38 ++++++++++++++++++++++++++++++++++---- |
||||
|
2 files changed, 38 insertions(+), 4 deletions(-) |
||||
|
|
||||
|
diff --git fuse-2.8.6/ChangeLog fuse-2.8.6-bugfix/ChangeLog
|
||||
|
index 77a9b9e..2c25c0b 100644
|
||||
|
--- fuse-2.8.6/ChangeLog
|
||||
|
+++ fuse-2.8.6-bugfix/ChangeLog
|
||||
|
@@ -1,3 +1,7 @@
|
||||
|
+2011-12-09 Miklos Szeredi <miklos@szeredi.hu>
|
||||
|
+
|
||||
|
+ * Fix hang in wait_on_path(). Reported by Ville Silventoinen
|
||||
|
+
|
||||
|
2011-10-13 Miklos Szeredi <miklos@szeredi.hu> |
||||
|
|
||||
|
* Reply to request with ENOMEM in case of failure to allocate |
||||
|
diff --git fuse-2.8.6/lib/fuse.c fuse-2.8.6-bugfix/lib/fuse.c
|
||||
|
index 95cf50b..d511964 100644
|
||||
|
--- fuse-2.8.6/lib/fuse.c
|
||||
|
+++ fuse-2.8.6-bugfix/lib/fuse.c
|
||||
|
@@ -495,6 +495,26 @@ static void unlock_path(struct fuse *f, fuse_ino_t nodeid, struct node *wnode,
|
||||
|
} |
||||
|
} |
||||
|
|
||||
|
+static void release_tickets(struct fuse *f, fuse_ino_t nodeid,
|
||||
|
+ struct node *wnode, int ticket)
|
||||
|
+{
|
||||
|
+ struct node *node;
|
||||
|
+
|
||||
|
+ if (wnode) {
|
||||
|
+ if (wnode->ticket != ticket)
|
||||
|
+ return;
|
||||
|
+
|
||||
|
+ wnode->ticket = 0;
|
||||
|
+ }
|
||||
|
+
|
||||
|
+ for (node = get_node(f, nodeid);
|
||||
|
+ node->nodeid != FUSE_ROOT_ID; node = node->parent) {
|
||||
|
+ if (node->ticket != ticket)
|
||||
|
+ return;
|
||||
|
+ node->ticket = 0;
|
||||
|
+ }
|
||||
|
+}
|
||||
|
+
|
||||
|
static int try_get_path(struct fuse *f, fuse_ino_t nodeid, const char *name, |
||||
|
char **path, struct node **wnodep, int ticket) |
||||
|
{ |
||||
|
@@ -507,9 +527,10 @@ static int try_get_path(struct fuse *f, fuse_ino_t nodeid, const char *name,
|
||||
|
|
||||
|
*path = NULL; |
||||
|
|
||||
|
+ err = -ENOMEM;
|
||||
|
buf = malloc(bufsize); |
||||
|
if (buf == NULL) |
||||
|
- return -ENOMEM;
|
||||
|
+ goto out_err;
|
||||
|
|
||||
|
s = buf + bufsize - 1; |
||||
|
*s = '\0'; |
||||
|
@@ -577,6 +598,10 @@ static int try_get_path(struct fuse *f, fuse_ino_t nodeid, const char *name,
|
||||
|
out_free: |
||||
|
free(buf); |
||||
|
|
||||
|
+ out_err:
|
||||
|
+ if (ticket && err != -EAGAIN)
|
||||
|
+ release_tickets(f, nodeid, wnode, ticket);
|
||||
|
+
|
||||
|
return err; |
||||
|
} |
||||
|
|
||||
|
@@ -711,9 +736,14 @@ static int try_get_path2(struct fuse *f, fuse_ino_t nodeid1, const char *name1,
|
||||
|
err = try_get_path(f, nodeid1, name1, path1, wnode1, ticket); |
||||
|
if (!err) { |
||||
|
err = try_get_path(f, nodeid2, name2, path2, wnode2, ticket); |
||||
|
- if (err)
|
||||
|
- unlock_path(f, nodeid1, wnode1 ? *wnode1 : NULL, NULL,
|
||||
|
- ticket);
|
||||
|
+ if (err) {
|
||||
|
+ struct node *wn1 = wnode1 ? *wnode1 : NULL;
|
||||
|
+
|
||||
|
+ unlock_path(f, nodeid1, wn1, NULL, ticket);
|
||||
|
+ free(path1);
|
||||
|
+ if (ticket && err != -EAGAIN)
|
||||
|
+ release_tickets(f, nodeid1, wn1, ticket);
|
||||
|
+ }
|
||||
|
} |
||||
|
return err; |
||||
|
} |
||||
|
--
|
||||
|
1.7.2.3 |
||||
|
|