You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
201 lines
6.2 KiB
201 lines
6.2 KiB
# --- 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 |
|
|
|
|