|
@@ -232,10 +232,10 @@ EXPORT_SYMBOL(flex_array_clear);
|
|
|
|
|
|
/**
|
|
/**
|
|
* flex_array_prealloc - guarantee that array space exists
|
|
* flex_array_prealloc - guarantee that array space exists
|
|
- * @fa: the flex array for which to preallocate parts
|
|
|
|
- * @start: index of first array element for which space is allocated
|
|
|
|
- * @end: index of last (inclusive) element for which space is allocated
|
|
|
|
- * @flags: page allocation flags
|
|
|
|
|
|
+ * @fa: the flex array for which to preallocate parts
|
|
|
|
+ * @start: index of first array element for which space is allocated
|
|
|
|
+ * @nr_elements: number of elements for which space is allocated
|
|
|
|
+ * @flags: page allocation flags
|
|
*
|
|
*
|
|
* This will guarantee that no future calls to flex_array_put()
|
|
* This will guarantee that no future calls to flex_array_put()
|
|
* will allocate memory. It can be used if you are expecting to
|
|
* will allocate memory. It can be used if you are expecting to
|
|
@@ -245,13 +245,16 @@ EXPORT_SYMBOL(flex_array_clear);
|
|
* Locking must be provided by the caller.
|
|
* Locking must be provided by the caller.
|
|
*/
|
|
*/
|
|
int flex_array_prealloc(struct flex_array *fa, unsigned int start,
|
|
int flex_array_prealloc(struct flex_array *fa, unsigned int start,
|
|
- unsigned int end, gfp_t flags)
|
|
|
|
|
|
+ unsigned int nr_elements, gfp_t flags)
|
|
{
|
|
{
|
|
int start_part;
|
|
int start_part;
|
|
int end_part;
|
|
int end_part;
|
|
int part_nr;
|
|
int part_nr;
|
|
|
|
+ unsigned int end;
|
|
struct flex_array_part *part;
|
|
struct flex_array_part *part;
|
|
|
|
|
|
|
|
+ end = start + nr_elements - 1;
|
|
|
|
+
|
|
if (start >= fa->total_nr_elements || end >= fa->total_nr_elements)
|
|
if (start >= fa->total_nr_elements || end >= fa->total_nr_elements)
|
|
return -ENOSPC;
|
|
return -ENOSPC;
|
|
if (elements_fit_in_base(fa))
|
|
if (elements_fit_in_base(fa))
|