blob: 468d2565a9fea27c9bffb49219972b77cd782eeb [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Ingo Molnar8703e8a2017-02-08 18:51:30 +01002#ifndef _LINUX_SCHED_USER_H
3#define _LINUX_SCHED_USER_H
4
Ingo Molnarde8deb02017-02-08 18:51:55 +01005#include <linux/uidgid.h>
6#include <linux/atomic.h>
Sebastian Andrzej Siewiorfc371912018-08-21 21:55:38 -07007#include <linux/refcount.h>
Luck, Tonybef3efb2018-02-22 09:15:06 -08008#include <linux/ratelimit.h>
Ingo Molnar8703e8a2017-02-08 18:51:30 +01009
Ingo Molnarbcbb6a52017-02-02 10:22:42 +010010struct key;
11
12/*
13 * Some day this will be a full-fledged user tracking system..
14 */
15struct user_struct {
Sebastian Andrzej Siewiorfc371912018-08-21 21:55:38 -070016 refcount_t __count; /* reference count */
Ingo Molnarbcbb6a52017-02-02 10:22:42 +010017 atomic_t processes; /* How many processes does this user have? */
18 atomic_t sigpending; /* How many pending signals does this user have? */
19#ifdef CONFIG_FANOTIFY
20 atomic_t fanotify_listeners;
21#endif
22#ifdef CONFIG_EPOLL
23 atomic_long_t epoll_watches; /* The number of file descriptors currently watched */
24#endif
25#ifdef CONFIG_POSIX_MQUEUE
26 /* protected by mq_lock */
27 unsigned long mq_bytes; /* How many bytes can be allocated to mqueue? */
28#endif
29 unsigned long locked_shm; /* How many pages of mlocked shm ? */
30 unsigned long unix_inflight; /* How many files in flight in unix sockets */
31 atomic_long_t pipe_bufs; /* how many pages are allocated in pipe buffers */
32
33#ifdef CONFIG_KEYS
Jann Horn0b9dc6c2019-03-27 16:55:08 +010034 /*
35 * These pointers can only change from NULL to a non-NULL value once.
36 * Writes are protected by key_user_keyring_mutex.
37 * Unlocked readers should use READ_ONCE() unless they know that
38 * install_user_keyrings() has been called successfully (which sets
39 * these members to non-NULL values, preventing further modifications).
40 */
Ingo Molnarbcbb6a52017-02-02 10:22:42 +010041 struct key *uid_keyring; /* UID specific keyring */
42 struct key *session_keyring; /* UID's default session keyring */
43#endif
44
45 /* Hash table maintenance information */
46 struct hlist_node uidhash_node;
47 kuid_t uid;
48
Willem de Bruijna91dbff2017-08-03 16:29:43 -040049#if defined(CONFIG_PERF_EVENTS) || defined(CONFIG_BPF_SYSCALL) || \
Jens Axboe2b188cc2019-01-07 10:46:33 -070050 defined(CONFIG_NET) || defined(CONFIG_IO_URING)
Ingo Molnarbcbb6a52017-02-02 10:22:42 +010051 atomic_long_t locked_vm;
52#endif
Luck, Tonybef3efb2018-02-22 09:15:06 -080053
54 /* Miscellaneous per-user rate limit */
55 struct ratelimit_state ratelimit;
Ingo Molnarbcbb6a52017-02-02 10:22:42 +010056};
57
58extern int uids_sysfs_init(void);
59
60extern struct user_struct *find_user(kuid_t);
61
62extern struct user_struct root_user;
63#define INIT_USER (&root_user)
64
65
66/* per-UID process charging. */
67extern struct user_struct * alloc_uid(kuid_t);
68static inline struct user_struct *get_uid(struct user_struct *u)
69{
Sebastian Andrzej Siewiorfc371912018-08-21 21:55:38 -070070 refcount_inc(&u->__count);
Ingo Molnarbcbb6a52017-02-02 10:22:42 +010071 return u;
72}
73extern void free_uid(struct user_struct *);
74
Ingo Molnar8703e8a2017-02-08 18:51:30 +010075#endif /* _LINUX_SCHED_USER_H */