On Fri, Apr 08, 2022 at 04:57:40AM +0000, Yosry Ahmed wrote:
+static ssize_t memory_reclaim(struct kernfs_open_file *of, char *buf,
size_t nbytes, loff_t off)+{
- struct mem_cgroup *memcg = mem_cgroup_from_css(of_css(of));
- unsigned int nr_retries = MAX_RECLAIM_RETRIES;
- unsigned long nr_to_reclaim, nr_reclaimed = 0;
- int err;
- buf = strstrip(buf);
- err = page_counter_memparse(buf, "", &nr_to_reclaim);
Is there a reason not to support "max"? Empty string seems odd to me here.
- if (err)
return err;- while (nr_reclaimed < nr_to_reclaim) {
unsigned long reclaimed;if (signal_pending(current))break;
I think this should be `return -EINTR;`
reclaimed = try_to_free_mem_cgroup_pages(memcg,nr_to_reclaim - nr_reclaimed,GFP_KERNEL, true);if (!reclaimed && !nr_retries--)break;
Here you can just `return -EAGAIN;`
nr_reclaimed += reclaimed;- }
- return nr_reclaimed < nr_to_reclaim ? -EAGAIN : nbytes;
Then this can just be `return nbytes;`
I'm very much in favor of this new interface. Thanks for working on it!