[GRASS-SVN] r71241 - grass/trunk/lib/raster

svn_grass at osgeo.org svn_grass at osgeo.org
Tue Jul 4 23:45:24 PDT 2017


Author: mmetz
Date: 2017-07-04 23:45:24 -0700 (Tue, 04 Jul 2017)
New Revision: 71241

Modified:
   grass/trunk/lib/raster/get_row.c
   grass/trunk/lib/raster/get_row_colr.c
   grass/trunk/lib/raster/put_row.c
Log:
rasterlib: replace G_alloca for reading rows (avoids stack overflow, #3365)

Modified: grass/trunk/lib/raster/get_row.c
===================================================================
--- grass/trunk/lib/raster/get_row.c	2017-07-04 20:53:58 UTC (rev 71240)
+++ grass/trunk/lib/raster/get_row.c	2017-07-05 06:45:24 UTC (rev 71241)
@@ -137,10 +137,10 @@
 	G_fatal_error(_("Error reading raster data for row %d of <%s>"),
 		      row, fcb->name);
 
-    cmp = G_alloca(readamount);
+    cmp = G_malloc(readamount);
 
     if (read(fcb->data_fd, cmp, readamount) != readamount) {
-	G_freea(cmp);
+	G_free(cmp);
 	G_fatal_error(_("Error reading raster data for row %d of <%s>"),
 		      row, fcb->name);
     }
@@ -172,7 +172,7 @@
     else
 	memcpy(data_buf, cmp, readamount);
 
-    G_freea(cmp2);
+    G_free(cmp2);
 }
 
 static void read_data_uncompressed(int fd, int row, unsigned char *data_buf,
@@ -205,7 +205,7 @@
     if (fcb->gdal->vflip)
 	row = fcb->cellhd.rows - 1 - row;
 
-    buf = fcb->gdal->hflip ? G_alloca(fcb->cellhd.cols * fcb->cur_nbytes)
+    buf = fcb->gdal->hflip ? G_malloc(fcb->cellhd.cols * fcb->cur_nbytes)
 	: data_buf;
 
     err =
@@ -220,7 +220,7 @@
 	    memcpy(data_buf + i * fcb->cur_nbytes,
 		   buf + (fcb->cellhd.cols - 1 - i) * fcb->cur_nbytes,
 		   fcb->cur_nbytes);
-	G_freea(buf);
+	G_free(buf);
     }
 
     if (err != CE_None)
@@ -464,7 +464,7 @@
 static void transfer_to_cell_fi(int fd, void *cell)
 {
     struct fileinfo *fcb = &R__.fileinfo[fd];
-    FCELL *work_buf = G_alloca(R__.rd_window.cols * sizeof(FCELL));
+    FCELL *work_buf = G_malloc(R__.rd_window.cols * sizeof(FCELL));
     int i;
 
     transfer_to_cell_XX(fd, work_buf);
@@ -473,13 +473,13 @@
 	((CELL *) cell)[i] = (fcb->col_map[i] == 0)
 	    ? 0 : Rast_quant_get_cell_value(&fcb->quant, work_buf[i]);
 
-    G_freea(work_buf);
+    G_free(work_buf);
 }
 
 static void transfer_to_cell_di(int fd, void *cell)
 {
     struct fileinfo *fcb = &R__.fileinfo[fd];
-    DCELL *work_buf = G_alloca(R__.rd_window.cols * sizeof(DCELL));
+    DCELL *work_buf = G_malloc(R__.rd_window.cols * sizeof(DCELL));
     int i;
 
     transfer_to_cell_XX(fd, work_buf);
@@ -488,12 +488,12 @@
 	((CELL *) cell)[i] = (fcb->col_map[i] == 0)
 	    ? 0 : Rast_quant_get_cell_value(&fcb->quant, work_buf[i]);
 
-    G_freea(work_buf);
+    G_free(work_buf);
 }
 
 static void transfer_to_cell_if(int fd, void *cell)
 {
-    CELL *work_buf = G_alloca(R__.rd_window.cols * sizeof(CELL));
+    CELL *work_buf = G_malloc(R__.rd_window.cols * sizeof(CELL));
     int i;
 
     transfer_to_cell_XX(fd, work_buf);
@@ -501,12 +501,12 @@
     for (i = 0; i < R__.rd_window.cols; i++)
 	((FCELL *) cell)[i] = work_buf[i];
 
-    G_freea(work_buf);
+    G_free(work_buf);
 }
 
 static void transfer_to_cell_df(int fd, void *cell)
 {
-    DCELL *work_buf = G_alloca(R__.rd_window.cols * sizeof(DCELL));
+    DCELL *work_buf = G_malloc(R__.rd_window.cols * sizeof(DCELL));
     int i;
 
     transfer_to_cell_XX(fd, work_buf);
@@ -514,12 +514,12 @@
     for (i = 0; i < R__.rd_window.cols; i++)
 	((FCELL *) cell)[i] = work_buf[i];
 
-    G_freea(work_buf);
+    G_free(work_buf);
 }
 
 static void transfer_to_cell_id(int fd, void *cell)
 {
-    CELL *work_buf = G_alloca(R__.rd_window.cols * sizeof(CELL));
+    CELL *work_buf = G_malloc(R__.rd_window.cols * sizeof(CELL));
     int i;
 
     transfer_to_cell_XX(fd, work_buf);
@@ -527,12 +527,12 @@
     for (i = 0; i < R__.rd_window.cols; i++)
 	((DCELL *) cell)[i] = work_buf[i];
 
-    G_freea(work_buf);
+    G_free(work_buf);
 }
 
 static void transfer_to_cell_fd(int fd, void *cell)
 {
-    FCELL *work_buf = G_alloca(R__.rd_window.cols * sizeof(FCELL));
+    FCELL *work_buf = G_malloc(R__.rd_window.cols * sizeof(FCELL));
     int i;
 
     transfer_to_cell_XX(fd, work_buf);
@@ -540,7 +540,7 @@
     for (i = 0; i < R__.rd_window.cols; i++)
 	((DCELL *) cell)[i] = work_buf[i];
 
-    G_freea(work_buf);
+    G_free(work_buf);
 }
 
 /*
@@ -598,7 +598,7 @@
     int i;
 
     if (fcb->reclass_flag && data_type != CELL_TYPE) {
-	temp_buf = G_alloca(R__.rd_window.cols * sizeof(CELL));
+	temp_buf = G_malloc(R__.rd_window.cols * sizeof(CELL));
 	buf = temp_buf;
 	type = CELL_TYPE;
     }
@@ -625,7 +625,9 @@
 	rast = G_incr_void_ptr(rast, size);
     }
 
-    G_freea(temp_buf);
+    if (fcb->reclass_flag && data_type != CELL_TYPE) {
+	G_free(temp_buf);
+    }
 }
 
 /*!
@@ -835,10 +837,10 @@
 	return 1;
     }
 
-    compressed_buf = G_alloca(readamount);
+    compressed_buf = G_malloc(readamount);
 
     if (read(null_fd, compressed_buf, readamount) != readamount) {
-	G_freea(compressed_buf);
+	G_free(compressed_buf);
 	G_fatal_error(_("Error reading null data for row %d of <%s>"),
 		      row, fcb->name);
     }
@@ -849,7 +851,7 @@
 		      row, fcb->name);
     }
 
-    G_freea(compressed_buf);
+    G_free(compressed_buf);
 
     return 1;
 }
@@ -907,13 +909,13 @@
 	    fcb->null_cur_row = -1;
 	    if (fcb->map_type == CELL_TYPE) {
 		/* If can't read null row, assume  that all map 0's are nulls */
-		CELL *mask_buf = G_alloca(R__.rd_window.cols * sizeof(CELL));
+		CELL *mask_buf = G_malloc(R__.rd_window.cols * sizeof(CELL));
 
 		get_map_row_nomask(fd, mask_buf, row, CELL_TYPE);
 		for (j = 0; j < R__.rd_window.cols; j++)
 		    flags[j] = (mask_buf[j] == 0);
 
-		G_freea(mask_buf);
+		G_free(mask_buf);
 	    }
 	    else {		/* fp map */
 		/* if can't read null row, assume  that all data is valid */
@@ -969,14 +971,16 @@
 
 static void embed_mask(char *flags, int row)
 {
-    CELL *mask_buf = G_alloca(R__.rd_window.cols * sizeof(CELL));
+    CELL *mask_buf = G_malloc(R__.rd_window.cols * sizeof(CELL));
     int i;
 
-    if (R__.auto_mask <= 0)
+    if (R__.auto_mask <= 0) {
+	G_free(mask_buf);
 	return;
+    }
 
     if (get_map_row_nomask(R__.mask_fd, mask_buf, row, CELL_TYPE) < 0) {
-	G_freea(mask_buf);
+	G_free(mask_buf);
 	return;
     }
 
@@ -989,7 +993,7 @@
 	if (mask_buf[i] == 0 || Rast_is_c_null_value(&mask_buf[i]))
 	    flags[i] = 1;
 
-    G_freea(mask_buf);
+    G_free(mask_buf);
 }
 
 static void get_null_value_row(int fd, char *flags, int row, int with_mask)
@@ -1021,7 +1025,7 @@
 	&& (R__.auto_mask <= 0 || !with_mask))
 	return;
 
-    null_buf = G_alloca(R__.rd_window.cols);
+    null_buf = G_malloc(R__.rd_window.cols);
 
     get_null_value_row(fd, null_buf, row, with_mask);
 
@@ -1036,7 +1040,7 @@
 	buf = G_incr_void_ptr(buf, size);
     }
 
-    G_freea(null_buf);
+    G_free(null_buf);
 }
 
 /*!
@@ -1063,13 +1067,13 @@
     if (!fcb->reclass_flag)
 	get_null_value_row(fd, flags, row, 1);
     else {
-	CELL *buf = G_alloca(R__.rd_window.cols * sizeof(CELL));
+	CELL *buf = G_malloc(R__.rd_window.cols * sizeof(CELL));
 	int i;
 
 	Rast_get_c_row(fd, buf, row);
 	for (i = 0; i < R__.rd_window.cols; i++)
 	    flags[i] = Rast_is_c_null_value(&buf[i]) ? 1 : 0;
 
-	G_freea(buf);
+	G_free(buf);
     }
 }

Modified: grass/trunk/lib/raster/get_row_colr.c
===================================================================
--- grass/trunk/lib/raster/get_row_colr.c	2017-07-04 20:53:58 UTC (rev 71240)
+++ grass/trunk/lib/raster/get_row_colr.c	2017-07-05 06:45:24 UTC (rev 71241)
@@ -48,7 +48,7 @@
     void *p;
     int i;
 
-    array = G_alloca(cols * size);
+    array = G_malloc(cols * size);
 
     Rast_get_row(fd, array, row, type);
 
@@ -56,10 +56,10 @@
 	for (i = 0, p = array; i < cols; i++, p = G_incr_void_ptr(p, size))
 	    nul[i] = Rast_is_null_value(p, type);
 
-    set = G_alloca(cols);
+    set = G_malloc(cols);
 
     Rast_lookup_colors(array, red, grn, blu, set, cols, colors, type);
 
-    G_freea(array);
-    G_freea(set);
+    G_free(array);
+    G_free(set);
 }

Modified: grass/trunk/lib/raster/put_row.c
===================================================================
--- grass/trunk/lib/raster/put_row.c	2017-07-04 20:53:58 UTC (rev 71240)
+++ grass/trunk/lib/raster/put_row.c	2017-07-05 06:45:24 UTC (rev 71241)
@@ -194,7 +194,7 @@
     if (n <= 0)
 	return;
 
-    work_buf = G_alloca(size + 1);
+    work_buf = G_malloc(size + 1);
 
     if (compressed)
 	set_file_pointer(fd, row);
@@ -209,7 +209,7 @@
     else
 	write_data(fd, row, work_buf, n);
 
-    G_freea(work_buf);
+    G_free(work_buf);
 }
 
 static void convert_int(unsigned char *wk, char *null_buf, const CELL * rast,
@@ -340,7 +340,7 @@
     if (n <= 0)
 	return;
 
-    work_buf = G_alloca(fcb->cellhd.cols * sizeof(CELL) + 1);
+    work_buf = G_malloc(fcb->cellhd.cols * sizeof(CELL) + 1);
     wk = work_buf;
 
     if (compressed)
@@ -365,7 +365,7 @@
 	    trim_bytes(wk, n, len, len - nbytes);
 
 	total = nbytes * n;
-	compressed_buf = G_alloca(total + 1);
+	compressed_buf = G_malloc(total + 1);
 
 	compressed_buf[0] = work_buf[0] = nbytes;
 
@@ -394,7 +394,7 @@
 			      row, fcb->name);
 	}
 
-	G_freea(compressed_buf);
+	G_free(compressed_buf);
     }
     else {
 	nwrite = fcb->nbytes * n;
@@ -404,7 +404,7 @@
 			  row, fcb->name);
     }
 
-    G_freea(work_buf);
+    G_free(work_buf);
 }
 
 static void put_data_gdal(int fd, const void *rast, int row, int n,
@@ -426,7 +426,7 @@
     if (n <= 0)
 	return;
 
-    work_buf = G_alloca(n * size);
+    work_buf = G_malloc(n * size);
 
     switch (map_type) {
     case CELL_TYPE:
@@ -456,7 +456,7 @@
     err = Rast_gdal_raster_IO(fcb->gdal->band, GF_Write, 0, row, n, 1,
 			      work_buf, n, 1, datatype, 0, 0);
 
-    G_freea(work_buf);
+    G_free(work_buf);
 
     if (err != CE_None)
 	G_fatal_error(_("Error writing data via GDAL for row %d of <%s>"),
@@ -503,7 +503,7 @@
 
     fcb->null_row_ptr[row] = lseek(fcb->null_fd, 0L, SEEK_CUR);
 
-    compressed_buf = G_alloca(size + 1);
+    compressed_buf = G_malloc(size + 1);
 
     /* compress null bits file with LZ4, see lib/gis/compress.h */
     nwrite = G_lz4_compress(flags, size, compressed_buf, size);
@@ -519,7 +519,7 @@
 			  row, fcb->name);
     }
 
-    G_freea(compressed_buf);
+    G_free(compressed_buf);
 }
 
 /*!
@@ -693,7 +693,7 @@
 	return;
     }
 
-    null_buf = G_alloca(fcb->cellhd.cols);
+    null_buf = G_malloc(fcb->cellhd.cols);
     G_zero(null_buf, fcb->cellhd.cols);
 
     put_raster_data(fd, null_buf, buf, fcb->cur_row, fcb->cellhd.cols,
@@ -716,5 +716,5 @@
     if (!fcb->gdal)
 	put_null_value_row(fd, null_buf);
 
-    G_freea(null_buf);
+    G_free(null_buf);
 }



More information about the grass-commit mailing list