Author: fernando
Date: Sun Mar 16 06:09:52 2014
New Revision: 2858

Log:
Fixes to build and secure fix for MariaDB-10.0.9.

Added:
   trunk/pcre/pcre-8.34-stack_guard-1.patch

Added: trunk/pcre/pcre-8.34-stack_guard-1.patch
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ trunk/pcre/pcre-8.34-stack_guard-1.patch    Sun Mar 16 06:09:52 2014        
(r2858)
@@ -0,0 +1,88 @@
+Submitted by:            Bruce Dubbs (bdubbs_at_linuxfromscratch_dot_org)
+Date:                    2014-03-16
+Initial Package Version: 8.34
+Upstream Status:         Committed
+Origin:                  Mageia (asked MariaDB to produce the patch)
+URL:                     https://bugs.mageia.org/show_bug.cgi?id=12665
+Description:             Eliminates the chance of anyone crashing 
MariaDB-10.0.9 server with a simple " SELECT a RLIKE REPEAT('(', 1000);" 
statement and fixes a build problem also of MariaDB-10.0.9 
(pcre-8.34/pcre_compile.c:7997: undefined reference to `pcre_stack_guard')
+
+
+--- pcre-8.34/pcre_compile.c   2013-12-15 17:56:22.000000000 +0100
++++ pcre-8.34/pcre_compile.c   2014-02-07 19:43:10.759051139 +0100
+@@ -7994,6 +7994,12 @@ unsigned int orig_bracount;
+ unsigned int max_bracount;
+ branch_chain bc;
+ 
++if (PUBL(stack_guard) && PUBL(stack_guard)())
++{
++  *errorcodeptr= ERR23;
++  return FALSE;
++}
++ 
+ bc.outer = bcptr;
+ bc.current_branch = code;
+ 
+--- pcre-8.34/pcre_globals.c   2012-01-05 18:07:07.000000000 +0100
++++ pcre-8.34/pcre_globals.c   2014-02-07 19:43:10.760051139 +0100
+@@ -72,6 +72,7 @@ PCRE_EXP_DATA_DEFN void  (*PUBL(free))(v
+ PCRE_EXP_DATA_DEFN void *(*PUBL(stack_malloc))(size_t) = LocalPcreMalloc;
+ PCRE_EXP_DATA_DEFN void  (*PUBL(stack_free))(void *) = LocalPcreFree;
+ PCRE_EXP_DATA_DEFN int   (*PUBL(callout))(PUBL(callout_block) *) = NULL;
++PCRE_EXP_DATA_DEFN int   (*PUBL(stack_guard))(void) = NULL;
+ 
+ #elif !defined VPCOMPAT
+ PCRE_EXP_DATA_DEFN void *(*PUBL(malloc))(size_t) = malloc;
+@@ -79,6 +80,7 @@ PCRE_EXP_DATA_DEFN void  (*PUBL(free))(v
+ PCRE_EXP_DATA_DEFN void *(*PUBL(stack_malloc))(size_t) = malloc;
+ PCRE_EXP_DATA_DEFN void  (*PUBL(stack_free))(void *) = free;
+ PCRE_EXP_DATA_DEFN int   (*PUBL(callout))(PUBL(callout_block) *) = NULL;
++PCRE_EXP_DATA_DEFN int   (*PUBL(stack_guard))(void) = NULL;
+ #endif
+ 
+ /* End of pcre_globals.c */
+--- pcre-8.34/pcre.h.in        2013-11-12 16:09:38.000000000 +0100
++++ pcre-8.34/pcre.h.in        2014-02-07 19:43:10.756051138 +0100
+@@ -491,36 +491,42 @@ PCRE_EXP_DECL void  (*pcre_free)(void *)
+ PCRE_EXP_DECL void *(*pcre_stack_malloc)(size_t);
+ PCRE_EXP_DECL void  (*pcre_stack_free)(void *);
+ PCRE_EXP_DECL int   (*pcre_callout)(pcre_callout_block *);
++PCRE_EXP_DECL int   (*pcre_stack_guard)(void);
+ 
+ PCRE_EXP_DECL void *(*pcre16_malloc)(size_t);
+ PCRE_EXP_DECL void  (*pcre16_free)(void *);
+ PCRE_EXP_DECL void *(*pcre16_stack_malloc)(size_t);
+ PCRE_EXP_DECL void  (*pcre16_stack_free)(void *);
+ PCRE_EXP_DECL int   (*pcre16_callout)(pcre16_callout_block *);
++PCRE_EXP_DECL int   (*pcre16_stack_guard)(void);
+ 
+ PCRE_EXP_DECL void *(*pcre32_malloc)(size_t);
+ PCRE_EXP_DECL void  (*pcre32_free)(void *);
+ PCRE_EXP_DECL void *(*pcre32_stack_malloc)(size_t);
+ PCRE_EXP_DECL void  (*pcre32_stack_free)(void *);
+ PCRE_EXP_DECL int   (*pcre32_callout)(pcre32_callout_block *);
++PCRE_EXP_DECL int   (*pcre32_stack_guard)(void);
+ #else   /* VPCOMPAT */
+ PCRE_EXP_DECL void *pcre_malloc(size_t);
+ PCRE_EXP_DECL void  pcre_free(void *);
+ PCRE_EXP_DECL void *pcre_stack_malloc(size_t);
+ PCRE_EXP_DECL void  pcre_stack_free(void *);
+ PCRE_EXP_DECL int   pcre_callout(pcre_callout_block *);
++PCRE_EXP_DECL int   pcre_stack_guard(void);
+ 
+ PCRE_EXP_DECL void *pcre16_malloc(size_t);
+ PCRE_EXP_DECL void  pcre16_free(void *);
+ PCRE_EXP_DECL void *pcre16_stack_malloc(size_t);
+ PCRE_EXP_DECL void  pcre16_stack_free(void *);
+ PCRE_EXP_DECL int   pcre16_callout(pcre16_callout_block *);
++PCRE_EXP_DECL int   (*pcre16_stack_guard)(void);
+ 
+ PCRE_EXP_DECL void *pcre32_malloc(size_t);
+ PCRE_EXP_DECL void  pcre32_free(void *);
+ PCRE_EXP_DECL void *pcre32_stack_malloc(size_t);
+ PCRE_EXP_DECL void  pcre32_stack_free(void *);
+ PCRE_EXP_DECL int   pcre32_callout(pcre32_callout_block *);
++PCRE_EXP_DECL int   (*pcre32_stack_guard)(void);
+ #endif  /* VPCOMPAT */
+ 
+ /* User defined callback which provides a stack just before the match starts. 
*/
+
-- 
http://linuxfromscratch.org/mailman/listinfo/patches
FAQ: http://www.linuxfromscratch.org/faq/
Unsubscribe: See the above information page

Reply via email to