diff options
| -rw-r--r-- | include/linux/flex_array.h | 1 | ||||
| -rw-r--r-- | lib/flex_array.c | 26 | 
2 files changed, 27 insertions, 0 deletions
diff --git a/include/linux/flex_array.h b/include/linux/flex_array.h index 45ff1849151..3887b21f883 100644 --- a/include/linux/flex_array.h +++ b/include/linux/flex_array.h @@ -44,6 +44,7 @@ void flex_array_free(struct flex_array *fa);  void flex_array_free_parts(struct flex_array *fa);  int flex_array_put(struct flex_array *fa, unsigned int element_nr, void *src,  		gfp_t flags); +int flex_array_clear(struct flex_array *fa, unsigned int element_nr);  void *flex_array_get(struct flex_array *fa, unsigned int element_nr);  #endif /* _FLEX_ARRAY_H */ diff --git a/lib/flex_array.c b/lib/flex_array.c index 7baed2fc3bc..b68f99be408 100644 --- a/lib/flex_array.c +++ b/lib/flex_array.c @@ -207,6 +207,32 @@ int flex_array_put(struct flex_array *fa, unsigned int element_nr, void *src,  }  /** + * flex_array_clear - clear element in array at @element_nr + * @element_nr:	index of the position to clear. + * + * Locking must be provided by the caller. + */ +int flex_array_clear(struct flex_array *fa, unsigned int element_nr) +{ +	int part_nr = fa_element_to_part_nr(fa, element_nr); +	struct flex_array_part *part; +	void *dst; + +	if (element_nr >= fa->total_nr_elements) +		return -ENOSPC; +	if (elements_fit_in_base(fa)) +		part = (struct flex_array_part *)&fa->parts[0]; +	else { +		part = fa->parts[part_nr]; +		if (!part) +			return -EINVAL; +	} +	dst = &part->elements[index_inside_part(fa, element_nr)]; +	memset(dst, 0, fa->element_size); +	return 0; +} + +/**   * flex_array_prealloc - guarantee that array space exists   * @start:	index of first array element for which space is allocated   * @end:	index of last (inclusive) element for which space is allocated  |