forked from rpms/glibc
		
	Fix an issue with the strcoll CVE patch
Expanded types for some variables to prevent overflow.
This commit is contained in:
		
							parent
							
								
									e3b637cf01
								
							
						
					
					
						commit
						735547c10e
					
				| @ -1,5 +1,5 @@ | ||||
| diff --git a/string/strcoll_l.c b/string/strcoll_l.c
 | ||||
| index ecda08f..ec630fe 100644
 | ||||
| index ecda08f..bb34a72 100644
 | ||||
| --- a/string/strcoll_l.c
 | ||||
| +++ b/string/strcoll_l.c
 | ||||
| @@ -41,11 +41,434 @@
 | ||||
| @ -10,15 +10,15 @@ index ecda08f..ec630fe 100644 | ||||
| +typedef struct
 | ||||
| +{
 | ||||
| +  int len;			/* Length of the current sequence.  */
 | ||||
| +  int val;			/* Position of the sequence relative to the
 | ||||
| +  size_t val;			/* Position of the sequence relative to the
 | ||||
| +				   previous non-ignored sequence.  */
 | ||||
| +  size_t idxnow;		/* Current index in sequences.  */
 | ||||
| +  size_t idxmax;		/* Maximum index in sequences.  */
 | ||||
| +  size_t idxcnt;		/* Current count of indeces.  */
 | ||||
| +  size_t idxcnt;		/* Current count of indices.  */
 | ||||
| +  size_t backw;			/* Current Backward sequence index.  */
 | ||||
| +  size_t backw_stop;		/* Index where the backward sequences stop.  */
 | ||||
| +  const USTRING_TYPE *us;	/* The string.  */
 | ||||
| +  int32_t *idxarr;		/* Array to cache weight indeces.  */
 | ||||
| +  int32_t *idxarr;		/* Array to cache weight indices.  */
 | ||||
| +  unsigned char *rulearr;	/* Array to cache rules.  */
 | ||||
| +  unsigned char rule;		/* Saved rule for the first sequence.  */
 | ||||
| +  int32_t idx;			/* Index to weight of the current sequence.  */
 | ||||
| @ -28,14 +28,14 @@ index ecda08f..ec630fe 100644 | ||||
| +  const USTRING_TYPE *back_us;	/* Beginning of the backward sequence.  */
 | ||||
| +} coll_seq;
 | ||||
| +
 | ||||
| +/* Get next sequence.  The weight indeces are cached, so we don't need to
 | ||||
| +/* Get next sequence.  The weight indices are cached, so we don't need to
 | ||||
| +   traverse the string.  */
 | ||||
| +static void
 | ||||
| +get_next_seq_cached (coll_seq *seq, int nrules, int pass,
 | ||||
| +		     const unsigned char *rulesets,
 | ||||
| +		     const USTRING_TYPE *weights)
 | ||||
| +{
 | ||||
| +  int val = seq->val = 0;
 | ||||
| +  size_t val = seq->val = 0;
 | ||||
| +  int len = seq->len;
 | ||||
| +  size_t backw_stop = seq->backw_stop;
 | ||||
| +  size_t backw = seq->backw;
 | ||||
| @ -50,7 +50,7 @@ index ecda08f..ec630fe 100644 | ||||
| +      ++val;
 | ||||
| +      if (backw_stop != ~0ul)
 | ||||
| +	{
 | ||||
| +	  /* The is something pushed.  */
 | ||||
| +	  /* There is something pushed.  */
 | ||||
| +	  if (backw == backw_stop)
 | ||||
| +	    {
 | ||||
| +	      /* The last pushed character was handled.  Continue
 | ||||
| @ -62,7 +62,7 @@ index ecda08f..ec630fe 100644 | ||||
| +		}
 | ||||
| +	      else
 | ||||
| +		{
 | ||||
| +		  /* Nothing anymore.  The backward sequence
 | ||||
| +		  /* Nothing any more.  The backward sequence
 | ||||
| +		     ended with the last sequence in the string.  */
 | ||||
| +		  idxnow = ~0ul;
 | ||||
| +		  break;
 | ||||
| @ -88,7 +88,7 @@ index ecda08f..ec630fe 100644 | ||||
| +	    {
 | ||||
| +	      /* No sequence at all or just one.  */
 | ||||
| +	      if (idxcnt == idxmax)
 | ||||
| +		/* Note that seq1len is still zero.  */
 | ||||
| +		/* Note that LEN is still zero.  */
 | ||||
| +		break;
 | ||||
| +
 | ||||
| +	      backw_stop = ~0ul;
 | ||||
| @ -117,7 +117,7 @@ index ecda08f..ec630fe 100644 | ||||
| +	      const USTRING_TYPE *extra, const int32_t *indirect)
 | ||||
| +{
 | ||||
| +#include WEIGHT_H
 | ||||
| +  int val = seq->val = 0;
 | ||||
| +  size_t val = seq->val = 0;
 | ||||
| +  int len = seq->len;
 | ||||
| +  size_t backw_stop = seq->backw_stop;
 | ||||
| +  size_t backw = seq->backw;
 | ||||
| @ -133,7 +133,7 @@ index ecda08f..ec630fe 100644 | ||||
| +      ++val;
 | ||||
| +      if (backw_stop != ~0ul)
 | ||||
| +	{
 | ||||
| +	  /* The is something pushed.  */
 | ||||
| +	  /* There is something pushed.  */
 | ||||
| +	  if (backw == backw_stop)
 | ||||
| +	    {
 | ||||
| +	      /* The last pushed character was handled.  Continue
 | ||||
| @ -144,8 +144,8 @@ index ecda08f..ec630fe 100644 | ||||
| +		  backw_stop = ~0ul;
 | ||||
| +		}
 | ||||
| +	      else
 | ||||
| +		/* Nothing anymore.  The backward sequence ended with
 | ||||
| +		   the last sequence in the string.  Note that seq2len
 | ||||
| +		/* Nothing any more.  The backward sequence ended with
 | ||||
| +		   the last sequence in the string.  Note that LEN
 | ||||
| +		   is still zero.  */
 | ||||
| +		break;
 | ||||
| +	    }
 | ||||
| @ -174,7 +174,7 @@ index ecda08f..ec630fe 100644 | ||||
| +	    {
 | ||||
| +	      /* No sequence at all or just one.  */
 | ||||
| +	      if (idxcnt == idxmax || backw_stop > idxcnt)
 | ||||
| +		/* Note that seq1len is still zero.  */
 | ||||
| +		/* Note that LEN is still zero.  */
 | ||||
| +		break;
 | ||||
| +
 | ||||
| +	      backw_stop = ~0ul;
 | ||||
| @ -207,7 +207,7 @@ index ecda08f..ec630fe 100644 | ||||
| +		      int pass)
 | ||||
| +{
 | ||||
| +#include WEIGHT_H
 | ||||
| +  int val = seq->val = 0;
 | ||||
| +  size_t val = seq->val = 0;
 | ||||
| +  int len = seq->len;
 | ||||
| +  size_t backw_stop = seq->backw_stop;
 | ||||
| +  size_t backw = seq->backw;
 | ||||
| @ -221,7 +221,7 @@ index ecda08f..ec630fe 100644 | ||||
| +      ++val;
 | ||||
| +      if (backw_stop != ~0ul)
 | ||||
| +	{
 | ||||
| +	  /* The is something pushed.  */
 | ||||
| +	  /* There is something pushed.  */
 | ||||
| +	  if (backw == backw_stop)
 | ||||
| +	    {
 | ||||
| +	      /* The last pushed character was handled.  Continue
 | ||||
| @ -245,7 +245,7 @@ index ecda08f..ec630fe 100644 | ||||
| +	      /* XXX Traverse BACKW sequences from the beginning of
 | ||||
| +		 BACKW_STOP to get the next sequence.  Is ther a quicker way
 | ||||
| +	         to do this?  */
 | ||||
| +	      int i = backw_stop;
 | ||||
| +	      size_t i = backw_stop;
 | ||||
| +	      us = seq->back_us;
 | ||||
| +	      while (i < backw)
 | ||||
| +		{
 | ||||
| @ -311,7 +311,7 @@ index ecda08f..ec630fe 100644 | ||||
| +	}
 | ||||
| +
 | ||||
| +      len = weights[idx++];
 | ||||
| +      /* Skip over indeces of previous levels.  */
 | ||||
| +      /* Skip over indices of previous levels.  */
 | ||||
| +      for (int i = 0; i < pass; i++)
 | ||||
| +	{
 | ||||
| +	  idx += len;
 | ||||
| @ -339,8 +339,8 @@ index ecda08f..ec630fe 100644 | ||||
| +{
 | ||||
| +  int seq1len = seq1->len;
 | ||||
| +  int seq2len = seq2->len;
 | ||||
| +  int val1 = seq1->val;
 | ||||
| +  int val2 = seq2->val;
 | ||||
| +  size_t val1 = seq1->val;
 | ||||
| +  size_t val2 = seq2->val;
 | ||||
| +  int idx1 = seq1->idx;
 | ||||
| +  int idx2 = seq2->idx;
 | ||||
| +  int result = 0;
 | ||||
| @ -348,7 +348,7 @@ index ecda08f..ec630fe 100644 | ||||
| +  /* Test for position if necessary.  */
 | ||||
| +  if (position && val1 != val2)
 | ||||
| +    {
 | ||||
| +      result = val1 - val2;
 | ||||
| +      result = val1 > val2 ? 1 : -1;
 | ||||
| +      goto out;
 | ||||
| +    }
 | ||||
| +
 | ||||
| @ -389,8 +389,8 @@ index ecda08f..ec630fe 100644 | ||||
| +{
 | ||||
| +  int seq1len = seq1->len;
 | ||||
| +  int seq2len = seq2->len;
 | ||||
| +  int val1 = seq1->val;
 | ||||
| +  int val2 = seq2->val;
 | ||||
| +  size_t val1 = seq1->val;
 | ||||
| +  size_t val2 = seq2->val;
 | ||||
| +  int32_t *idx1arr = seq1->idxarr;
 | ||||
| +  int32_t *idx2arr = seq2->idxarr;
 | ||||
| +  int idx1now = seq1->idxnow;
 | ||||
| @ -400,7 +400,7 @@ index ecda08f..ec630fe 100644 | ||||
| +  /* Test for position if necessary.  */
 | ||||
| +  if (position && val1 != val2)
 | ||||
| +    {
 | ||||
| +      result = val1 - val2;
 | ||||
| +      result = val1 > val2 ? 1 : -1;
 | ||||
| +      goto out;
 | ||||
| +    }
 | ||||
| +
 | ||||
| @ -766,7 +766,7 @@ index ecda08f..ec630fe 100644 | ||||
|      { | ||||
| +      seq1.idxcnt = 0;
 | ||||
| +      seq1.idx = 0;
 | ||||
| +      seq1.idx = 0;
 | ||||
| +      seq2.idx = 0;
 | ||||
| +      seq1.backw_stop = ~0ul;
 | ||||
| +      seq1.backw = ~0ul;
 | ||||
| +      seq2.idxcnt = 0;
 | ||||
| @ -774,7 +774,7 @@ index ecda08f..ec630fe 100644 | ||||
| +      seq2.backw = ~0ul;
 | ||||
| +
 | ||||
| +      /* We need the elements of the strings as unsigned values since they
 | ||||
| +	 are used as indeces.  */
 | ||||
| +	 are used as indices.  */
 | ||||
| +      seq1.us = (const USTRING_TYPE *) s1;
 | ||||
| +      seq2.us = (const USTRING_TYPE *) s2;
 | ||||
| +
 | ||||
|  | ||||
| @ -1620,6 +1620,7 @@ rm -f *.filelist* | ||||
| * Tue Aug 20 2013 Siddhesh Poyarekar <siddhesh@redhat.com> - 2.18-3 | ||||
| - Remove non-ELF support in rtkaio. | ||||
| - Avoid inlining of cleanup function for kaio_suspend. | ||||
| - Expand sizes of some types in strcoll (#855399, CVE-2012-4424). | ||||
| 
 | ||||
| * Mon Aug 19 2013 Siddhesh Poyarekar <siddhesh@redhat.com> - 2.18-2 | ||||
| - Fix buffer overflow in readdir_r (#995841, CVE-2013-4237). | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user