diff options
-rw-r--r-- | office/LibreOffice/LibreOffice.SlackBuild | 5 | ||||
-rw-r--r-- | office/LibreOffice/LibreOffice.info | 10 | ||||
-rw-r--r-- | office/LibreOffice/firebird.diff | 1091 |
3 files changed, 7 insertions, 1099 deletions
diff --git a/office/LibreOffice/LibreOffice.SlackBuild b/office/LibreOffice/LibreOffice.SlackBuild index 5683f4355c6d7..0dff27339b529 100644 --- a/office/LibreOffice/LibreOffice.SlackBuild +++ b/office/LibreOffice/LibreOffice.SlackBuild @@ -26,9 +26,9 @@ PRGNAM=LibreOffice SRCNAM=libreoffice -VERSION=${VERSION:-5.3.0.3} +VERSION=${VERSION:-5.3.1.2} SHORT_VERSION=${VERSION%.*.*} -BUILD=${BUILD:-3} +BUILD=${BUILD:-1} TAG=${TAG:-_SBo} PACKAGER=${PACKAGER:-"AnonymousCoward"} @@ -70,7 +70,6 @@ rm -rf $SRCNAM-$VERSION tar xvf $CWD/$SRCNAM-$VERSION.tar.xz cd $SRCNAM-$VERSION patch -p0 < $CWD/no-check-if-root.diff -patch -p1 < $CWD/firebird.diff if [ "$HAVE_SRCS_TARBALL" = "1" ]; then tar xvf $CWD/$SRCNAM-${VERSION}-srcs.tar.xz diff --git a/office/LibreOffice/LibreOffice.info b/office/LibreOffice/LibreOffice.info index 152e815ecd10d..44deca35740bf 100644 --- a/office/LibreOffice/LibreOffice.info +++ b/office/LibreOffice/LibreOffice.info @@ -1,10 +1,10 @@ PRGNAM="LibreOffice" -VERSION="5.3.0.3" +VERSION="5.3.1.2" HOMEPAGE="http://libreoffice.org" -DOWNLOAD="http://download.documentfoundation.org/libreoffice/src/5.3.0/libreoffice-5.3.0.3.tar.xz \ - http://sourceforge.net/projects/slackbuildsdirectlinks/files/LibreOffice/libreoffice-5.3.0.3-srcs.tar.xz" -MD5SUM="204c492a0b5e58dd0be9788c74a364ab \ - 20d3cee8f200ce35b6f1c966ef5abb3e" +DOWNLOAD="http://download.documentfoundation.org/libreoffice/src/5.3.1/libreoffice-5.3.1.2.tar.xz \ + http://sourceforge.net/projects/slackbuildsdirectlinks/files/LibreOffice/libreoffice-5.3.1.2-srcs.tar.xz" +MD5SUM="4ba66c0812165af9af8e03f3f60280a5 \ + 2ca9b33502785c152217e0ff4092292e" DOWNLOAD_x86_64="" MD5SUM_x86_64="" REQUIRES="python3 openjdk apache-ant perl-Archive-Zip" diff --git a/office/LibreOffice/firebird.diff b/office/LibreOffice/firebird.diff deleted file mode 100644 index 49bc2750c4f12..0000000000000 --- a/office/LibreOffice/firebird.diff +++ /dev/null @@ -1,1091 +0,0 @@ -diff --git a/external/firebird/0001-Avoid-hangup-in-SS-when-error-happens-at-system-atta.patch.1 b/external/firebird/0001-Avoid-hangup-in-SS-when-error-happens-at-system-atta.patch.1 -new file mode 100644 -index 0000000..e569fcc ---- /dev/null -+++ b/external/firebird/0001-Avoid-hangup-in-SS-when-error-happens-at-system-atta.patch.1 -@@ -0,0 +1,51 @@ -+From 36a7a2634669075be3294a1d075524a0b6f80962 Mon Sep 17 00:00:00 2001 -+From: hvlad <hvlad@users.sourceforge.net> -+Date: Wed, 17 Aug 2016 15:45:30 +0300 -+Subject: [PATCH] Avoid hangup in SS when error happens at system attachment -+ initialization time -+ -+--- -+ src/jrd/cch.cpp | 7 ++++++- -+ src/jrd/vio.cpp | 5 +++++ -+ 2 files changed, 11 insertions(+), 1 deletion(-) -+ -+diff --git a/src/jrd/cch.cpp b/src/jrd/cch.cpp -+index 35ea096..643cf4d 100644 -+--- a/src/jrd/cch.cpp -++++ b/src/jrd/cch.cpp -+@@ -2963,10 +2963,15 @@ static THREAD_ENTRY_DECLARE cache_writer(THREAD_ENTRY_PARAM arg) -+ iscDbLogStatus(dbb->dbb_filename.c_str(), &status_vector); -+ } -+ -+- bcb->bcb_flags &= ~(BCB_cache_writer | BCB_writer_start); -++ bcb->bcb_flags &= ~BCB_cache_writer; -+ -+ try -+ { -++ if (bcb->bcb_flags & BCB_writer_start) -++ { -++ bcb->bcb_flags &= ~BCB_writer_start; -++ bcb->bcb_writer_init.release(); -++ } -+ bcb->bcb_writer_fini.release(); -+ } -+ catch (const Firebird::Exception& ex) -+diff --git a/src/jrd/vio.cpp b/src/jrd/vio.cpp -+index a8cf0fc..3d35a27 100644 -+--- a/src/jrd/vio.cpp -++++ b/src/jrd/vio.cpp -+@@ -4988,6 +4988,11 @@ static THREAD_ENTRY_DECLARE garbage_collector(THREAD_ENTRY_PARAM arg) -+ try -+ { -+ // Notify the finalization caller that we're finishing. -++ if (dbb->dbb_flags & DBB_gc_starting) -++ { -++ dbb->dbb_flags &= ~DBB_gc_starting; -++ dbb->dbb_gc_init.release(); -++ } -+ dbb->dbb_gc_fini.release(); -+ } -+ catch (const Firebird::Exception& ex) -+-- -+2.9.3 -+ -diff --git a/external/firebird/0002-Backported-fix-for-CORE-5452-Segfault-when-engine-s-.patch.1 b/external/firebird/0002-Backported-fix-for-CORE-5452-Segfault-when-engine-s-.patch.1 -new file mode 100644 -index 0000000..c55df4d ---- /dev/null -+++ b/external/firebird/0002-Backported-fix-for-CORE-5452-Segfault-when-engine-s-.patch.1 -@@ -0,0 +1,1013 @@ -+From 40f782ae3e918c4f3842571ff8064be1c4f54961 Mon Sep 17 00:00:00 2001 -+From: AlexPeshkoff <peshkoff@mail.ru> -+Date: Fri, 13 Jan 2017 14:29:54 +0300 -+Subject: [PATCH] Backported fix for CORE-5452: Segfault when engine's dynamic -+ library is unloaded right after closing worker threads (GC and/or cache -+ writer) -+ -+--- -+ src/alice/alice_meta.epp | 1 - -+ src/burp/burp.h | 2 - -+ src/common/ThreadStart.h | 86 ++++++++++++++++++++++++++++ -+ src/common/classes/Synchronize.h | 5 +- -+ src/common/classes/misc/class_perf.cpp | 1 - -+ src/common/xdr.cpp | 2 - -+ src/gpre/boot/gpre_meta_boot.cpp | 1 - -+ src/gpre/std/gpre_meta.epp | 1 - -+ src/include/fb_exception.h | 1 - -+ src/include/firebird.h | 1 - -+ src/isql/OptionsBase.cpp | 1 - -+ src/isql/extract.epp | 1 - -+ src/isql/isql.epp | 5 -- -+ src/jrd/Attachment.h | 1 + -+ src/jrd/Database.h | 6 +- -+ src/jrd/Mapping.cpp | 26 +++++---- -+ src/jrd/cch.cpp | 31 +++++----- -+ src/jrd/cch.h | 14 ++++- -+ src/jrd/event.cpp | 13 +++-- -+ src/jrd/event_proto.h | 7 +-- -+ src/jrd/intl.cpp | 1 - -+ src/jrd/trace/TraceConfigStorage.h | 1 + -+ src/jrd/vio.cpp | 23 ++++---- -+ src/lock/lock.cpp | 29 ++++++---- -+ src/lock/lock_proto.h | 8 +-- -+ src/qli/command.cpp | 1 - -+ src/qli/dtr.h | 1 - -+ src/qli/lex.cpp | 4 -- -+ src/qli/meta.epp | 1 - -+ src/utilities/gsec/gsecswi.h | 1 - -+ src/utilities/gstat/dba.epp | 1 + -+ src/utilities/nbackup/nbkswi.h | 1 - -+ src/utilities/ntrace/os/win32/FileObject.cpp | 1 - -+ src/yvalve/gds.cpp | 1 + -+ src/yvalve/preparse.cpp | 1 - -+ 35 files changed, 182 insertions(+), 99 deletions(-) -+ -+diff --git a/src/alice/alice_meta.epp b/src/alice/alice_meta.epp -+index d0f59bc..65dc37e 100644 -+--- a/src/alice/alice_meta.epp -++++ b/src/alice/alice_meta.epp -+@@ -30,7 +30,6 @@ -+ #include "firebird.h" -+ #include <stdio.h> -+ #include "../jrd/ibase.h" -+-//#include "../jrd/license.h" -+ #include "../alice/alice.h" -+ #include "../alice/alice_meta.h" -+ #include "../yvalve/gds_proto.h" -+diff --git a/src/burp/burp.h b/src/burp/burp.h -+index 293a91f..fe26335 100644 -+--- a/src/burp/burp.h -++++ b/src/burp/burp.h -+@@ -769,8 +769,6 @@ struct burp_meta_obj -+ // I need to review if we tolerate different lengths for different OS's here. -+ const unsigned int MAX_FILE_NAME_SIZE = 256; -+ -+-//#include "../jrd/svc.h" -+- -+ #include "../burp/std_desc.h" -+ -+ #ifdef WIN_NT -+diff --git a/src/common/ThreadStart.h b/src/common/ThreadStart.h -+index 85e6a38..823c5c1 100644 -+--- a/src/common/ThreadStart.h -++++ b/src/common/ThreadStart.h -+@@ -31,6 +31,7 @@ -+ #define JRD_THREADSTART_H -+ -+ #include "../common/ThreadData.h" -++#include "../common/classes/semaphore.h" -+ -+ #ifdef WIN_NT -+ #include <windows.h> -+@@ -89,4 +90,89 @@ inline ThreadId getThreadId() -+ return Thread::getId(); -+ } -+ -++ -++#ifndef USE_POSIX_THREADS -++#define USE_FINI_SEM -++#endif -++ -++template <typename TA> -++class ThreadFinishSync -++{ -++public: -++ typedef void ThreadRoutine(TA); -++ -++ ThreadFinishSync(Firebird::MemoryPool& pool, ThreadRoutine* routine, int priority_arg) -++ : -++#ifdef USE_FINI_SEM -++ fini(pool), -++#else -++ threadHandle(0), -++#endif -++ threadRoutine(routine), -++ threadPriority(priority_arg) -++ { } -++ -++ void run(TA arg) -++ { -++ threadArg = arg; -++ -++ Thread::start(internalRun, this, threadPriority -++#ifndef USE_FINI_SEM -++ , &threadHandle -++#endif -++ ); -++ } -++ -++ void waitForCompletion() -++ { -++#ifdef USE_FINI_SEM -++ fini.enter(); -++#else -++ Thread::waitForCompletion(threadHandle); -++ threadHandle = 0; -++#endif -++ } -++ -++private: -++#ifdef USE_FINI_SEM -++ Firebird::Semaphore fini; -++#else -++ Thread::Handle threadHandle; -++#endif -++ -++ TA threadArg; -++ ThreadRoutine* threadRoutine; -++ int threadPriority; -++ bool starting; -++ -++ static THREAD_ENTRY_DECLARE internalRun(THREAD_ENTRY_PARAM arg) -++ { -++ ((ThreadFinishSync*)arg)->internalRun(); -++ return 0; -++ } -++ -++ void internalRun() -++ { -++ try -++ { -++ threadRoutine(threadArg); -++ } -++ catch (const Firebird::Exception& ex) -++ { -++ threadArg->exceptionHandler(ex, threadRoutine); -++ } -++ -++#ifdef USE_FINI_SEM -++ try -++ { -++ fini.release(); -++ } -++ catch (const Firebird::Exception& ex) -++ { -++ threadArg->exceptionHandler(ex, threadRoutine); -++ } -++#endif -++ } -++}; -++ -+ #endif // JRD_THREADSTART_H -+diff --git a/src/common/classes/Synchronize.h b/src/common/classes/Synchronize.h -+index 198de44..3788541 100644 -+--- a/src/common/classes/Synchronize.h -++++ b/src/common/classes/Synchronize.h -+@@ -33,10 +33,7 @@ -+ #define CLASSES_SYNCHRONIZE_H -+ -+ #include "../common/classes/SyncObject.h" -+- -+-#ifndef WIN_NT -+-#include "fb_pthread.h" -+-#endif -++#include "../common/ThreadStart.h" -+ -+ -+ namespace Firebird { -+diff --git a/src/common/classes/misc/class_perf.cpp b/src/common/classes/misc/class_perf.cpp -+index 97b7bb3..142bfde 100644 -+--- a/src/common/classes/misc/class_perf.cpp -++++ b/src/common/classes/misc/class_perf.cpp -+@@ -28,7 +28,6 @@ -+ -+ #include "tree.h" -+ #include "alloc.h" -+-//#include "../memory/memory_pool.h" -+ #include <stdio.h> -+ #include <time.h> -+ #include <set> -+diff --git a/src/common/xdr.cpp b/src/common/xdr.cpp -+index b9f9f4d..1dfff76 100644 -+--- a/src/common/xdr.cpp -++++ b/src/common/xdr.cpp -+@@ -26,9 +26,7 @@ -+ -+ #include "firebird.h" -+ #include <string.h> -+-//#include "../remote/remote.h" -+ #include "../common/xdr.h" -+-//#include "../remote/proto_proto.h" -+ #include "../common/xdr_proto.h" -+ #include "../yvalve/gds_proto.h" -+ #include "../common/gdsassert.h" -+diff --git a/src/gpre/boot/gpre_meta_boot.cpp b/src/gpre/boot/gpre_meta_boot.cpp -+index 0fde018..1f302c6 100644 -+--- a/src/gpre/boot/gpre_meta_boot.cpp -++++ b/src/gpre/boot/gpre_meta_boot.cpp -+@@ -32,7 +32,6 @@ -+ #include <string.h> -+ #include "../jrd/ibase.h" -+ #include "../gpre/gpre.h" -+-//#include "../jrd/license.h" -+ #include "../jrd/intl.h" -+ #include "../gpre/gpre_proto.h" -+ #include "../gpre/hsh_proto.h" -+diff --git a/src/gpre/std/gpre_meta.epp b/src/gpre/std/gpre_meta.epp -+index 34ff932..0780dd4 100644 -+--- a/src/gpre/std/gpre_meta.epp -++++ b/src/gpre/std/gpre_meta.epp -+@@ -32,7 +32,6 @@ -+ #include <string.h> -+ #include "../jrd/ibase.h" -+ #include "../gpre/gpre.h" -+-//#include "../jrd/license.h" -+ #include "../jrd/intl.h" -+ #include "../gpre/gpre_proto.h" -+ #include "../gpre/hsh_proto.h" -+diff --git a/src/include/fb_exception.h b/src/include/fb_exception.h -+index 030cf94..c4c1df4 100644 -+--- a/src/include/fb_exception.h -++++ b/src/include/fb_exception.h -+@@ -43,7 +43,6 @@ -+ -+ #include "fb_types.h" -+ #include "firebird/Interface.h" -+-#include "../common/ThreadStart.h" -+ -+ namespace Firebird -+ { -+diff --git a/src/include/firebird.h b/src/include/firebird.h -+index 3d74354..87f0a11 100644 -+--- a/src/include/firebird.h -++++ b/src/include/firebird.h -+@@ -68,7 +68,6 @@ -+ -+ #ifdef __cplusplus -+ #include "../common/common.h" -+-//#include "fb_exception.h" -+ #endif -+ -+ #ifndef NULL -+diff --git a/src/isql/OptionsBase.cpp b/src/isql/OptionsBase.cpp -+index 5a78540..0974fa3 100644 -+--- a/src/isql/OptionsBase.cpp -++++ b/src/isql/OptionsBase.cpp -+@@ -24,7 +24,6 @@ -+ -+ #include "firebird.h" -+ #include "OptionsBase.h" -+-//#include "../common/utils_proto.h" // strnicmp -+ #include "../common/gdsassert.h" -+ -+ -+diff --git a/src/isql/extract.epp b/src/isql/extract.epp -+index ec2ddb1..99e821c 100644 -+--- a/src/isql/extract.epp -++++ b/src/isql/extract.epp -+@@ -59,7 +59,6 @@ -+ #include "../jrd/ods.h" -+ #include "../common/utils_proto.h" -+ #include "../jrd/constants.h" -+-//#include "../common/classes/ImplementHelper.h" -+ -+ using MsgFormat::SafeArg; -+ -+diff --git a/src/isql/isql.epp b/src/isql/isql.epp -+index ccadce2..98b37bb 100644 -+--- a/src/isql/isql.epp -++++ b/src/isql/isql.epp -+@@ -46,7 +46,6 @@ -+ #include "firebird.h" -+ #include <stdio.h> -+ #include "../yvalve/keywords.h" -+-//#include "../yvalve/gds_proto.h" -+ #include "../jrd/intl.h" -+ #include <stdlib.h> -+ #include <stdarg.h> -+@@ -79,10 +78,6 @@ -+ #include <locale.h> -+ #endif -+ -+-//#ifdef HAVE_IO_H -+-//#include <io.h> // mktemp -+-//#endif -+- -+ #ifdef HAVE_EDITLINE_H -+ // This is a local file included in our distribution - but not always -+ // compiled into the system -+diff --git a/src/jrd/Attachment.h b/src/jrd/Attachment.h -+index 2807db3..e71610e 100644 -+--- a/src/jrd/Attachment.h -++++ b/src/jrd/Attachment.h -+@@ -39,6 +39,7 @@ -+ #include "../common/classes/array.h" -+ #include "../common/classes/stack.h" -+ #include "../common/classes/timestamp.h" -++#include "../common/ThreadStart.h" -+ -+ #include "../jrd/EngineInterface.h" -+ -+diff --git a/src/jrd/Database.h b/src/jrd/Database.h -+index 0eab40d..f0f44d3 100644 -+--- a/src/jrd/Database.h -++++ b/src/jrd/Database.h -+@@ -440,7 +440,7 @@ public: -+ GarbageCollector* dbb_garbage_collector; // GarbageCollector class -+ Firebird::Semaphore dbb_gc_sem; // Event to wake up garbage collector -+ Firebird::Semaphore dbb_gc_init; // Event for initialization garbage collector -+- Firebird::Semaphore dbb_gc_fini; // Event for finalization garbage collector -++ ThreadFinishSync<Database*> dbb_gc_fini; // Sync for finalization garbage collector -+ -+ Firebird::MemoryStats dbb_memory_stats; -+ RuntimeStatistics dbb_stats; -+@@ -511,6 +511,7 @@ private: -+ dbb_owner(*p), -+ dbb_pools(*p, 4), -+ dbb_sort_buffers(*p), -++ dbb_gc_fini(*p, garbage_collector, THREAD_medium), -+ dbb_stats(*p), -+ dbb_lock_owner_id(getLockOwnerId()), -+ dbb_tip_cache(NULL), -+@@ -560,6 +561,9 @@ public: -+ // reset sweep flags and release sweep lock -+ void clearSweepFlags(thread_db* tdbb); -+ -++ static void garbage_collector(Database* dbb); -++ void exceptionHandler(const Firebird::Exception& ex, ThreadFinishSync<Database*>::ThreadRoutine* routine); -++ -+ private: -+ //static int blockingAstSharedCounter(void*); -+ static int blocking_ast_sweep(void* ast_object); -+diff --git a/src/jrd/Mapping.cpp b/src/jrd/Mapping.cpp -+index c1bcf0e..8df7e2f 100644 -+--- a/src/jrd/Mapping.cpp -++++ b/src/jrd/Mapping.cpp -+@@ -581,7 +581,8 @@ class MappingIpc FB_FINAL : public Firebird::IpcObject -+ -+ public: -+ explicit MappingIpc(MemoryPool&) -+- : processId(getpid()) -++ : processId(getpid()), -++ cleanupSync(*getDefaultMemoryPool(), clearDelivery, THREAD_high) -+ { } -+ -+ ~MappingIpc() -+@@ -602,7 +603,7 @@ public: -+ sMem->process[process].flags &= ~MappingHeader::FLAG_ACTIVE; -+ (void) // Ignore errors in cleanup -+ sharedMemory->eventPost(&sMem->process[process].notifyEvent); -+- cleanupSemaphore.tryEnter(5); -++ cleanupSync.waitForCompletion(); -+ -+ // Ignore errors in cleanup -+ sharedMemory->eventFini(&sMem->process[process].notifyEvent); -+@@ -755,7 +756,7 @@ public: -+ -+ try -+ { -+- Thread::start(clearDelivery, this, THREAD_high); -++ cleanupSync.run(this); -+ } -+ catch (const Exception&) -+ { -+@@ -764,6 +765,12 @@ public: -+ } -+ } -+ -++ void exceptionHandler(const Exception& ex, ThreadFinishSync<MappingIpc*>::ThreadRoutine*) -++ { -++ iscLogException("Fatal error in clearDeliveryThread", ex); -++ fb_utils::logAndDie("Fatal error in clearDeliveryThread"); -++ } -++ -+ private: -+ void clearDeliveryThread() -+ { -+@@ -801,13 +808,10 @@ private: -+ } -+ if (startup) -+ startupSemaphore.release(); -+- -+- cleanupSemaphore.release(); -+ } -+ catch (const Exception& ex) -+ { -+- iscLogException("Fatal error in clearDeliveryThread", ex); -+- fb_utils::logAndDie("Fatal error in clearDeliveryThread"); -++ exceptionHandler(ex, NULL); -+ } -+ } -+ -+@@ -862,11 +866,9 @@ private: -+ MappingIpc* const data; -+ }; -+ -+- static THREAD_ENTRY_DECLARE clearDelivery(THREAD_ENTRY_PARAM par) -++ static void clearDelivery(MappingIpc* mapping) -+ { -+- MappingIpc* m = (MappingIpc*)par; -+- m->clearDeliveryThread(); -+- return 0; -++ mapping->clearDeliveryThread(); -+ } -+ -+ AutoPtr<SharedMemory<MappingHeader> > sharedMemory; -+@@ -874,7 +876,7 @@ private: -+ const SLONG processId; -+ unsigned process; -+ Semaphore startupSemaphore; -+- Semaphore cleanupSemaphore; -++ ThreadFinishSync<MappingIpc*> cleanupSync; -+ }; -+ -+ GlobalPtr<MappingIpc, InstanceControl::PRIORITY_DELETE_FIRST> mappingIpc; -+diff --git a/src/jrd/cch.cpp b/src/jrd/cch.cpp -+index e1d403b..1bf714f 100644 -+--- a/src/jrd/cch.cpp -++++ b/src/jrd/cch.cpp -+@@ -120,14 +120,11 @@ static BufferDesc* alloc_bdb(thread_db*, BufferControl*, UCHAR **); -+ static Lock* alloc_page_lock(Jrd::thread_db*, BufferDesc*); -+ static int blocking_ast_bdb(void*); -+ #ifdef CACHE_READER -+-static THREAD_ENTRY_DECLARE cache_reader(THREAD_ENTRY_PARAM); -+- -+ static void prefetch_epilogue(Prefetch*, FbStatusVector *); -+ static void prefetch_init(Prefetch*, thread_db*); -+ static void prefetch_io(Prefetch*, FbStatusVector *); -+ static void prefetch_prologue(Prefetch*, SLONG *); -+ #endif -+-static THREAD_ENTRY_DECLARE cache_writer(THREAD_ENTRY_PARAM); -+ static void check_precedence(thread_db*, WIN*, PageNumber); -+ static void clear_precedence(thread_db*, BufferDesc*); -+ static BufferDesc* dealloc_bdb(BufferDesc*); -+@@ -1438,7 +1435,7 @@ void CCH_init2(thread_db* tdbb) -+ -+ try -+ { -+- Thread::start(cache_writer, dbb, THREAD_medium); -++ bcb->bcb_writer_fini.run(bcb); -+ } -+ catch (const Exception&) -+ { -+@@ -2017,7 +2014,7 @@ void CCH_shutdown(thread_db* tdbb) -+ { -+ bcb->bcb_flags &= ~BCB_cache_writer; -+ bcb->bcb_writer_sem.release(); // Wake up running thread -+- bcb->bcb_writer_fini.enter(); -++ bcb->bcb_writer_fini.waitForCompletion(); -+ } -+ -+ SyncLockGuard bcbSync(&bcb->bcb_syncObject, SYNC_EXCLUSIVE, "CCH_shutdown"); -+@@ -2692,7 +2689,7 @@ static void flushAll(thread_db* tdbb, USHORT flush_flag) -+ -+ -+ #ifdef CACHE_READER -+-static THREAD_ENTRY_DECLARE cache_reader(THREAD_ENTRY_PARAM arg) -++void BufferControl::cache_reader(BufferControl* bcb) -+ { -+ /************************************** -+ * -+@@ -2706,7 +2703,7 @@ static THREAD_ENTRY_DECLARE cache_reader(THREAD_ENTRY_PARAM arg) -+ * busy at a time. -+ * -+ **************************************/ -+- Database* dbb = (Database*) arg; -++ Database* dbb = bcb->bcb_database; -+ Database::SyncGuard dsGuard(dbb); -+ -+ FbLocalStatus status_vector; -+@@ -2846,7 +2843,7 @@ static THREAD_ENTRY_DECLARE cache_reader(THREAD_ENTRY_PARAM arg) -+ #endif -+ -+ -+-static THREAD_ENTRY_DECLARE cache_writer(THREAD_ENTRY_PARAM arg) -++void BufferControl::cache_writer(BufferControl* bcb) -+ { -+ /************************************** -+ * -+@@ -2859,8 +2856,7 @@ static THREAD_ENTRY_DECLARE cache_writer(THREAD_ENTRY_PARAM arg) -+ * -+ **************************************/ -+ FbLocalStatus status_vector; -+- Database* const dbb = (Database*) arg; -+- BufferControl* const bcb = dbb->dbb_bcb; -++ Database* const dbb = bcb->bcb_database; -+ -+ try -+ { -+@@ -2964,8 +2960,7 @@ static THREAD_ENTRY_DECLARE cache_writer(THREAD_ENTRY_PARAM arg) -+ } // try -+ catch (const Firebird::Exception& ex) -+ { -+- ex.stuffException(&status_vector); -+- iscDbLogStatus(dbb->dbb_filename.c_str(), &status_vector); -++ bcb->exceptionHandler(ex, cache_writer); -+ } -+ -+ bcb->bcb_flags &= ~BCB_cache_writer; -+@@ -2977,15 +2972,19 @@ static THREAD_ENTRY_DECLARE cache_writer(THREAD_ENTRY_PARAM arg) -+ bcb->bcb_flags &= ~BCB_writer_start; -+ bcb->bcb_writer_init.release(); -+ } -+- bcb->bcb_writer_fini.release(); -+ } -+ catch (const Firebird::Exception& ex) -+ { -+- ex.stuffException(&status_vector); -+- iscDbLogStatus(dbb->dbb_filename.c_str(), &status_vector); -++ bcb->exceptionHandler(ex, cache_writer); -+ } -++} -+ -+- return 0; -++ -++void BufferControl::exceptionHandler(const Firebird::Exception& ex, BcbSync::ThreadRoutine* /*routine*/) -++{ -++ FbLocalStatus status_vector; -++ ex.stuffException(&status_vector); -++ iscDbLogStatus(bcb_database->dbb_filename.c_str(), &status_vector); -+ } -+ -+ -+diff --git a/src/jrd/cch.h b/src/jrd/cch.h -+index b920566..b7f8486 100644 -+--- a/src/jrd/cch.h -++++ b/src/jrd/cch.h -+@@ -29,6 +29,7 @@ -+ #include "../common/classes/RefCounted.h" -+ #include "../common/classes/semaphore.h" -+ #include "../common/classes/SyncObject.h" -++#include "../common/ThreadStart.h" -+ #ifdef SUPERSERVER_V2 -+ #include "../jrd/sbm.h" -+ #include "../jrd/pag.h" -+@@ -85,7 +86,8 @@ class BufferControl : public pool_alloc<type_bcb> -+ BufferControl(MemoryPool& p, Firebird::MemoryStats& parentStats) -+ : bcb_bufferpool(&p), -+ bcb_memory_stats(&parentStats), -+- bcb_memory(p) -++ bcb_memory(p), -++ bcb_writer_fini(p, cache_writer, THREAD_medium) -+ { -+ bcb_database = NULL; -+ QUE_INIT(bcb_in_use); -+@@ -144,18 +146,24 @@ public: -+ Firebird::SyncObject bcb_syncLRU; -+ //Firebird::SyncObject bcb_syncPageWrite; -+ -++ typedef ThreadFinishSync<BufferControl*> BcbSync; -++ -++ static void cache_writer(BufferControl* bcb); -+ Firebird::Semaphore bcb_writer_sem; // Wake up cache writer -+ Firebird::Semaphore bcb_writer_init; // Cache writer initialization -+- Firebird::Semaphore bcb_writer_fini; // Cache writer finalization -++ BcbSync bcb_writer_fini; // Cache writer finalization -+ #ifdef SUPERSERVER_V2 -++ static void cache_reader(BufferControl* bcb); -+ // the code in cch.cpp is not tested for semaphore instead event !!! -+ Firebird::Semaphore bcb_reader_sem; // Wake up cache reader -+ Firebird::Semaphore bcb_reader_init; // Cache reader initialization -+- Firebird::Semaphore bcb_reader_fini; // Cache reader finalization -++ BcbSync bcb_reader_fini; // Cache reader finalization -+ -+ PageBitmap* bcb_prefetch; // Bitmap of pages to prefetch -+ #endif -+ -++ void exceptionHandler(const Firebird::Exception& ex, BcbSync::ThreadRoutine* routine); -++ -+ bcb_repeat* bcb_rpt; -+ }; -+ -+diff --git a/src/jrd/event.cpp b/src/jrd/event.cpp -+index 3a6bf28..cb6dc33 100644 -+--- a/src/jrd/event.cpp -++++ b/src/jrd/event.cpp -+@@ -126,6 +126,7 @@ EventManager::EventManager(const Firebird::string& id, Firebird::RefPtr<Config> -+ m_processOffset(0), -+ m_dbId(getPool(), id), -+ m_config(conf), -++ m_cleanupSync(getPool(), watcher_thread, THREAD_medium), -+ m_sharedFileCreated(false), -+ m_exiting(false) -+ { -+@@ -146,7 +147,7 @@ EventManager::~EventManager() -+ // Terminate the event watcher thread -+ m_startupSemaphore.tryEnter(5); -+ (void) m_sharedMemory->eventPost(&m_process->prb_event); -+- m_cleanupSemaphore.tryEnter(5); -++ m_cleanupSync.waitForCompletion(); -+ -+ #ifdef HAVE_OBJECT_MAP -+ m_sharedMemory->unmapObject(&localStatus, &m_process); -+@@ -697,7 +698,7 @@ void EventManager::create_process() -+ -+ release_shmem(); -+ -+- Thread::start(watcher_thread, this, THREAD_medium); -++ m_cleanupSync.run(this); -+ } -+ -+ -+@@ -1414,12 +1415,16 @@ void EventManager::watcher_thread() -+ { -+ m_startupSemaphore.release(); -+ } -+- m_cleanupSemaphore.release(); -+ } -+ catch (const Firebird::Exception& ex) -+ { -+- iscLogException("Error closing event watcher thread\n", ex); -++ exceptionHandler(ex, NULL); -+ } -+ } -+ -++void EventManager::exceptionHandler(const Firebird::Exception& ex, ThreadFinishSync<EventManager*>::ThreadRoutine*) -++{ -++ iscLogException("Error closing event watcher thread\n", ex); -++} -++ -+ } // namespace -+diff --git a/src/jrd/event_proto.h b/src/jrd/event_proto.h -+index 3301203..9bfd20e 100644 -+--- a/src/jrd/event_proto.h -++++ b/src/jrd/event_proto.h -+@@ -63,6 +63,7 @@ public: -+ -+ bool initialize(Firebird::SharedMemoryBase*, bool); -+ void mutexBug(int osErrorCode, const char* text); -++ void exceptionHandler(const Firebird::Exception& ex, ThreadFinishSync<EventManager*>::ThreadRoutine* routine); -+ -+ private: -+ void acquire_shmem(); -+@@ -91,11 +92,9 @@ private: -+ void detach_shared_file(); -+ void get_shared_file_name(Firebird::PathName&) const; -+ -+- static THREAD_ENTRY_DECLARE watcher_thread(THREAD_ENTRY_PARAM arg) -++ static void watcher_thread(EventManager* eventMgr) -+ { -+- EventManager* const eventMgr = static_cast<EventManager*>(arg); -+ eventMgr->watcher_thread(); -+- return 0; -+ } -+ -+ static void mutex_bugcheck(const TEXT*, int); -+@@ -109,7 +108,7 @@ private: -+ Firebird::AutoPtr<Firebird::SharedMemory<evh> > m_sharedMemory; -+ -+ Firebird::Semaphore m_startupSemaphore; -+- Firebird::Semaphore m_cleanupSemaphore; -++ ThreadFinishSync<EventManager*> m_cleanupSync; -+ -+ bool m_sharedFileCreated; -+ bool m_exiting; -+diff --git a/src/jrd/intl.cpp b/src/jrd/intl.cpp -+index 6666c5f..b0e662b 100644 -+--- a/src/jrd/intl.cpp -++++ b/src/jrd/intl.cpp -+@@ -104,7 +104,6 @@ -+ #include "../intl/charsets.h" -+ #include "../intl/country_codes.h" -+ #include "../common/gdsassert.h" -+-//#include "../jrd/license.h" -+ #ifdef INTL_BUILTIN -+ #include "../intl/ld_proto.h" -+ #endif -+diff --git a/src/jrd/trace/TraceConfigStorage.h b/src/jrd/trace/TraceConfigStorage.h -+index ca973c0..3d08143 100644 -+--- a/src/jrd/trace/TraceConfigStorage.h -++++ b/src/jrd/trace/TraceConfigStorage.h -+@@ -32,6 +32,7 @@ -+ #include "../../common/classes/fb_string.h" -+ #include "../../common/classes/init.h" -+ #include "../../common/isc_s_proto.h" -++#include "../../common/ThreadStart.h" -+ #include "../../jrd/trace/TraceSession.h" -+ #include "../../common/classes/RefCounted.h" -+ -+diff --git a/src/jrd/vio.cpp b/src/jrd/vio.cpp -+index 02c5809..8ca9f66 100644 -+--- a/src/jrd/vio.cpp -++++ b/src/jrd/vio.cpp -+@@ -107,7 +107,6 @@ static bool dfw_should_know(record_param* org_rpb, record_param* new_rpb, -+ USHORT irrelevant_field, bool void_update_is_relevant = false); -+ static void garbage_collect(thread_db*, record_param*, ULONG, RecordStack&); -+ static void garbage_collect_idx(thread_db*, record_param*, Record*, Record*); -+-static THREAD_ENTRY_DECLARE garbage_collector(THREAD_ENTRY_PARAM); -+ -+ -+ #ifdef VIO_DEBUG -+@@ -1958,7 +1957,7 @@ void VIO_fini(thread_db* tdbb) -+ { -+ dbb->dbb_flags &= ~DBB_garbage_collector; -+ dbb->dbb_gc_sem.release(); // Wake up running thread -+- dbb->dbb_gc_fini.enter(); -++ dbb->dbb_gc_fini.waitForCompletion(); -+ } -+ } -+ -+@@ -2420,7 +2419,7 @@ void VIO_init(thread_db* tdbb) -+ { -+ try -+ { -+- Thread::start(garbage_collector, dbb, THREAD_medium); -++ dbb->dbb_gc_fini.run(dbb); -+ } -+ catch (const Exception&) -+ { -+@@ -4741,7 +4740,7 @@ static void garbage_collect_idx(thread_db* tdbb, -+ } -+ -+ -+-static THREAD_ENTRY_DECLARE garbage_collector(THREAD_ENTRY_PARAM arg) -++void Database::garbage_collector(Database* dbb) -+ { -+ /************************************** -+ * -+@@ -4758,7 +4757,6 @@ static THREAD_ENTRY_DECLARE garbage_collector(THREAD_ENTRY_PARAM arg) -+ * -+ **************************************/ -+ FbLocalStatus status_vector; -+- Database* const dbb = (Database*) arg; -+ -+ try -+ { -+@@ -4989,8 +4987,7 @@ static THREAD_ENTRY_DECLARE garbage_collector(THREAD_ENTRY_PARAM arg) -+ } // try -+ catch (const Firebird::Exception& ex) -+ { -+- ex.stuffException(&status_vector); -+- iscDbLogStatus(dbb->dbb_filename.c_str(), &status_vector); -++ dbb->exceptionHandler(ex, NULL); -+ } -+ -+ dbb->dbb_flags &= ~(DBB_garbage_collector | DBB_gc_active | DBB_gc_pending); -+@@ -5003,15 +5000,19 @@ static THREAD_ENTRY_DECLARE garbage_collector(THREAD_ENTRY_PARAM arg) -+ dbb->dbb_flags &= ~DBB_gc_starting; -+ dbb->dbb_gc_init.release(); -+ } -+- dbb->dbb_gc_fini.release(); -+ } -+ catch (const Firebird::Exception& ex) -+ { -+- ex.stuffException(&status_vector); -+- iscDbLogStatus(dbb->dbb_filename.c_str(), &status_vector); -++ dbb->exceptionHandler(ex, NULL); -+ } -++} -++ -+ -+- return 0; -++void Database::exceptionHandler(const Firebird::Exception& ex, ThreadFinishSync<Database*>::ThreadRoutine* /*routine*/) -++{ -++ FbLocalStatus status_vector; -++ ex.stuffException(&status_vector); -++ iscDbLogStatus(dbb_filename.c_str(), &status_vector); -+ } -+ -+ -+diff --git a/src/lock/lock.cpp b/src/lock/lock.cpp -+index 89eb4c5..2ab3358 100644 -+--- a/src/lock/lock.cpp -++++ b/src/lock/lock.cpp -+@@ -214,6 +214,7 @@ LockManager::LockManager(const Firebird::string& id, RefPtr<Config> conf) -+ m_sharedFileCreated(false), -+ m_process(NULL), -+ m_processOffset(0), -++ m_cleanupSync(getPool(), blocking_action_thread, THREAD_high), -+ m_sharedMemory(NULL), -+ m_blockage(false), -+ m_dbId(getPool(), id), -+@@ -259,7 +260,7 @@ LockManager::~LockManager() -+ m_sharedMemory->eventPost(&m_process->prc_blocking); -+ -+ // Wait for the AST thread to finish cleanup or for 5 seconds -+- m_cleanupSemaphore.tryEnter(5); -++ m_cleanupSync.waitForCompletion(); -+ } -+ -+ #ifdef HAVE_OBJECT_MAP -+@@ -1548,16 +1549,22 @@ void LockManager::blocking_action_thread() -+ { -+ iscLogException("Error in blocking action thread\n", x); -+ } -++} -+ -+- try -+- { -+- // Wakeup the main thread waiting for our exit -+- m_cleanupSemaphore.release(); -+- } -+- catch (const Firebird::Exception& x) -+- { -+- iscLogException("Error closing blocking action thread\n", x); -+- } -++ -++void LockManager::exceptionHandler(const Firebird::Exception& ex, ThreadFinishSync<LockManager*>::ThreadRoutine* /*routine*/) -++{ -++/************************************** -++ * -++ * e x c e p t i o n H a n d l e r -++ * -++ ************************************** -++ * -++ * Functional description -++ * Handler for blocking thread close bugs. -++ * -++ **************************************/ -++ iscLogException("Error closing blocking action thread\n", ex); -+ } -+ -+ -+@@ -1815,7 +1822,7 @@ bool LockManager::create_process(CheckStatusWrapper* statusVector) -+ { -+ try -+ { -+- Thread::start(blocking_action_thread, this, THREAD_high); -++ m_cleanupSync.run(this); -+ } -+ catch (const Exception& ex) -+ { -+diff --git a/src/lock/lock_proto.h b/src/lock/lock_proto.h -+index d991c1e..2faec49 100644 -+--- a/src/lock/lock_proto.h -++++ b/src/lock/lock_proto.h -+@@ -418,6 +418,8 @@ public: -+ SINT64 readData2(USHORT, const UCHAR*, USHORT, SRQ_PTR); -+ SINT64 writeData(SRQ_PTR, SINT64); -+ -++ void exceptionHandler(const Firebird::Exception& ex, ThreadFinishSync<LockManager*>::ThreadRoutine* routine); -++ -+ private: -+ explicit LockManager(const Firebird::string&, Firebird::RefPtr<Config>); -+ ~LockManager(); -+@@ -471,11 +473,9 @@ private: -+ void detach_shared_file(Firebird::CheckStatusWrapper*); -+ void get_shared_file_name(Firebird::PathName&, ULONG extend = 0) const; -+ -+- static THREAD_ENTRY_DECLARE blocking_action_thread(THREAD_ENTRY_PARAM arg) -++ static void blocking_action_thread(LockManager* lockMgr) -+ { -+- LockManager* const lockMgr = static_cast<LockManager*>(arg); -+ lockMgr->blocking_action_thread(); -+- return 0; -+ } -+ -+ bool initialize(Firebird::SharedMemoryBase* sm, bool init); -+@@ -490,7 +490,7 @@ private: -+ Firebird::RWLock m_remapSync; -+ Firebird::AtomicCounter m_waitingOwners; -+ -+- Firebird::Semaphore m_cleanupSemaphore; -++ ThreadFinishSync<LockManager*> m_cleanupSync; -+ Firebird::Semaphore m_startupSemaphore; -+ -+ public: -+diff --git a/src/qli/command.cpp b/src/qli/command.cpp -+index 5f949f3..fbbf4fb 100644 -+--- a/src/qli/command.cpp -++++ b/src/qli/command.cpp -+@@ -30,7 +30,6 @@ -+ #include "../qli/parse.h" -+ #include "../qli/compile.h" -+ #include "../qli/exe.h" -+-//#include "../jrd/license.h" -+ #include "../qli/all_proto.h" -+ #include "../qli/err_proto.h" -+ #include "../qli/exe_proto.h" -+diff --git a/src/qli/dtr.h b/src/qli/dtr.h -+index ba5cd64..e246ef4 100644 -+--- a/src/qli/dtr.h -++++ b/src/qli/dtr.h -+@@ -480,7 +480,6 @@ struct qli_fun -+ }; -+ -+ // Program wide globals -+-//#include <setjmp.h> -+ -+ #ifdef QLI_MAIN -+ #define EXTERN -+diff --git a/src/qli/lex.cpp b/src/qli/lex.cpp -+index c20d1f9..9e26046 100644 -+--- a/src/qli/lex.cpp -++++ b/src/qli/lex.cpp -+@@ -50,10 +50,6 @@ using MsgFormat::SafeArg; -+ #include <unistd.h> -+ #endif -+ -+-//#ifdef HAVE_CTYPES_H -+-//#include <ctypes.h> -+-//#endif -+- -+ #ifdef HAVE_IO_H -+ #include <io.h> // isatty -+ #endif -+diff --git a/src/qli/meta.epp b/src/qli/meta.epp -+index a7f222c..2d55716 100644 -+--- a/src/qli/meta.epp -++++ b/src/qli/meta.epp -+@@ -28,7 +28,6 @@ -+ #include "../qli/dtr.h" -+ #include "../qli/compile.h" -+ #include "../qli/exe.h" -+-//#include "../jrd/license.h" -+ #include "../jrd/flags.h" -+ #include "../jrd/ibase.h" -+ #include "../qli/reqs.h" -+diff --git a/src/utilities/gsec/gsecswi.h b/src/utilities/gsec/gsecswi.h -+index b8519f5..9b560e3 100644 -+--- a/src/utilities/gsec/gsecswi.h -++++ b/src/utilities/gsec/gsecswi.h -+@@ -24,7 +24,6 @@ -+ #ifndef GSEC_GSECSWI_H -+ #define GSEC_GSECSWI_H -+ -+-//#include "../common/common.h" -+ #include "../jrd/constants.h" -+ -+ /* Switch handling constants. Note that the first IN_SW_DATA_ITEMS -+diff --git a/src/utilities/gstat/dba.epp b/src/utilities/gstat/dba.epp -+index 379b418..19b99d1 100644 -+--- a/src/utilities/gstat/dba.epp -++++ b/src/utilities/gstat/dba.epp -+@@ -56,6 +56,7 @@ -+ #include "../common/classes/UserBlob.h" -+ #include "../common/os/os_utils.h" -+ #include "../common/StatusHolder.h" -++#include "../common/ThreadStart.h" -+ -+ using MsgFormat::SafeArg; -+ -+diff --git a/src/utilities/nbackup/nbkswi.h b/src/utilities/nbackup/nbkswi.h -+index 4326c3d..b8d43da 100644 -+--- a/src/utilities/nbackup/nbkswi.h -++++ b/src/utilities/nbackup/nbkswi.h -+@@ -27,7 +27,6 @@ -+ #ifndef NBACKUP_NBKSWI_H -+ #define NBACKUP_NBKSWI_H -+ -+-//#include "../common/common.h" -+ #include "../jrd/constants.h" -+ -+ // Switch handling constants -+diff --git a/src/utilities/ntrace/os/win32/FileObject.cpp b/src/utilities/ntrace/os/win32/FileObject.cpp -+index 73ed38f..53fbfc0 100644 -+--- a/src/utilities/ntrace/os/win32/FileObject.cpp -++++ b/src/utilities/ntrace/os/win32/FileObject.cpp -+@@ -27,7 +27,6 @@ -+ -+ #include "firebird.h" -+ #include "../FileObject.h" -+-//#include "../common/classes/locks.h" -+ -+ using namespace Firebird; -+ Firebird::Mutex open_mutex; -+diff --git a/src/yvalve/gds.cpp b/src/yvalve/gds.cpp -+index c851f7c..998bbde 100644 -+--- a/src/yvalve/gds.cpp -++++ b/src/yvalve/gds.cpp -+@@ -57,6 +57,7 @@ -+ #include "../common/classes/init.h" -+ #include "../common/classes/TempFile.h" -+ #include "../common/utils_proto.h" -++#include "../common/ThreadStart.h" -+ -+ #ifdef HAVE_UNISTD_H -+ #include <unistd.h> -+diff --git a/src/yvalve/preparse.cpp b/src/yvalve/preparse.cpp -+index b2335a5..e742784 100644 -+--- a/src/yvalve/preparse.cpp -++++ b/src/yvalve/preparse.cpp -+@@ -25,7 +25,6 @@ -+ #include "firebird.h" -+ #include <stdlib.h> -+ #include <string.h> -+-//#include "../dsql/chars.h" -+ #include "../yvalve/prepa_proto.h" -+ #include "../yvalve/gds_proto.h" -+ #include "../yvalve/YObjects.h" -+--- a/src/common/isc_sync.cpp -++++ b/src/common/isc_sync.cpp -+@@ -67,6 +67,7 @@ -+ #include "../common/classes/RefMutex.h" -+ #include "../common/classes/array.h" -+ #include "../common/StatusHolder.h" -++#include "../common/ThreadStart.h" -+ -+ static int process_id; -+ -+-- -+2.9.3 -+ -diff --git a/external/firebird/UnpackedTarball_firebird.mk b/external/firebird/UnpackedTarball_firebird.mk -index b65d041..d62bad7 100644 ---- a/external/firebird/UnpackedTarball_firebird.mk -+++ b/external/firebird/UnpackedTarball_firebird.mk -@@ -22,6 +22,8 @@ $(eval $(call gb_UnpackedTarball_add_patches,firebird,\ - external/firebird/wnt-dbgutil.patch \ - external/firebird/debug-gfix-failure.patch \ - external/firebird/libc++.patch \ -+ external/firebird/0001-Avoid-hangup-in-SS-when-error-happens-at-system-atta.patch.1 \ -+ external/firebird/0002-Backported-fix-for-CORE-5452-Segfault-when-engine-s-.patch.1 \ - )) - - ifeq ($(OS)-$(COM),WNT-MSC) - -generated by cgit v0.10.2 at 2017-02-14 10:16:39 (GMT) |