shithub: libsamplerate

Download patch

ref: 36dfd68836a185182775a0ca760dd2bbbcd53e30
parent: 8a83ad3cca8596b34ff0d0faadd0d7b5c801faea
author: evpobr <[email protected]>
date: Tue Oct 27 17:47:48 EDT 2020

Reduce usage of flexible array fields

--- a/src/src_linear.c
+++ b/src/src_linear.c
@@ -31,7 +31,7 @@
 	bool	dirty ;
 	long	in_count, in_used ;
 	long	out_count, out_gen ;
-	float	last_value [] ;
+	float	*last_value ;
 } LINEAR_DATA ;
 
 /*----------------------------------------------------------------------------------------
@@ -160,7 +160,8 @@
 
 enum SRC_ERR
 linear_set_converter (SRC_STATE *state, int src_enum)
-{	LINEAR_DATA *priv = NULL ;
+{
+	LINEAR_DATA *priv = NULL ;
 
 	if (src_enum != SRC_LINEAR)
 		return SRC_ERR_BAD_CONVERTER ;
@@ -168,13 +169,24 @@
 	linear_close (state) ;
 
 	if (state->private_data == NULL)
-	{	priv = ZERO_ALLOC (LINEAR_DATA, sizeof (*priv) + state->channels * sizeof (float)) ;
-		state->private_data = priv ;
-		} ;
+	{
+		priv = ZERO_ALLOC (ZOH_DATA, sizeof (*priv)) ;
+		if (priv)
+		{
+			priv->last_value = calloc (state->channels, sizeof (float)) ;
+			if (!priv->last_value)
+			{
+				free (priv) ;
+				priv = NULL ;
+			}
+		}
+	}
 
 	if (priv == NULL)
 		return SRC_ERR_MALLOC_FAILED ;
 
+	state->private_data = priv ;
+
 	priv->linear_magic_marker = LINEAR_MAGIC_MARKER ;
 
 	state->const_process = linear_vari_process ;
@@ -213,12 +225,18 @@
 
 	LINEAR_DATA *to_priv = NULL ;
 	LINEAR_DATA* from_priv = (LINEAR_DATA*) from->private_data ;
-	size_t private_size = sizeof (*to_priv) + from->channels * sizeof (float) ;
+	if ((to_priv = ZERO_ALLOC (LINEAR_DATA, sizeof (LINEAR_DATA))) == NULL)
+		return SRC_ERR_MALLOC_FAILED ;
 
-	if ((to_priv = ZERO_ALLOC (LINEAR_DATA, private_size)) == NULL)
+	memcpy (to_priv, from_priv, sizeof (LINEAR_DATA)) ;
+	to_priv->last_value = malloc (sizeof (float) * from->channels) ;
+	if (!to_priv->last_value)
+	{
+		free (to_priv) ;
 		return SRC_ERR_MALLOC_FAILED ;
+	}
+	memcpy (to_priv->last_value, from_priv->last_value, sizeof (float) * from->channels) ;
 
-	memcpy (to_priv, from_priv, private_size) ;
 	to->private_data = to_priv ;
 
 	return SRC_ERR_NO_ERROR ;
@@ -229,10 +247,15 @@
 {
 	if (state)
 	{
-		if (state->private_data)
+		LINEAR_DATA *linear = (LINEAR_DATA *) state->private_data ;
+		if (linear)
 		{
-			free (state->private_data) ;
-			state->private_data = NULL ;
+			if (linear->last_value)
+			{	free (linear->last_value) ;
+				linear->last_value = NULL ;
+				} ;
+			free (linear) ;
+			linear = NULL ;
 		}
 	}
 } /* linear_close */
--- a/src/src_sinc.c
+++ b/src/src_sinc.c
@@ -53,8 +53,7 @@
 	/* Sure hope noone does more than 128 channels at once. */
 	double left_calc [128], right_calc [128] ;
 
-	/* C99 struct flexible array. */
-	float	buffer [] ;
+	float	*buffer ;
 } SINC_FILTER ;
 
 static enum SRC_ERR sinc_multichan_vari_process (SRC_STATE *state, SRC_DATA *data) ;
@@ -220,10 +219,16 @@
 	temp_filter.b_len *= state->channels ;
 	temp_filter.b_len += 1 ; // There is a <= check against samples_in_hand requiring a buffer bigger than the calculation above
 
-	if ((filter = ZERO_ALLOC (SINC_FILTER, sizeof (SINC_FILTER) + sizeof (filter->buffer [0]) * (temp_filter.b_len + state->channels))) == NULL)
+	if ((filter = ZERO_ALLOC (SINC_FILTER, sizeof (SINC_FILTER))) == NULL)
 		return SRC_ERR_MALLOC_FAILED ;
 
 	*filter = temp_filter ;
+	filter->buffer = calloc (temp_filter.b_len + state->channels, sizeof (float)) ;
+	if (!filter->buffer)
+	{	free (filter) ;
+		return SRC_ERR_MALLOC_FAILED ;
+		} ;
+
 	memset (&temp_filter, 0xEE, sizeof (temp_filter)) ;
 
 	state->private_data = filter ;
@@ -267,12 +272,18 @@
 
 	SINC_FILTER *to_filter = NULL ;
 	SINC_FILTER* from_filter = (SINC_FILTER*) from->private_data ;
-	size_t private_length = sizeof (SINC_FILTER) + sizeof (from_filter->buffer [0]) * (from_filter->b_len + from->channels) ;
 
-	if ((to_filter = ZERO_ALLOC (SINC_FILTER, private_length)) == NULL)
+	if ((to_filter = ZERO_ALLOC (SINC_FILTER, sizeof (SINC_FILTER))) == NULL)
 		return SRC_ERR_MALLOC_FAILED ;
+	memcpy (to_filter, from_filter, sizeof (SINC_FILTER)) ;
+	to_filter->buffer = malloc (sizeof (float) * (from_filter->b_len + from->channels)) ;
+	if (!to_filter->buffer)
+	{
+		free (to_filter) ;
+		return SRC_ERR_MALLOC_FAILED ;
+	}
+	memcpy (to_filter->buffer, from_filter->buffer, sizeof (float) * (from_filter->b_len + from->channels)) ;
 
-	memcpy (to_filter, from_filter, private_length) ;
 	to->private_data = to_filter ;
 
 	return SRC_ERR_NO_ERROR ;
@@ -1150,10 +1161,15 @@
 {
 	if (state)
 	{
-		if (state->private_data)
+		SINC_FILTER *sinc = (SINC_FILTER *) state->private_data ;
+		if (sinc)
 		{
-			free (state->private_data) ;
-			state->private_data = NULL ;
+			if (sinc->buffer)
+			{	free (sinc->buffer) ;
+				sinc->buffer = NULL ;
+				} ;
+			free (sinc) ;
+			sinc = NULL ;
 		}
 	}
 } /* sinc_close */
--- a/src/src_zoh.c
+++ b/src/src_zoh.c
@@ -29,7 +29,7 @@
 	bool	dirty ;
 	long	in_count, in_used ;
 	long	out_count, out_gen ;
-	float	last_value [] ;
+	float	*last_value ;
 } ZOH_DATA ;
 
 /*----------------------------------------------------------------------------------------
@@ -151,7 +151,8 @@
 
 enum SRC_ERR
 zoh_set_converter (SRC_STATE *state, int src_enum)
-{	ZOH_DATA *priv = NULL ;
+{
+	ZOH_DATA *priv = NULL ;
 
 	if (src_enum != SRC_ZERO_ORDER_HOLD)
 		return SRC_ERR_BAD_CONVERTER ;
@@ -159,13 +160,24 @@
 	zoh_close (state) ;
 
 	if (state->private_data == NULL)
-	{	priv = ZERO_ALLOC (ZOH_DATA, sizeof (*priv) + state->channels * sizeof (float)) ;
-		state->private_data = priv ;
-		} ;
+	{
+		priv = ZERO_ALLOC (ZOH_DATA, sizeof (*priv)) ;
+		if (priv)
+		{
+			priv->last_value = calloc (state->channels, sizeof (float)) ;
+			if (!priv->last_value)
+			{
+				free (priv) ;
+				priv = NULL ;
+			}
+		}
+	}
 
 	if (priv == NULL)
 		return SRC_ERR_MALLOC_FAILED ;
 
+	state->private_data = priv ;
+
 	priv->zoh_magic_marker = ZOH_MAGIC_MARKER ;
 
 	state->const_process = zoh_vari_process ;
@@ -191,7 +203,7 @@
 		return ;
 
 	priv->dirty = false ;
-	memset (priv->last_value, 0, sizeof (priv->last_value [0]) * state->channels) ;
+	memset (priv->last_value, 0, sizeof (float) * state->channels) ;
 
 	return ;
 } /* zoh_reset */
@@ -204,12 +216,18 @@
 
 	ZOH_DATA *to_priv = NULL ;
 	ZOH_DATA* from_priv = (ZOH_DATA*) from->private_data ;
-	size_t private_size = sizeof (*to_priv) + from->channels * sizeof (float) ;
 
-	if ((to_priv = ZERO_ALLOC (ZOH_DATA, private_size)) == NULL)
+	if ((to_priv = ZERO_ALLOC (ZOH_DATA, sizeof (ZOH_DATA))) == NULL)
 		return SRC_ERR_MALLOC_FAILED ;
 
-	memcpy (to_priv, from_priv, private_size) ;
+	memcpy (to_priv, from_priv, sizeof (ZOH_DATA)) ;
+	to_priv->last_value = malloc (sizeof (float) * from->channels) ;
+	if (!to_priv->last_value)
+	{	free (to_priv) ;
+		return SRC_ERR_MALLOC_FAILED ;
+		} ;
+	memcpy (to_priv->last_value, from_priv->last_value, sizeof (float) * from->channels) ;
+
 	to->private_data = to_priv ;
 
 	return SRC_ERR_NO_ERROR ;
@@ -220,10 +238,15 @@
 {
 	if (state)
 	{
-		if (state->private_data)
+		ZOH_DATA *zoh = (ZOH_DATA *) state->private_data ;
+		if (zoh)
 		{
-			free (state->private_data) ;
-			state->private_data = NULL ;
+			if (zoh->last_value)
+			{	free (zoh->last_value) ;
+				zoh->last_value = NULL ;
+				} ;
+			free (zoh) ;
+			zoh = NULL ;
 		}
 	}
 } /* zoh_close */