|  | /* SPDX-License-Identifier: GPL-2.0 */ | 
|  | #ifndef _LINUX_SCHED_PRIO_H | 
|  | #define _LINUX_SCHED_PRIO_H | 
|  |  | 
|  | #define MAX_NICE	19 | 
|  | #define MIN_NICE	-20 | 
|  | #define NICE_WIDTH	(MAX_NICE - MIN_NICE + 1) | 
|  |  | 
|  | /* | 
|  | * Priority of a process goes from 0..MAX_PRIO-1, valid RT | 
|  | * priority is 0..MAX_RT_PRIO-1, and SCHED_NORMAL/SCHED_BATCH | 
|  | * tasks are in the range MAX_RT_PRIO..MAX_PRIO-1. Priority | 
|  | * values are inverted: lower p->prio value means higher priority. | 
|  | * | 
|  | * The MAX_USER_RT_PRIO value allows the actual maximum | 
|  | * RT priority to be separate from the value exported to | 
|  | * user-space.  This allows kernel threads to set their | 
|  | * priority to a value higher than any user task. Note: | 
|  | * MAX_RT_PRIO must not be smaller than MAX_USER_RT_PRIO. | 
|  | */ | 
|  |  | 
|  | #define MAX_USER_RT_PRIO	100 | 
|  | #define MAX_RT_PRIO		MAX_USER_RT_PRIO | 
|  |  | 
|  | #define MAX_PRIO		(MAX_RT_PRIO + NICE_WIDTH) | 
|  | #define DEFAULT_PRIO		(MAX_RT_PRIO + NICE_WIDTH / 2) | 
|  |  | 
|  | /* | 
|  | * Convert user-nice values [ -20 ... 0 ... 19 ] | 
|  | * to static priority [ MAX_RT_PRIO..MAX_PRIO-1 ], | 
|  | * and back. | 
|  | */ | 
|  | #define NICE_TO_PRIO(nice)	((nice) + DEFAULT_PRIO) | 
|  | #define PRIO_TO_NICE(prio)	((prio) - DEFAULT_PRIO) | 
|  |  | 
|  | /* | 
|  | * 'User priority' is the nice value converted to something we | 
|  | * can work with better when scaling various scheduler parameters, | 
|  | * it's a [ 0 ... 39 ] range. | 
|  | */ | 
|  | #define USER_PRIO(p)		((p)-MAX_RT_PRIO) | 
|  | #define TASK_USER_PRIO(p)	USER_PRIO((p)->static_prio) | 
|  | #define MAX_USER_PRIO		(USER_PRIO(MAX_PRIO)) | 
|  |  | 
|  | /* | 
|  | * Convert nice value [19,-20] to rlimit style value [1,40]. | 
|  | */ | 
|  | static inline long nice_to_rlimit(long nice) | 
|  | { | 
|  | return (MAX_NICE - nice + 1); | 
|  | } | 
|  |  | 
|  | /* | 
|  | * Convert rlimit style value [1,40] to nice value [-20, 19]. | 
|  | */ | 
|  | static inline long rlimit_to_nice(long prio) | 
|  | { | 
|  | return (MAX_NICE - prio + 1); | 
|  | } | 
|  |  | 
|  | #endif /* _LINUX_SCHED_PRIO_H */ |