File libraw-CVE-2025-43962.patch of Package libraw.38394

Index: LibRaw-0.15.4/internal/dcraw_common.cpp
===================================================================
--- LibRaw-0.15.4.orig/internal/dcraw_common.cpp
+++ LibRaw-0.15.4/internal/dcraw_common.cpp
@@ -1547,6 +1547,9 @@ void CLASS phase_one_correct()
   if (off_412) {
     fseek (ifp, off_412, SEEK_SET);
     for (i=0; i < 9; i++) head[i] = get4() & 0x7fff;
+    unsigned w0 = head[1] * head[3], w1 = head[2] * head[4];
+    if (w0 > 10240000 || w1 > 10240000)
+       throw LIBRAW_EXCEPTION_ALLOC;
     yval[0] = (float *) calloc (head[1]*head[3] + head[2]*head[4], 6);
     merror (yval[0], "phase_one_correct()");
     yval[1] = (float  *) (yval[0] + head[1]*head[3]);
@@ -1567,9 +1570,17 @@ void CLASS phase_one_correct()
 	for (i=cip; i < cip+2; i++) {
 	  for (k=j=0; j < head[1]; j++)
 	    if (num < xval[0][k = head[1]*i+j]) break;
-	  frac = (j == 0 || j == head[1]) ? 0 :
-		(xval[0][k] - num) / (xval[0][k] - xval[0][k-1]);
-	  mult[i-cip] = yval[0][k-1] * frac + yval[0][k] * (1-frac);
+              if (j == 0 || j == head[1] || k < 1 || k >= w0+w1)
+                      frac = 0;
+              else
+              {
+                      int xdiv = (xval[0][k] - xval[0][k - 1]);
+                      frac = xdiv ? (xval[0][k] - num) / (xval[0][k] - xval[0][k - 1]) : 0;
+              }
+              if (k < w0 + w1)
+                      mult[i - cip] = yval[0][k > 0 ? k - 1 : 0] * frac + yval[0][k] * (1 - frac);
+              else
+                      mult[i - cip] = 0;
 	}
 	i = ((mult[0] * (1-cfrac) + mult[1] * cfrac) * row + num) * 2;
 	RAW(row,col) = LIM(i,0,65535);
openSUSE Build Service is sponsored by