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-next>] [day] [month] [year] [list]
Date:	Wed, 9 Sep 2015 11:32:43 +0200
From:	Henrik Austad <henrik@...tad.us>
To:	Peter Zijlstra <peterz@...radead.org>,
	Ingo Molnar <mingo@...hat.com>
Cc:	linux-kernel@...r.kernel.org
Subject: Re: [PATCH] sched: make policy-testing consistent in core

As per-irc request

*prod*

thanks!
-Henrik

On Thu, Aug 20, 2015 at 03:54:02PM +0200, Henrik Austad wrote:
> Most of the policy-tests are done via the <class>_policy() helpers with
> the notable exception of idle. A new wrapper for valid_policy() has also
> been added to improve readability  in set_load_weight().
> 
> This commit does not change the logical behavior of the scheduler core.
> 
> Signed-off-by: Henrik Austad <henrik@...tad.us>
> CC: Ingo Molnar <mingo@...hat.com>
> CC: Peter Zijlstra <peterz@...radead.org>
> CC: linux-kernel@...r.kernel.org
> ---
>  kernel/sched/core.c  | 9 +++------
>  kernel/sched/sched.h | 9 +++++++++
>  2 files changed, 12 insertions(+), 6 deletions(-)
> 
> diff --git a/kernel/sched/core.c b/kernel/sched/core.c
> index 78b4bad10081..476a30e5632a 100644
> --- a/kernel/sched/core.c
> +++ b/kernel/sched/core.c
> @@ -816,7 +816,7 @@ static void set_load_weight(struct task_struct *p)
>  	/*
>  	 * SCHED_IDLE tasks get minimal weight:
>  	 */
> -	if (p->policy == SCHED_IDLE) {
> +	if (idle_policy(p->policy)) {
>  		load->weight = scale_load(WEIGHT_IDLEPRIO);
>  		load->inv_weight = WMULT_IDLEPRIO;
>  		return;
> @@ -3684,10 +3684,7 @@ recheck:
>  	} else {
>  		reset_on_fork = !!(attr->sched_flags & SCHED_FLAG_RESET_ON_FORK);
>  
> -		if (policy != SCHED_DEADLINE &&
> -				policy != SCHED_FIFO && policy != SCHED_RR &&
> -				policy != SCHED_NORMAL && policy != SCHED_BATCH &&
> -				policy != SCHED_IDLE)
> +		if (!valid_policy(policy))
>  			return -EINVAL;
>  	}
>  
> @@ -3743,7 +3740,7 @@ recheck:
>  		 * Treat SCHED_IDLE as nice 20. Only allow a switch to
>  		 * SCHED_NORMAL if the RLIMIT_NICE would normally permit it.
>  		 */
> -		if (p->policy == SCHED_IDLE && policy != SCHED_IDLE) {
> +		if (idle_policy(p->policy) && !idle_policy(policy)) {
>  			if (!can_nice(p, task_nice(p)))
>  				return -EPERM;
>  		}
> diff --git a/kernel/sched/sched.h b/kernel/sched/sched.h
> index 84d48790bb6d..fe7cb34cc55b 100644
> --- a/kernel/sched/sched.h
> +++ b/kernel/sched/sched.h
> @@ -84,6 +84,10 @@ static inline void update_cpu_load_active(struct rq *this_rq) { }
>   */
>  #define RUNTIME_INF	((u64)~0ULL)
>  
> +static inline int idle_policy(int policy)
> +{
> +	return policy == SCHED_IDLE;
> +}
>  static inline int fair_policy(int policy)
>  {
>  	return policy == SCHED_NORMAL || policy == SCHED_BATCH;
> @@ -98,6 +102,11 @@ static inline int dl_policy(int policy)
>  {
>  	return policy == SCHED_DEADLINE;
>  }
> +static inline bool valid_policy(int policy)
> +{
> +	return idle_policy(policy) || fair_policy(policy) ||
> +		rt_policy(policy) || dl_policy(policy);
> +}
>  
>  static inline int task_has_rt_policy(struct task_struct *p)
>  {
> -- 
> 1.9.1
> 

-- 
Henrik Austad

Download attachment "signature.asc" of type "application/pgp-signature" (182 bytes)

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ