blob: d01c96c1966e2724460eeaaef3bdd6c522fc7bda [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _LINUX_RESOURCE_H
2#define _LINUX_RESOURCE_H
3
4#include <linux/time.h>
Jean Delvare8705a1b2010-11-11 14:05:07 -08005#include <linux/types.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07006
7/*
8 * Resource control/accounting header file for linux
9 */
10
11/*
12 * Definition of struct rusage taken from BSD 4.3 Reno
13 *
14 * We don't support all of these yet, but we might as well have them....
15 * Otherwise, each time we add new items, programs which depend on this
16 * structure will lose. This reduces the chances of that happening.
17 */
18#define RUSAGE_SELF 0
19#define RUSAGE_CHILDREN (-1)
20#define RUSAGE_BOTH (-2) /* sys_wait4() uses this */
Sripathi Kodi679c9cd2008-04-29 00:58:42 -070021#define RUSAGE_THREAD 1 /* only the calling thread */
Linus Torvalds1da177e2005-04-16 15:20:36 -070022
23struct rusage {
24 struct timeval ru_utime; /* user time used */
25 struct timeval ru_stime; /* system time used */
26 long ru_maxrss; /* maximum resident set size */
27 long ru_ixrss; /* integral shared memory size */
28 long ru_idrss; /* integral unshared data size */
29 long ru_isrss; /* integral unshared stack size */
30 long ru_minflt; /* page reclaims */
31 long ru_majflt; /* page faults */
32 long ru_nswap; /* swaps */
33 long ru_inblock; /* block input operations */
34 long ru_oublock; /* block output operations */
35 long ru_msgsnd; /* messages sent */
36 long ru_msgrcv; /* messages received */
37 long ru_nsignals; /* signals received */
38 long ru_nvcsw; /* voluntary context switches */
39 long ru_nivcsw; /* involuntary " */
40};
41
42struct rlimit {
43 unsigned long rlim_cur;
44 unsigned long rlim_max;
45};
46
Jiri Slaby6a1d5e22010-03-24 17:06:58 +010047#define RLIM64_INFINITY (~0ULL)
48
49struct rlimit64 {
50 __u64 rlim_cur;
51 __u64 rlim_max;
52};
53
Linus Torvalds1da177e2005-04-16 15:20:36 -070054#define PRIO_MIN (-20)
55#define PRIO_MAX 20
56
57#define PRIO_PROCESS 0
58#define PRIO_PGRP 1
59#define PRIO_USER 2
60
61/*
62 * Limit the stack by to some sane default: root can always
63 * increase this limit if needed.. 8MB seems reasonable.
64 */
65#define _STK_LIM (8*1024*1024)
66
67/*
Kurt Garloff08334222008-10-29 14:00:48 -070068 * GPG2 wants 64kB of mlocked memory, to make sure pass phrases
Linus Torvalds1da177e2005-04-16 15:20:36 -070069 * and other sensitive information are never written to disk.
70 */
Kurt Garloff08334222008-10-29 14:00:48 -070071#define MLOCK_LIMIT ((PAGE_SIZE > 64*1024) ? PAGE_SIZE : 64*1024)
Linus Torvalds1da177e2005-04-16 15:20:36 -070072
73/*
74 * Due to binary compatibility, the actual resource numbers
75 * may be different for different linux versions..
76 */
77#include <asm/resource.h>
78
Jiri Slaby96d07d22009-11-20 14:16:33 +010079#ifdef __KERNEL__
80
81struct task_struct;
82
Adrian Bunk83cc5ed2006-06-25 05:47:41 -070083int getrusage(struct task_struct *p, int who, struct rusage __user *ru);
Jiri Slaby5b415352010-03-24 16:11:29 +010084int do_prlimit(struct task_struct *tsk, unsigned int resource,
85 struct rlimit *new_rlim, struct rlimit *old_rlim);
Adrian Bunk83cc5ed2006-06-25 05:47:41 -070086
Jiri Slaby96d07d22009-11-20 14:16:33 +010087#endif /* __KERNEL__ */
88
Linus Torvalds1da177e2005-04-16 15:20:36 -070089#endif