hc
2024-11-01 2f529f9b558ca1c1bd74be7437a84e4711743404
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _LINUX_SCHED_USER_H
#define _LINUX_SCHED_USER_H
 
#include <linux/uidgid.h>
#include <linux/atomic.h>
#include <linux/refcount.h>
#include <linux/ratelimit.h>
#include <linux/android_kabi.h>
 
/*
 * Some day this will be a full-fledged user tracking system..
 */
struct user_struct {
   refcount_t __count;    /* reference count */
   atomic_t processes;    /* How many processes does this user have? */
   atomic_t sigpending;    /* How many pending signals does this user have? */
#ifdef CONFIG_FANOTIFY
   atomic_t fanotify_listeners;
#endif
#ifdef CONFIG_EPOLL
   atomic_long_t epoll_watches; /* The number of file descriptors currently watched */
#endif
#ifdef CONFIG_POSIX_MQUEUE
   /* protected by mq_lock    */
   unsigned long mq_bytes;    /* How many bytes can be allocated to mqueue? */
#endif
   unsigned long locked_shm; /* How many pages of mlocked shm ? */
   unsigned long unix_inflight;    /* How many files in flight in unix sockets */
   atomic_long_t pipe_bufs;  /* how many pages are allocated in pipe buffers */
 
   /* Hash table maintenance information */
   struct hlist_node uidhash_node;
   kuid_t uid;
 
#if defined(CONFIG_PERF_EVENTS) || defined(CONFIG_BPF_SYSCALL) || \
    defined(CONFIG_NET) || defined(CONFIG_IO_URING)
   atomic_long_t locked_vm;
#endif
#ifdef CONFIG_WATCH_QUEUE
   atomic_t nr_watches;    /* The number of watches this user currently has */
#endif
 
   /* Miscellaneous per-user rate limit */
   struct ratelimit_state ratelimit;
 
   ANDROID_KABI_RESERVE(1);
   ANDROID_KABI_RESERVE(2);
   ANDROID_OEM_DATA_ARRAY(1, 2);
};
 
extern int uids_sysfs_init(void);
 
extern struct user_struct *find_user(kuid_t);
 
extern struct user_struct root_user;
#define INIT_USER (&root_user)
 
 
/* per-UID process charging. */
extern struct user_struct * alloc_uid(kuid_t);
static inline struct user_struct *get_uid(struct user_struct *u)
{
   refcount_inc(&u->__count);
   return u;
}
extern void free_uid(struct user_struct *);
 
#endif /* _LINUX_SCHED_USER_H */