2012-12-24 15:36:14 +04:00
|
|
|
#ifndef __CR_PROC_PARSE_H__
|
|
|
|
#define __CR_PROC_PARSE_H__
|
2012-01-13 20:54:08 +04:00
|
|
|
|
2012-04-05 15:43:00 +04:00
|
|
|
#include <sys/types.h>
|
2013-01-09 17:02:47 +04:00
|
|
|
#include "asm/types.h"
|
2012-07-11 09:22:38 +04:00
|
|
|
#include "image.h"
|
2012-04-05 15:43:00 +04:00
|
|
|
#include "list.h"
|
2014-07-10 17:00:28 +04:00
|
|
|
#include "cgroup.h"
|
2015-08-11 17:18:07 +03:00
|
|
|
#include "mount.h"
|
2012-04-05 15:43:00 +04:00
|
|
|
|
2013-02-15 17:33:06 +04:00
|
|
|
#include "protobuf/eventfd.pb-c.h"
|
|
|
|
#include "protobuf/eventpoll.pb-c.h"
|
|
|
|
#include "protobuf/signalfd.pb-c.h"
|
|
|
|
#include "protobuf/fsnotify.pb-c.h"
|
2014-06-30 21:58:05 +04:00
|
|
|
#include "protobuf/timerfd.pb-c.h"
|
2012-07-17 07:24:54 +04:00
|
|
|
|
2012-01-15 20:24:13 +04:00
|
|
|
#define PROC_TASK_COMM_LEN 32
|
|
|
|
#define PROC_TASK_COMM_LEN_FMT "(%31s"
|
2012-01-13 20:54:08 +04:00
|
|
|
|
|
|
|
struct proc_pid_stat {
|
2012-01-14 01:48:29 +04:00
|
|
|
int pid;
|
2012-01-15 20:24:13 +04:00
|
|
|
char comm[PROC_TASK_COMM_LEN];
|
2012-01-14 01:48:29 +04:00
|
|
|
char state;
|
|
|
|
int ppid;
|
|
|
|
int pgid;
|
|
|
|
int sid;
|
|
|
|
int tty_nr;
|
|
|
|
int tty_pgrp;
|
|
|
|
unsigned int flags;
|
|
|
|
unsigned long min_flt;
|
|
|
|
unsigned long cmin_flt;
|
|
|
|
unsigned long maj_flt;
|
|
|
|
unsigned long cmaj_flt;
|
|
|
|
unsigned long utime;
|
|
|
|
unsigned long stime;
|
|
|
|
long cutime;
|
|
|
|
long cstime;
|
|
|
|
long priority;
|
|
|
|
long nice;
|
|
|
|
int num_threads;
|
|
|
|
int zero0;
|
|
|
|
unsigned long long start_time;
|
|
|
|
unsigned long vsize;
|
|
|
|
long mm_rss;
|
|
|
|
unsigned long rsslim;
|
|
|
|
unsigned long start_code;
|
|
|
|
unsigned long end_code;
|
|
|
|
unsigned long start_stack;
|
|
|
|
unsigned long esp;
|
|
|
|
unsigned long eip;
|
|
|
|
unsigned long sig_pending;
|
|
|
|
unsigned long sig_blocked;
|
|
|
|
unsigned long sig_ignored;
|
|
|
|
unsigned long sig_handled;
|
|
|
|
unsigned long wchan;
|
|
|
|
unsigned long zero1;
|
|
|
|
unsigned long zero2;
|
|
|
|
int exit_signal;
|
|
|
|
int task_cpu;
|
|
|
|
unsigned int rt_priority;
|
|
|
|
unsigned int policy;
|
|
|
|
unsigned long long delayacct_blkio_ticks;
|
|
|
|
unsigned long gtime;
|
|
|
|
long cgtime;
|
|
|
|
unsigned long start_data;
|
|
|
|
unsigned long end_data;
|
|
|
|
unsigned long start_brk;
|
2012-01-23 15:18:31 +04:00
|
|
|
unsigned long arg_start;
|
|
|
|
unsigned long arg_end;
|
|
|
|
unsigned long env_start;
|
|
|
|
unsigned long env_end;
|
2012-01-22 20:22:40 +04:00
|
|
|
int exit_code;
|
2012-01-13 20:54:08 +04:00
|
|
|
};
|
|
|
|
|
2012-01-27 21:37:13 +04:00
|
|
|
#define PROC_CAP_SIZE 2
|
|
|
|
|
|
|
|
struct proc_status_creds {
|
|
|
|
unsigned int uids[4];
|
|
|
|
unsigned int gids[4];
|
|
|
|
|
2013-12-12 10:03:07 +04:00
|
|
|
u32 cap_inh[PROC_CAP_SIZE];
|
|
|
|
u32 cap_prm[PROC_CAP_SIZE];
|
|
|
|
u32 cap_eff[PROC_CAP_SIZE];
|
|
|
|
u32 cap_bnd[PROC_CAP_SIZE];
|
2014-11-01 01:02:23 +03:00
|
|
|
|
|
|
|
char state;
|
|
|
|
int ppid;
|
2015-06-18 11:59:16 -06:00
|
|
|
|
|
|
|
int seccomp_mode;
|
2012-01-27 21:37:13 +04:00
|
|
|
};
|
|
|
|
|
2015-06-18 11:59:19 -06:00
|
|
|
bool proc_status_creds_eq(struct proc_status_creds *o1, struct proc_status_creds *o2);
|
|
|
|
|
2012-08-09 16:27:30 +04:00
|
|
|
struct fstype {
|
|
|
|
char *name;
|
2013-12-04 19:51:10 +04:00
|
|
|
int code;
|
2012-08-09 16:27:30 +04:00
|
|
|
int (*dump)(struct mount_info *pm);
|
|
|
|
int (*restore)(struct mount_info *pm);
|
2013-12-04 19:51:25 +04:00
|
|
|
int (*parse)(struct mount_info *pm);
|
2012-08-09 16:27:30 +04:00
|
|
|
};
|
|
|
|
|
2013-03-01 20:11:51 +04:00
|
|
|
struct vm_area_list;
|
|
|
|
|
2015-04-02 21:00:45 +02:00
|
|
|
extern bool add_skip_mount(const char *mountpoint);
|
2015-03-31 18:24:14 +02:00
|
|
|
extern struct mount_info *parse_mountinfo(pid_t pid, struct ns_id *nsid, bool for_dump);
|
2012-02-17 01:39:36 +04:00
|
|
|
extern int parse_pid_stat(pid_t pid, struct proc_pid_stat *s);
|
2014-12-19 15:57:00 +03:00
|
|
|
extern int parse_smaps(pid_t pid, struct vm_area_list *vma_area_list);
|
2014-02-07 13:32:21 +04:00
|
|
|
extern int parse_self_maps_lite(struct vm_area_list *vms);
|
2012-02-17 01:39:36 +04:00
|
|
|
extern int parse_pid_status(pid_t pid, struct proc_status_creds *);
|
2012-01-14 01:48:29 +04:00
|
|
|
|
2014-08-25 23:19:54 +04:00
|
|
|
struct inotify_wd_entry {
|
|
|
|
InotifyWdEntry e;
|
|
|
|
FhEntry f_handle;
|
|
|
|
struct list_head node;
|
|
|
|
};
|
|
|
|
|
2014-08-25 23:19:56 +04:00
|
|
|
struct fanotify_mark_entry {
|
|
|
|
FanotifyMarkEntry e;
|
|
|
|
FhEntry f_handle;
|
|
|
|
struct list_head node;
|
|
|
|
union {
|
|
|
|
FanotifyInodeMarkEntry ie;
|
|
|
|
FanotifyMountMarkEntry me;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2014-08-25 23:19:58 +04:00
|
|
|
struct eventpoll_tfd_entry {
|
|
|
|
EventpollTfdEntry e;
|
|
|
|
struct list_head node;
|
|
|
|
};
|
|
|
|
|
2012-07-11 09:22:38 +04:00
|
|
|
union fdinfo_entries {
|
2012-07-17 07:24:54 +04:00
|
|
|
EventfdFileEntry efd;
|
2012-08-02 12:25:18 +04:00
|
|
|
SignalfdEntry sfd;
|
2014-08-25 23:19:54 +04:00
|
|
|
struct inotify_wd_entry ify;
|
2014-08-25 23:19:56 +04:00
|
|
|
struct fanotify_mark_entry ffy;
|
2014-08-25 23:19:58 +04:00
|
|
|
struct eventpoll_tfd_entry epl;
|
2014-06-30 21:58:05 +04:00
|
|
|
TimerfdEntry tfy;
|
2012-07-11 09:22:38 +04:00
|
|
|
};
|
|
|
|
|
2014-08-25 23:19:54 +04:00
|
|
|
extern void free_inotify_wd_entry(union fdinfo_entries *e);
|
2014-08-25 23:19:56 +04:00
|
|
|
extern void free_fanotify_mark_entry(union fdinfo_entries *e);
|
2014-08-25 23:19:58 +04:00
|
|
|
extern void free_event_poll_entry(union fdinfo_entries *e);
|
2014-08-25 23:19:54 +04:00
|
|
|
|
2014-04-09 03:34:53 +04:00
|
|
|
struct fdinfo_common {
|
|
|
|
off64_t pos;
|
|
|
|
int flags;
|
2014-04-09 03:34:54 +04:00
|
|
|
int mnt_id;
|
2015-04-24 14:49:15 +03:00
|
|
|
int owner;
|
2014-04-09 03:34:53 +04:00
|
|
|
};
|
|
|
|
|
2012-07-11 09:22:38 +04:00
|
|
|
extern int parse_fdinfo(int fd, int type,
|
|
|
|
int (*cb)(union fdinfo_entries *e, void *arg), void *arg);
|
2014-01-30 13:41:53 +04:00
|
|
|
extern int parse_fdinfo_pid(int pid, int fd, int type,
|
|
|
|
int (*cb)(union fdinfo_entries *e, void *arg), void *arg);
|
2013-01-17 16:09:32 +08:00
|
|
|
extern int parse_file_locks(void);
|
2014-09-23 20:32:00 +04:00
|
|
|
extern int get_fd_mntid(int fd, int *mnt_id);
|
2012-07-11 09:22:38 +04:00
|
|
|
|
2013-09-23 14:33:30 +04:00
|
|
|
struct pid;
|
|
|
|
extern int parse_threads(int pid, struct pid **_t, int *_n);
|
|
|
|
|
2014-04-21 18:23:49 +04:00
|
|
|
extern int check_mnt_id(void);
|
|
|
|
|
2014-05-08 16:30:30 +04:00
|
|
|
/*
|
|
|
|
* This struct describes a group controlled by one controller.
|
|
|
|
* The @name is the controller name or 'name=...' for named cgroups.
|
|
|
|
* The @path is the path from the hierarchy root.
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct cg_ctl {
|
|
|
|
struct list_head l;
|
|
|
|
char *name;
|
|
|
|
char *path;
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Returns the list of cg_ctl-s sorted by name
|
|
|
|
*/
|
|
|
|
|
|
|
|
extern int parse_task_cgroup(int pid, struct list_head *l, unsigned int *n);
|
|
|
|
extern void put_ctls(struct list_head *);
|
|
|
|
|
2014-07-10 17:00:28 +04:00
|
|
|
int parse_cgroups(struct list_head *cgroups, unsigned int *n_cgroups);
|
|
|
|
|
2014-08-19 22:31:07 -07:00
|
|
|
/* callback for AUFS support */
|
|
|
|
extern int aufs_parse(struct mount_info *mi);
|
|
|
|
|
2015-07-24 21:15:28 +00:00
|
|
|
/* callback for OverlayFS support */
|
|
|
|
extern int overlayfs_parse(struct mount_info *mi);
|
|
|
|
|
2015-08-06 12:37:26 +03:00
|
|
|
int parse_children(pid_t pid, pid_t **_c, int *_n);
|
|
|
|
|
2012-12-25 22:40:24 +04:00
|
|
|
#endif /* __CR_PROC_PARSE_H__ */
|