lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Sat, 05 Aug 2006 01:09:47 +0159
From:	Jiri Slaby <jirislaby@...il.com>
To:	vatsa@...ibm.com
CC:	Ingo Molnar <mingo@...e.hu>, Nick Piggin <nickpiggin@...oo.com.au>,
	Sam Vilain <sam@...ain.net>, linux-kernel@...r.kernel.org,
	Kirill Korotaev <dev@...nvz.org>,
	Mike Galbraith <efault@....de>,
	Balbir Singh <balbir@...ibm.com>, sekharan@...ibm.com,
	Andrew Morton <akpm@...l.org>, nagar@...son.ibm.com,
	haveblue@...ibm.com, pj@....com
Subject: Re: [ RFC, PATCH 2/5 ] CPU controller - Define group operations

Srivatsa Vaddagiri wrote:
> Define these operations for a task-group:
> 
> 	- create new group
> 	- destroy existing group
> 	- assign bandwidth (quota) for a group
> 	- get bandwidth (quota) of a group
> 
> 
> Signed-off-by : Srivatsa Vaddagiri <vatsa@...ibm.com>
> 
> 
> 
>  include/linux/sched.h |   12 +++++++
>  kernel/sched.c        |   79 ++++++++++++++++++++++++++++++++++++++++++++++++++
>  2 files changed, 91 insertions(+)
> 
> diff -puN kernel/sched.c~cpu_ctlr_grp_ops kernel/sched.c
> --- linux-2.6.18-rc3/kernel/sched.c~cpu_ctlr_grp_ops	2006-08-04 07:58:50.000000000 +0530
> +++ linux-2.6.18-rc3-root/kernel/sched.c	2006-08-04 07:58:50.000000000 +0530
> @@ -7063,3 +7063,82 @@ void set_curr_task(int cpu, struct task_
>  }
>  
>  #endif
> +
> +#ifdef CONFIG_CPUMETER
> +
> +/* Allocate runqueue structures for the new task-group */
> +void *sched_alloc_group(void)
> +{
> +	struct task_grp *tg;
> +	struct task_grp_rq *tgrq;
> +	int i;
> +
> +	tg = kzalloc(sizeof(*tg), GFP_KERNEL);
> +	if (!tg)
> +		return NULL;
> +
> +	tg->ticks = -1;		/* No limit */
> +
> +	for_each_possible_cpu(i) {
> +		tgrq = kzalloc(sizeof(*tgrq), GFP_KERNEL);
> +		if (!tgrq)
> +			goto oom;
> +		tg->rq[i] = tgrq;
> +		task_grp_rq_init(tgrq, tg->ticks);
> +	}
> +
> +	return (void *)tg;

unneeded cast

> +oom:
> +	while (i--)
> +		kfree(tg->rq[i]);
> +
> +	kfree(tg);
> +	return NULL;
> +}
> +
> +/* Deallocate runqueue structures */
> +void sched_dealloc_group(void *grp)
> +{
> +	struct task_grp *tg = (struct task_grp *)grp;

again

> +	int i;
> +
> +	for_each_possible_cpu(i)
> +		kfree(tg->rq[i]);
> +
> +	kfree(tg);
> +}
> +
> +/* Assign quota to this group */
> +void sched_assign_quota(void *grp, int quota)
> +{
> +	struct task_grp *tg = (struct task_grp *)grp;

and one more time

> +	int i;
> +
> +	tg->ticks = (quota * 5 * HZ) / 100;
> +
> +	for_each_possible_cpu(i)
> +		tg->rq[i]->ticks = tg->ticks;
> +
> +}
> +
> +/* Return assigned quota for this group */
> +int sched_get_quota(void *grp)
> +{
> +	struct task_grp *tg = (struct task_grp *)grp;

...

> +	int quota;
> +
> +	quota = (tg->ticks * 100) / (5 * HZ);
> +
> +	return quota;

what about to just
return (tg->ticks * 100) / (5 * HZ);

regards,
-- 
<a href="http://www.fi.muni.cz/~xslaby/">Jiri Slaby</a>
faculty of informatics, masaryk university, brno, cz
e-mail: jirislaby gmail com, gpg pubkey fingerprint:
B674 9967 0407 CE62 ACC8  22A0 32CC 55C3 39D4 7A7E
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ