From 8c316845267e069a89eb6c273de1233abcaa4cb6 Mon Sep 17 00:00:00 2001 From: Sergey Popov Date: Mon, 14 Jan 2019 12:43:33 +0300 Subject: [PATCH] sys-fs/mhddfs: revision bump Bump EAPI to 7. Fix segfault, use slotted sys-fs/fuse dependency Committed straight to stable Signed-off-by: Sergey Popov Closes: https://bugs.gentoo.org/570992 Closes: https://bugs.gentoo.org/673644 Package-Manager: Portage-2.3.49, Repoman-2.3.10 --- .../files/mhddfs-0.1.39-segfault-fix.patch | 207 ++++++++++++++++++ .../files/mhddfs-respect-compiler-vars.patch | 4 +- ...-0.1.39.ebuild => mhddfs-0.1.39-r1.ebuild} | 21 +- 3 files changed, 221 insertions(+), 11 deletions(-) create mode 100644 sys-fs/mhddfs/files/mhddfs-0.1.39-segfault-fix.patch rename sys-fs/mhddfs/{mhddfs-0.1.39.ebuild => mhddfs-0.1.39-r1.ebuild} (75%) diff --git a/sys-fs/mhddfs/files/mhddfs-0.1.39-segfault-fix.patch b/sys-fs/mhddfs/files/mhddfs-0.1.39-segfault-fix.patch new file mode 100644 index 000000000000..493a78396190 --- /dev/null +++ b/sys-fs/mhddfs/files/mhddfs-0.1.39-segfault-fix.patch @@ -0,0 +1,207 @@ +Patch backported from +https://github.com/vdudouyt/mhddfs-nosegfault + +Thanks to Gabor Kovari + +--- a/src/main.c 2012-06-17 16:09:56.000000000 +0200 ++++ b/src/main.c 2015-12-21 16:32:29.000000000 +0100 +@@ -33,6 +33,13 @@ + #include + #include + ++#include ++#include ++#include ++ ++#include ++#include ++ + #ifndef WITHOUT_XATTR + #include + #endif +@@ -42,7 +49,21 @@ + + #include "debug.h" + +-#include ++void save_backtrace(int sig) ++{ ++ void *array[10]; ++ size_t size; ++ ++ // get void*'s for all entries on the stack ++ size = backtrace(array, 10); ++ ++ // print out all the frames to stderr ++ fprintf(stderr, "Error: signal %d\n", sig); ++ FILE *log = fopen("/tmp/mhddfs_backtrace.log", "w"); ++ backtrace_symbols_fd(array, size, fileno(log)); ++ fclose(log); ++ exit(1); ++} + + // getattr + static int mhdd_stat(const char *file_name, struct stat *buf) +@@ -161,16 +182,13 @@ + mhdd_debug(MHDD_MSG, "mhdd_readdir: %s\n", dirname); + char **dirs = (char **) calloc(mhdd.cdirs+1, sizeof(char *)); + ++ struct stat st; ++ + typedef struct dir_item { + char *name; + struct stat *st; +- UT_hash_handle hh; + } dir_item; + +- dir_item * items_ht = NULL; +- +- +- struct stat st; + + // find all dirs + for(i = j = found = 0; id_name, prev); +- +- if (prev) { ++ if(g_hash_table_lookup(hash, de->d_name)) ++ { + continue; + } + + // add item + char *object_name = create_path(dirs[i], de->d_name); +- struct dir_item *new_item = +- calloc(1, sizeof(struct dir_item)); ++ struct dir_item *new_item = calloc(1, sizeof(struct dir_item)); + + new_item->name = strdup(de->d_name); + new_item->st = calloc(1, sizeof(struct stat)); + lstat(object_name, new_item->st); + +- HASH_ADD_KEYPTR( +- hh, +- items_ht, +- new_item->name, +- strlen(new_item->name), +- new_item +- ); ++ g_hash_table_insert(hash, new_item->name, new_item); + free(object_name); + } + + closedir(dh); + } + +- dir_item *item, *tmp; +- +- // fill list +- HASH_ITER(hh, items_ht, item, tmp) { +- if (filler(buf, item->name, item->st, 0)) +- break; +- } ++ dir_item *item; + +- // free memory +- HASH_ITER(hh, items_ht, item, tmp) { ++ gpointer key, value; ++ GHashTableIter iter; ++ g_hash_table_iter_init(&iter, hash); ++ ++ while(g_hash_table_iter_next (&iter, &key, &value)) ++ { ++ item = (dir_item*) value; ++ int result = filler(buf, item->name, item->st, 0); + free(item->name); + free(item->st); + free(item); ++ if(result) break; + } +- HASH_CLEAR(hh, items_ht); ++ ++ g_hash_table_destroy(hash); + + for (i = 0; dirs[i]; i++) + free(dirs[i]); +@@ -1008,6 +1020,19 @@ + } + #endif + ++static void limits_init() ++{ ++ struct rlimit limit; ++ limit.rlim_cur = 512000; ++ limit.rlim_max = 512000; ++ ++ if(setrlimit(RLIMIT_NOFILE, &limit) != 0) ++ { ++ perror("setrlimit() failed"); ++ exit(-1); ++ } ++} ++ + // functions links + static struct fuse_operations mhdd_oper = { + .getattr = mhdd_stat, +@@ -1048,5 +1073,7 @@ + mhdd_debug_init(); + struct fuse_args *args = parse_options(argc, argv); + flist_init(); ++ limits_init(); ++ signal(SIGSEGV, save_backtrace); + return fuse_main(args->argc, args->argv, &mhdd_oper, 0); + } +--- a/src/usage.c 2012-06-17 16:09:56.000000000 +0200 ++++ b/src/usage.c 2015-12-21 16:32:29.000000000 +0100 +@@ -25,6 +25,7 @@ + "\n" + "Multi-hdd FUSE filesystem\n" + " Copyright (C) 2008, Dmitry E. Oboukhov \n" ++ " Copyright (C) 2015, Valentin Dudouyt \n" + "\n" + "Usage:\n" + " mhddfs dir1,dir2.. mountpoint [ -o OPTIONS ]\n" +--- a/Makefile 2016-01-05 16:45:10.184105001 +0100 ++++ b/Makefile 2015-12-21 16:32:29.000000000 +0100 +@@ -22,13 +22,13 @@ + + TARGET = mhddfs + +-CFLAGS += -Wall $(shell pkg-config fuse --cflags) \ +- -DFUSE_USE_VERSION=26 -MMD ++CFLAGS = -Wall $(shell pkg-config fuse glib-2.0 --cflags) \ ++ -DFUSE_USE_VERSION=26 -MMD -g -rdynamic -O0 + ifdef WITHOUT_XATTR + CFLAGS += -DWITHOUT_XATTR + endif + +-LIBS = $(shell pkg-config fuse --libs) ++LDFLAGS = $(shell pkg-config fuse glib-2.0 --libs) + + FORTAR = src COPYING LICENSE README Makefile \ + README.ru.UTF-8 ChangeLog mhddfs.1 \ +@@ -53,7 +53,7 @@ + ifeq ($(DEBVERSION), $(VERSION)) + all: $(TARGET) + else +-all: update_version $(TARGET) ++all: $(TARGET) + endif + + update_version: + diff --git a/sys-fs/mhddfs/files/mhddfs-respect-compiler-vars.patch b/sys-fs/mhddfs/files/mhddfs-respect-compiler-vars.patch index 331bb7c23f60..0c6f24f4d1a7 100644 --- a/sys-fs/mhddfs/files/mhddfs-respect-compiler-vars.patch +++ b/sys-fs/mhddfs/files/mhddfs-respect-compiler-vars.patch @@ -1,5 +1,5 @@ ---- Makefile.orig 2012-11-19 15:25:21.665692111 +0400 -+++ Makefile 2012-11-19 15:27:08.406691288 +0400 +--- a/Makefile 2012-11-19 15:25:21.665692111 +0400 ++++ b/Makefile 2012-11-19 15:27:08.406691288 +0400 @@ -22,13 +22,13 @@ TARGET = mhddfs diff --git a/sys-fs/mhddfs/mhddfs-0.1.39.ebuild b/sys-fs/mhddfs/mhddfs-0.1.39-r1.ebuild similarity index 75% rename from sys-fs/mhddfs/mhddfs-0.1.39.ebuild rename to sys-fs/mhddfs/mhddfs-0.1.39-r1.ebuild index 79fe6fb79f89..f161e79fa0f9 100644 --- a/sys-fs/mhddfs/mhddfs-0.1.39.ebuild +++ b/sys-fs/mhddfs/mhddfs-0.1.39-r1.ebuild @@ -1,9 +1,9 @@ -# Copyright 1999-2016 Gentoo Foundation +# Copyright 1999-2019 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -EAPI=4 +EAPI=7 -inherit base eutils toolchain-funcs +inherit toolchain-funcs MY_P="${PN}_${PV}" @@ -14,14 +14,17 @@ SRC_URI="http://mhddfs.uvw.ru/downloads/${MY_P}.tar.gz" LICENSE="GPL-3" SLOT="0" KEYWORDS="amd64" + IUSE="l10n_ru suid" -RDEPEND=">=sys-fs/fuse-2.7.0" -DEPEND="${RDEPEND} - dev-libs/uthash" +RDEPEND="sys-fs/fuse:0" +DEPEND="${RDEPEND}" -DOCS="ChangeLog README" -PATCHES=( "${FILESDIR}/${PN}-respect-compiler-vars.patch" ) +DOCS=( ChangeLog README ) +PATCHES=( + "${FILESDIR}/${PN}-respect-compiler-vars.patch" + "${FILESDIR}/${P}-segfault-fix.patch" +) src_compile() { emake CC="$(tc-getCC)" @@ -30,7 +33,7 @@ src_compile() { src_install() { dobin mhddfs doman mhddfs.1 - dodoc ${DOCS} + einstalldocs use l10n_ru && dodoc README.ru.UTF-8 use suid && fperms u+s /usr/bin/${PN} } -- 2.26.2