mirror of
				https://kernel.googlesource.com/pub/scm/linux/kernel/git/torvalds/linux
				synced 2025-11-04 08:34:47 +10:00 
			
		
		
		
	leds: is31fl32xx: Use struct_size() helper
One of the more common cases of allocation size calculations is finding
the size of a structure that has a zero-sized array at the end, along
with memory for some number of elements for that array. For example:
struct is31fl32xx_priv {
	...
        struct is31fl32xx_led_data leds[0];
};
Make use of the struct_size() helper instead of an open-coded version
in order to avoid any potential type mistakes.
So, replace the following function:
static inline size_t sizeof_is31fl32xx_priv(int num_leds)
{
       return sizeof(struct is31fl32xx_priv) +
                     (sizeof(struct is31fl32xx_led_data) * num_leds);
}
with:
struct_size(priv, leds, count)
This code was detected with the help of Coccinelle.
Signed-off-by: Gustavo A. R. Silva <gustavo@embeddedor.com>
Acked-by: Pavel Machek <pavel@ucw.cz>
Signed-off-by: Jacek Anaszewski <jacek.anaszewski@gmail.com>
			
			
This commit is contained in:
		
							parent
							
								
									2637fd436c
								
							
						
					
					
						commit
						1669ec78b8
					
				@ -324,12 +324,6 @@ static int is31fl32xx_init_regs(struct is31fl32xx_priv *priv)
 | 
			
		||||
	return 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static inline size_t sizeof_is31fl32xx_priv(int num_leds)
 | 
			
		||||
{
 | 
			
		||||
	return sizeof(struct is31fl32xx_priv) +
 | 
			
		||||
		      (sizeof(struct is31fl32xx_led_data) * num_leds);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static int is31fl32xx_parse_child_dt(const struct device *dev,
 | 
			
		||||
				     const struct device_node *child,
 | 
			
		||||
				     struct is31fl32xx_led_data *led_data)
 | 
			
		||||
@ -450,7 +444,7 @@ static int is31fl32xx_probe(struct i2c_client *client,
 | 
			
		||||
	if (!count)
 | 
			
		||||
		return -EINVAL;
 | 
			
		||||
 | 
			
		||||
	priv = devm_kzalloc(dev, sizeof_is31fl32xx_priv(count),
 | 
			
		||||
	priv = devm_kzalloc(dev, struct_size(priv, leds, count),
 | 
			
		||||
			    GFP_KERNEL);
 | 
			
		||||
	if (!priv)
 | 
			
		||||
		return -ENOMEM;
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user