-
Notifications
You must be signed in to change notification settings - Fork 3
/
ppm_ringbuffer.h
62 lines (54 loc) · 2.44 KB
/
ppm_ringbuffer.h
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
// SPDX-License-Identifier: GPL-2.0-only OR MIT
/*
Copyright (C) 2023 The Falco Authors.
This file is dual licensed under either the MIT or GPL 2. See MIT.txt
or GPL2.txt for full copies of the license.
*/
#ifndef PPM_RINGBUFFER_H_
#define PPM_RINGBUFFER_H_
#ifdef __KERNEL__
#include <linux/types.h>
#else
#include <stdbool.h>
#include <stdint.h>
#endif
/* This method validates the per-CPU buffer bytes dimension:
* The single buffer dimension must be:
* - greater than `2 * PAGE_SIZE`.
* - a multiple of the system PAGE_SIZE.
* - a power of 2.
*
* Returns true if the buffer has a valid dimension.
*/
static inline bool validate_buffer_bytes_dim(unsigned long buf_bytes_dim, unsigned long page_size)
{
return ((buf_bytes_dim > (2 * page_size)) && ((buf_bytes_dim % page_size) == 0) && ((buf_bytes_dim & (buf_bytes_dim - 1)) == 0));
}
/*
* This gets mapped to user level, so we want to keep it as clean as possible
*/
struct ppm_ring_buffer_info {
volatile uint32_t head;
volatile uint32_t tail;
volatile uint64_t n_evts; /* Total number of events that were received by the driver. */
volatile uint64_t n_drops_buffer; /* Total number of kernel side drops due to full buffer, includes all categories below, likely higher than sum of syscall categories. */
/* Kernel side drops due to full buffer for categories of system calls. Not all system calls of interest are mapped into one of the categories. */
volatile uint64_t n_drops_buffer_clone_fork_enter;
volatile uint64_t n_drops_buffer_clone_fork_exit;
volatile uint64_t n_drops_buffer_execve_enter;
volatile uint64_t n_drops_buffer_execve_exit;
volatile uint64_t n_drops_buffer_connect_enter;
volatile uint64_t n_drops_buffer_connect_exit;
volatile uint64_t n_drops_buffer_open_enter;
volatile uint64_t n_drops_buffer_open_exit;
volatile uint64_t n_drops_buffer_dir_file_enter;
volatile uint64_t n_drops_buffer_dir_file_exit;
volatile uint64_t n_drops_buffer_other_interest_enter; /* Category of other system calls of interest, not all other system calls that did not match a category from above. */
volatile uint64_t n_drops_buffer_other_interest_exit;
volatile uint64_t n_drops_buffer_close_exit;
volatile uint64_t n_drops_buffer_proc_exit;
volatile uint64_t n_drops_pf; /* Number of dropped events (page faults). */
volatile uint64_t n_preemptions; /* Number of preemptions. */
volatile uint64_t n_context_switches; /* Number of received context switch events. */
};
#endif /* PPM_RINGBUFFER_H_ */