Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 164525
b: refs/heads/master
c: 4af5a2f
h: refs/heads/master
i:
  164523: 1fd2359
v: v3
  • Loading branch information
David Rientjes authored and Linus Torvalds committed Sep 22, 2009
1 parent 5c7d89c commit f10f6a1
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 1 deletion.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 19da3dd157f8db6fe727ff268dab4791d55a6371
refs/heads/master: 4af5a2f770cc8575840ccb1514ec76ecb592985c
1 change: 1 addition & 0 deletions trunk/include/linux/flex_array.h
Original file line number Diff line number Diff line change
Expand Up @@ -46,5 +46,6 @@ 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);
int flex_array_shrink(struct flex_array *fa);

#endif /* _FLEX_ARRAY_H */
40 changes: 40 additions & 0 deletions trunk/lib/flex_array.c
Original file line number Diff line number Diff line change
Expand Up @@ -291,3 +291,43 @@ void *flex_array_get(struct flex_array *fa, unsigned int element_nr)
}
return &part->elements[index_inside_part(fa, element_nr)];
}

static int part_is_free(struct flex_array_part *part)
{
int i;

for (i = 0; i < sizeof(struct flex_array_part); i++)
if (part->elements[i] != FLEX_ARRAY_FREE)
return 0;
return 1;
}

/**
* flex_array_shrink - free unused second-level pages
*
* Frees all second-level pages that consist solely of unused
* elements. Returns the number of pages freed.
*
* Locking must be provided by the caller.
*/
int flex_array_shrink(struct flex_array *fa)
{
struct flex_array_part *part;
int max_part = nr_base_part_ptrs();
int part_nr;
int ret = 0;

if (elements_fit_in_base(fa))
return ret;
for (part_nr = 0; part_nr < max_part; part_nr++) {
part = fa->parts[part_nr];
if (!part)
continue;
if (part_is_free(part)) {
fa->parts[part_nr] = NULL;
kfree(part);
ret++;
}
}
return ret;
}

0 comments on commit f10f6a1

Please sign in to comment.