Blame SOURCES/ghostscript-cve-2020-16304.patch

0ab051
diff --git a/base/gxicolor.c b/base/gxicolor.c
0ab051
index 34cfaa4..585bd81 100644
0ab051
--- a/base/gxicolor.c
0ab051
+++ b/base/gxicolor.c
0ab051
@@ -644,16 +644,16 @@ image_render_color_thresh(gx_image_enum *penum_orig, const byte *buffer, int dat
0ab051
                                     *(devc_contone_gray+1) = *psrc_temp;
0ab051
                             }
0ab051
                         } else {
0ab051
-                        /* Mono case, forward */
0ab051
-                        psrc_temp = psrc_cm;
0ab051
-                        for (k=0; k
0ab051
-                            dda_next(dda_ht);
0ab051
-                            xn = fixed2int_var_rounded(dda_current(dda_ht));
0ab051
-                            while (xr < xn) {
0ab051
-                                *devc_contone_gray++ = *psrc_temp;
0ab051
-                                xr++;
0ab051
-                            }           /* at loop exit xn will be >= xr */
0ab051
-                            psrc_temp++;
0ab051
+                            /* Mono case, forward */
0ab051
+                            psrc_temp = psrc_cm;
0ab051
+                            for (k=0; k
0ab051
+                                dda_next(dda_ht);
0ab051
+                                xn = fixed2int_var_rounded(dda_current(dda_ht));
0ab051
+                                while (xr < xn) {
0ab051
+                                    *devc_contone_gray++ = *psrc_temp;
0ab051
+                                    xr++;
0ab051
+                                }           /* at loop exit xn will be >= xr */
0ab051
+                                psrc_temp++;
0ab051
                             }
0ab051
                         }
0ab051
                     } else {
0ab051
@@ -668,7 +668,7 @@ image_render_color_thresh(gx_image_enum *penum_orig, const byte *buffer, int dat
0ab051
                                 xr--;
0ab051
                             }           /* at loop exit xn will be >= xr */
0ab051
                             psrc_temp++;
0ab051
-                            }
0ab051
+                        }
0ab051
                     }
0ab051
                     break;
0ab051
                 /* Monochrome landscape */
0ab051
@@ -811,10 +811,9 @@ image_render_color_thresh(gx_image_enum *penum_orig, const byte *buffer, int dat
0ab051
                             dda_next(dda_ht);
0ab051
                             xn = fixed2int_var_rounded(dda_current(dda_ht));
0ab051
                             while (xr > xn) {
0ab051
-                                for (j = 0; j < spp_out; j++) {
0ab051
+                                for (j = 0; j < spp_out; j++)
0ab051
                                     *(devc_contone[j] + position) = (psrc_plane[j])[i];
0ab051
-                                    position -= LAND_BITS;
0ab051
-                                }
0ab051
+                                position -= LAND_BITS;
0ab051
                                 xr--;
0ab051
                             }           /* at loop exit xn will be <= xr */
0ab051
                             i++;
0ab051
@@ -825,9 +824,8 @@ image_render_color_thresh(gx_image_enum *penum_orig, const byte *buffer, int dat
0ab051
                            and 2x scaling which we will run into in 300 and
0ab051
                            600dpi devices and content */
0ab051
                         /* Apply initial offset */
0ab051
-                        for (k = 0; k < spp_out; k++) {
0ab051
+                        for (k = 0; k < spp_out; k++)
0ab051
                             devc_contone[k] = devc_contone[k] + position;
0ab051
-                        }
0ab051
                         if (src_size == dest_height) {
0ab051
                             for (k = 0; k < data_length; k++) {
0ab051
                                 /* Is it better to unwind this?  We know it is 4 */
0ab051
@@ -853,10 +851,9 @@ image_render_color_thresh(gx_image_enum *penum_orig, const byte *buffer, int dat
0ab051
                                 dda_next(dda_ht);
0ab051
                                 xn = fixed2int_var_rounded(dda_current(dda_ht));
0ab051
                                 while (xr > xn) {
0ab051
-                                    for (j = 0; j < spp_out; j++) {
0ab051
+                                    for (j = 0; j < spp_out; j++)
0ab051
                                         *(devc_contone[j] + position) = (psrc_plane[j])[i];
0ab051
-                                        position -= LAND_BITS;
0ab051
-                                    }
0ab051
+                                    position -= LAND_BITS;
0ab051
                                     xr--;
0ab051
                                 }           /* at loop exit xn will be <= xr */
0ab051
                                 i++;