Blame SOURCES/Judy-1.0.5-undefined-behavior.patch

f7f82a
diff -crb judy-1.0.5-orig/src/JudyCommon/JudyByCount.c judy-1.0.5/src/JudyCommon/JudyByCount.c
f7f82a
*** judy-1.0.5-orig/src/JudyCommon/JudyByCount.c	2005-02-15 15:06:07.000000000 -0600
f7f82a
--- judy-1.0.5/src/JudyCommon/JudyByCount.c	2014-02-18 13:45:35.225145230 -0600
f7f82a
***************
f7f82a
*** 817,823 ****
f7f82a
  // Shorthand for where to find start of Index bytes array:
f7f82a
  
f7f82a
  #ifdef JUDY1
f7f82a
! #define	PJI (Pjp->jp_1Index)
f7f82a
  #else
f7f82a
  #define	PJI (Pjp->jp_LIndex)
f7f82a
  #endif
f7f82a
--- 817,823 ----
f7f82a
  // Shorthand for where to find start of Index bytes array:
f7f82a
  
f7f82a
  #ifdef JUDY1
f7f82a
! #define	PJI (Pjp->jp_2Index)
f7f82a
  #else
f7f82a
  #define	PJI (Pjp->jp_LIndex)
f7f82a
  #endif
f7f82a
diff -crb judy-1.0.5-orig/src/JudyCommon/JudyGet.c judy-1.0.5/src/JudyCommon/JudyGet.c
f7f82a
*** judy-1.0.5-orig/src/JudyCommon/JudyGet.c	2005-02-15 15:06:07.000000000 -0600
f7f82a
--- judy-1.0.5/src/JudyCommon/JudyGet.c	2014-02-18 13:49:50.840632644 -0600
f7f82a
***************
f7f82a
*** 630,636 ****
f7f82a
  #ifdef JUDY1
f7f82a
  
f7f82a
  #define CHECKINDEXNATIVE(LEAF_T, PJP, IDX, INDEX)                       \
f7f82a
! if (((LEAF_T *)((PJP)->jp_1Index))[(IDX) - 1] == (LEAF_T)(INDEX))       \
f7f82a
      return(1)
f7f82a
  
f7f82a
  #define CHECKLEAFNONNAT(LFBTS, PJP, INDEX, IDX, COPY)                   \
f7f82a
--- 630,636 ----
f7f82a
  #ifdef JUDY1
f7f82a
  
f7f82a
  #define CHECKINDEXNATIVE(LEAF_T, PJP, IDX, INDEX)                       \
f7f82a
! if (((LEAF_T *)((PJP)->jp_2Index))[(IDX) - 1] == (LEAF_T)(INDEX))       \
f7f82a
      return(1)
f7f82a
  
f7f82a
  #define CHECKLEAFNONNAT(LFBTS, PJP, INDEX, IDX, COPY)                   \
f7f82a
diff -crb judy-1.0.5-orig/src/JudyCommon/JudyIns.c judy-1.0.5/src/JudyCommon/JudyIns.c
f7f82a
*** judy-1.0.5-orig/src/JudyCommon/JudyIns.c	2005-02-15 15:06:07.000000000 -0600
f7f82a
--- judy-1.0.5/src/JudyCommon/JudyIns.c	2014-02-18 13:00:49.871850635 -0600
f7f82a
***************
f7f82a
*** 1503,1509 ****
f7f82a
              JU_BITMAPSETL(Pjlb, Index);
f7f82a
  
f7f82a
              for (offset = 0; offset < 15; ++offset)
f7f82a
!                 JU_BITMAPSETL(Pjlb, Pjp->jp_1Index[offset]);
f7f82a
  
f7f82a
  //          Set jp_DcdPopO including the current pop0; incremented later:
f7f82a
              DcdP0 = (Index & cJU_DCDMASK(1)) + 15 - 1;
f7f82a
--- 1503,1510 ----
f7f82a
              JU_BITMAPSETL(Pjlb, Index);
f7f82a
  
f7f82a
              for (offset = 0; offset < 15; ++offset)
f7f82a
! //              JU_BITMAPSETL(Pjlb, Pjp->jp_1Index[offset]); // elements 8..15 are optimized out by gcc, so need to do the following
f7f82a
!               JU_BITMAPSETL(Pjlb, Pjp->jp_2Index[offset]);
f7f82a
  
f7f82a
  //          Set jp_DcdPopO including the current pop0; incremented later:
f7f82a
              DcdP0 = (Index & cJU_DCDMASK(1)) + 15 - 1;
f7f82a
diff -crb judy-1.0.5-orig/src/JudyCommon/JudyPrevNext.c judy-1.0.5/src/JudyCommon/JudyPrevNext.c
f7f82a
*** judy-1.0.5-orig/src/JudyCommon/JudyPrevNext.c	2005-02-15 15:06:07.000000000 -0600
f7f82a
--- judy-1.0.5/src/JudyCommon/JudyPrevNext.c	2014-02-18 13:45:40.972875737 -0600
f7f82a
***************
f7f82a
*** 907,913 ****
f7f82a
  // Shorthand for where to find start of Index bytes array:
f7f82a
  
f7f82a
  #ifdef JUDY1
f7f82a
! #define	PJI (Pjp->jp_1Index)
f7f82a
  #else
f7f82a
  #define	PJI (Pjp->jp_LIndex)
f7f82a
  #endif
f7f82a
--- 907,913 ----
f7f82a
  // Shorthand for where to find start of Index bytes array:
f7f82a
  
f7f82a
  #ifdef JUDY1
f7f82a
! #define	PJI (Pjp->jp_2Index)
f7f82a
  #else
f7f82a
  #define	PJI (Pjp->jp_LIndex)
f7f82a
  #endif
f7f82a
diff -crb judy-1.0.5-orig/src/JudyCommon/JudyPrivateBranch.h judy-1.0.5/src/JudyCommon/JudyPrivateBranch.h
f7f82a
*** judy-1.0.5-orig/src/JudyCommon/JudyPrivateBranch.h	2005-02-15 15:06:07.000000000 -0600
f7f82a
--- judy-1.0.5/src/JudyCommon/JudyPrivateBranch.h	2014-02-18 13:00:39.510533765 -0600
f7f82a
***************
f7f82a
*** 86,91 ****
f7f82a
--- 86,98 ----
f7f82a
          } jpi_t;
f7f82a
  
f7f82a
  
f7f82a
+ typedef struct _JUDY_POINTER_IMMED2      // JPI2.
f7f82a
+         {
f7f82a
+             uint8_t j_pi_2Index[2 * sizeof(Word_t) - 1];        // see above.
f7f82a
+             uint8_t j_pi_Type;                  // JP type, 1 of cJ*_JPIMMED*.
f7f82a
+         } jpi2_t;
f7f82a
+ 
f7f82a
+ 
f7f82a
  // UNION OF JP TYPES:
f7f82a
  //
f7f82a
  // A branch is an array of cJU_BRANCHUNUMJPS (256) of this object, or an
f7f82a
***************
f7f82a
*** 97,102 ****
f7f82a
--- 104,110 ----
f7f82a
          {
f7f82a
              jpo_t j_po;                 // other than immediate indexes.
f7f82a
              jpi_t j_pi;                 // immediate indexes.
f7f82a
+             jpi2_t j_pi2;               // immediate indexes using j_pi_LIndex as well
f7f82a
          } jp_t, *Pjp_t;
f7f82a
  
f7f82a
  // For coding convenience:
f7f82a
***************
f7f82a
*** 105,110 ****
f7f82a
--- 113,119 ----
f7f82a
  
f7f82a
  #define jp_1Index  j_pi.j_pi_1Index     // for storing Indexes in first  word.
f7f82a
  #define jp_LIndex  j_pi.j_pi_LIndex     // for storing Indexes in second word.
f7f82a
+ #define jp_2Index  j_pi2.j_pi_2Index     // for storing Indexes spanning both words.
f7f82a
  #define jp_Addr    j_po.j_po_Addr
f7f82a
  //#define       jp_DcdPop0 j_po.jpo_u.j_po_DcdPop0
f7f82a
  #define jp_Type    j_po.jpo_u.j_po_Bytes[sizeof(Word_t) - 1]