fsnotify_groupRegular
4.4: ✅struct fsnotify_group {
atomic_t refcnt;
const struct fsnotify_ops *ops;
struct mutex notification_mutex;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
struct mutex mark_mutex;
atomic_t num_marks;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
4.8: ✅struct fsnotify_group {
atomic_t refcnt;
const struct fsnotify_ops *ops;
struct mutex notification_mutex;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
4.10: ✅struct fsnotify_group {
atomic_t refcnt;
const struct fsnotify_ops *ops;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
4.13: ✅struct fsnotify_group {
atomic_t refcnt;
const struct fsnotify_ops *ops;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
atomic_t user_waits;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
4.15: ✅struct fsnotify_group {
refcount_t refcnt;
const struct fsnotify_ops *ops;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
atomic_t user_waits;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
4.18: ✅struct fsnotify_group {
refcount_t refcnt;
const struct fsnotify_ops *ops;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
atomic_t user_waits;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
5.0: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
5.3: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
5.4: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
5.8: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
5.11: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
5.13: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
5.15: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
5.19: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
int flags;
unsigned int owner_flags;
struct mutex mark_mutex;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
6.2: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
int flags;
unsigned int owner_flags;
struct mutex mark_mutex;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
6.5: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
int flags;
unsigned int owner_flags;
struct mutex mark_mutex;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
6.8: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
int flags;
unsigned int owner_flags;
struct mutex mark_mutex;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
arm64: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
armhf: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
ppc64el: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
riscv64: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
aws: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
azure: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
gcp: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
lowlatency: ✅struct fsnotify_group {
const struct fsnotify_ops *ops;
refcount_t refcnt;
spinlock_t notification_lock;
struct list_head notification_list;
wait_queue_head_t notification_waitq;
unsigned int q_len;
unsigned int max_events;
unsigned int priority;
bool shutdown;
struct mutex mark_mutex;
atomic_t num_marks;
atomic_t user_waits;
struct list_head marks_list;
struct fasync_struct *fsn_fa;
struct fsnotify_event *overflow_event;
struct mem_cgroup *memcg;
void *private;
struct inotify_group_private_data inotify_data;
struct fanotify_group_private_data fanotify_data;
};
Regular
4.4 and 4.8 ⚠️bool shutdown
4.8 and 4.10 ⚠️spinlock_t notification_lock
struct mutex notification_mutex
4.10 and 4.13 ⚠️atomic_t user_waits
4.13 and 4.15 ⚠️atomic_t refcnt ➡️ refcount_t refcnt
4.15 and 4.18 ✅
4.18 and 5.0 ⚠️struct mem_cgroup *memcg
5.0 and 5.3 ✅
5.3 and 5.4 ✅
5.4 and 5.8 ✅
5.8 and 5.11 ✅
5.11 and 5.13 ⚠️atomic_t num_marks
5.13 and 5.15 ✅
5.15 and 5.19 ⚠️int flags
unsigned int owner_flags
5.19 and 6.2 ✅
6.2 and 6.5 ✅
6.5 and 6.8 ✅
amd64 and arm64 ✅
amd64 and armhf ✅
amd64 and ppc64el ✅
amd64 and riscv64 ✅
generic and aws ✅
generic and azure ✅
generic and gcp ✅
generic and lowlatency ✅