Blame SOURCES/libgcrypt-1.6.1-mpicoder-gccopt.patch

5bcc82
diff -up libgcrypt-1.6.1/mpi/mpicoder.c.gccopt libgcrypt-1.6.1/mpi/mpicoder.c
5bcc82
--- libgcrypt-1.6.1/mpi/mpicoder.c.gccopt	2014-02-28 15:37:53.983139821 +0100
5bcc82
+++ libgcrypt-1.6.1/mpi/mpicoder.c	2014-02-28 15:47:35.312576387 +0100
5bcc82
@@ -627,16 +627,16 @@ _gcry_mpi_print (enum gcry_mpi_format fo
5bcc82
           extra = 1;
5bcc82
 	}
5bcc82
 
5bcc82
-      if (buffer && n > len)
5bcc82
-        {
5bcc82
-          /* The provided buffer is too short. */
5bcc82
-          xfree (tmp);
5bcc82
-          return GPG_ERR_TOO_SHORT;
5bcc82
-	}
5bcc82
       if (buffer)
5bcc82
         {
5bcc82
           unsigned char *s = buffer;
5bcc82
 
5bcc82
+          if (n > len)
5bcc82
+            {
5bcc82
+              /* The provided buffer is too short. */
5bcc82
+              xfree (tmp);
5bcc82
+              return GPG_ERR_TOO_SHORT;
5bcc82
+            }
5bcc82
           if (extra == 1)
5bcc82
             *s++ = 0;
5bcc82
           else if (extra)
5bcc82
@@ -654,13 +654,12 @@ _gcry_mpi_print (enum gcry_mpi_format fo
5bcc82
       /* Note:  We ignore the sign for this format.  */
5bcc82
       /* FIXME: for performance reasons we should put this into
5bcc82
 	 mpi_aprint because we can then use the buffer directly.  */
5bcc82
-
5bcc82
-      if (buffer && n > len)
5bcc82
-        return GPG_ERR_TOO_SHORT;
5bcc82
       if (buffer)
5bcc82
         {
5bcc82
           unsigned char *tmp;
5bcc82
 
5bcc82
+          if (n > len)
5bcc82
+            return GPG_ERR_TOO_SHORT;
5bcc82
           tmp = _gcry_mpi_get_buffer (a, 0, &n, NULL);
5bcc82
           if (!tmp)
5bcc82
             return gpg_err_code_from_syserror ();
5bcc82
@@ -678,14 +677,14 @@ _gcry_mpi_print (enum gcry_mpi_format fo
5bcc82
       if (negative)
5bcc82
         return GPG_ERR_INV_ARG;
5bcc82
 
5bcc82
-      if (buffer && n+2 > len)
5bcc82
-        return GPG_ERR_TOO_SHORT;
5bcc82
-
5bcc82
       if (buffer)
5bcc82
         {
5bcc82
           unsigned char *tmp;
5bcc82
           unsigned char *s = buffer;
5bcc82
 
5bcc82
+          if (n+2 > len)
5bcc82
+            return GPG_ERR_TOO_SHORT;
5bcc82
+
5bcc82
           s[0] = nbits >> 8;
5bcc82
           s[1] = nbits;
5bcc82
 
5bcc82
@@ -724,16 +723,16 @@ _gcry_mpi_print (enum gcry_mpi_format fo
5bcc82
           extra=1;
5bcc82
 	}
5bcc82
 
5bcc82
-      if (buffer && n+4 > len)
5bcc82
-        {
5bcc82
-          xfree(tmp);
5bcc82
-          return GPG_ERR_TOO_SHORT;
5bcc82
-	}
5bcc82
-
5bcc82
       if (buffer)
5bcc82
         {
5bcc82
           unsigned char *s = buffer;
5bcc82
 
5bcc82
+          if (n+4 > len)
5bcc82
+            {
5bcc82
+              xfree(tmp);
5bcc82
+              return GPG_ERR_TOO_SHORT;
5bcc82
+            }
5bcc82
+
5bcc82
           *s++ = n >> 24;
5bcc82
           *s++ = n >> 16;
5bcc82
           *s++ = n >> 8;
5bcc82
@@ -761,15 +760,15 @@ _gcry_mpi_print (enum gcry_mpi_format fo
5bcc82
       if (!n || (*tmp & 0x80))
5bcc82
         extra = 2;
5bcc82
 
5bcc82
-      if (buffer && 2*n + extra + negative + 1 > len)
5bcc82
-        {
5bcc82
-          xfree(tmp);
5bcc82
-          return GPG_ERR_TOO_SHORT;
5bcc82
-	}
5bcc82
       if (buffer)
5bcc82
         {
5bcc82
           unsigned char *s = buffer;
5bcc82
 
5bcc82
+          if (2*n + extra + negative + 1 > len)
5bcc82
+            {
5bcc82
+              xfree(tmp);
5bcc82
+              return GPG_ERR_TOO_SHORT;
5bcc82
+	    }
5bcc82
           if (negative)
5bcc82
             *s++ = '-';
5bcc82
           if (extra)