Re: [PATCH -V8 13/16] hugetlb/cgroup: add hugetlb cgroup control files

From: Aneesh Kumar K.V
Date: Mon Jun 11 2012 - 05:43:38 EST


Michal Hocko <mhocko@xxxxxxx> writes:

> On Sat 09-06-12 14:29:58, Aneesh Kumar K.V wrote:
>> From: "Aneesh Kumar K.V" <aneesh.kumar@xxxxxxxxxxxxxxxxxx>
>>
>> Add the control files for hugetlb controller
>>
>> Signed-off-by: Aneesh Kumar K.V <aneesh.kumar@xxxxxxxxxxxxxxxxxx>
>> ---
> [...]
>> +int __init hugetlb_cgroup_file_init(int idx)
>> +{
>> + char buf[32];
>> + struct cftype *cft;
>> + struct hstate *h = &hstates[idx];
>> +
>> + /* format the size */
>> + mem_fmt(buf, 32, huge_page_size(h));
>> +
>> + /* Add the limit file */
>> + cft = &h->cgroup_files[0];
>> + snprintf(cft->name, MAX_CFTYPE_NAME, "%s.limit_in_bytes", buf);
>> + cft->private = MEMFILE_PRIVATE(idx, RES_LIMIT);
>> + cft->read = hugetlb_cgroup_read;
>> + cft->write_string = hugetlb_cgroup_write;
>> +
>> + /* Add the usage file */
>> + cft = &h->cgroup_files[1];
>> + snprintf(cft->name, MAX_CFTYPE_NAME, "%s.usage_in_bytes", buf);
>> + cft->private = MEMFILE_PRIVATE(idx, RES_USAGE);
>> + cft->read = hugetlb_cgroup_read;
>> +
>> + /* Add the MAX usage file */
>> + cft = &h->cgroup_files[2];
>> + snprintf(cft->name, MAX_CFTYPE_NAME, "%s.max_usage_in_bytes", buf);
>> + cft->private = MEMFILE_PRIVATE(idx, RES_MAX_USAGE);
>> + cft->trigger = hugetlb_cgroup_reset;
>> + cft->read = hugetlb_cgroup_read;
>> +
>> + /* Add the failcntfile */
>> + cft = &h->cgroup_files[3];
>> + snprintf(cft->name, MAX_CFTYPE_NAME, "%s.failcnt", buf);
>> + cft->private = MEMFILE_PRIVATE(idx, RES_FAILCNT);
>> + cft->trigger = hugetlb_cgroup_reset;
>> + cft->read = hugetlb_cgroup_read;
>> +
>> + /* NULL terminate the last cft */
>> + cft = &h->cgroup_files[4];
>> + memset(cft, 0, sizeof(*cft));
>> +
>> + WARN_ON(cgroup_add_cftypes(&hugetlb_subsys, h->cgroup_files));
>> +
>> + return 0;
>> +}
>> +
>
> I am not so familiar with the recent changes in the generic cgroup
> infrastructure but isn't this somehow automated?

yes for most of the cgroups. But in the hugetlb case we have variable number
of control files. We have the above set of control files for each
hugetlb size supported by the architecture.

-aneesh

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/