Commit | Line | Data |
---|---|---|
35a8230b TJ |
1 | #ifndef _IPT_ACCOUNT_H |
2 | #define _IPT_ACCOUNT_H | |
3 | ||
3e722f3c | 4 | #define ACCOUNT_MAX_TABLES 32 |
35a8230b | 5 | #define ACCOUNT_TABLE_NAME_LEN 32 |
3e722f3c | 6 | #define ACCOUNT_MAX_HANDLES 10 |
35a8230b | 7 | |
3e722f3c | 8 | /* Structure for the userspace part of ipt_ACCOUNT */ |
35a8230b TJ |
9 | struct ipt_account_info { |
10 | u_int32_t net_ip; | |
11 | u_int32_t net_mask; | |
12 | char table_name[ACCOUNT_TABLE_NAME_LEN]; | |
13 | int32_t table_nr; | |
14 | }; | |
15 | ||
3e722f3c TJ |
16 | /* Internal table structure, generated by check_entry() */ |
17 | struct ipt_account_table | |
18 | { | |
19 | char name[ACCOUNT_TABLE_NAME_LEN]; /* name of the table */ | |
70288420 TJ |
20 | unsigned int ip; /* base IP of network */ |
21 | unsigned int netmask; /* netmask of the network */ | |
bea3921b | 22 | unsigned char depth; /* size of network: 0: 8 bit, 1: 16bit, 2: 24 bit */ |
3e722f3c TJ |
23 | unsigned int refcount; /* refcount of this table. if zero, destroy it */ |
24 | unsigned int itemcount; /* number of IPs in this table */ | |
25 | void *data; /* pointer to the actual data, depending on netmask */ | |
26 | }; | |
27 | ||
bea3921b | 28 | /* Internal handle structure */ |
3e722f3c TJ |
29 | struct ipt_account_handle |
30 | { | |
bea3921b TJ |
31 | unsigned int ip; /* base IP of network. Used for caculating the final IP during get_data() */ |
32 | unsigned char depth; /* size of network. See above for details */ | |
3e722f3c | 33 | unsigned int itemcount; /* number of IPs in this table */ |
bea3921b TJ |
34 | void *data; /* pointer to the actual data, depending on size */ |
35 | }; | |
36 | ||
37 | /* Handle structure for communication with the userspace library */ | |
38 | struct ipt_account_handle_sockopt | |
39 | { | |
40 | unsigned int handle_nr; /* Used for HANDLE_FREE */ | |
41 | char name[ACCOUNT_TABLE_NAME_LEN]; /* Used for HANDLE_PREPARE_READ/READ_FLUSH */ | |
42 | unsigned int itemcount; /* Used for HANDLE_PREPARE_READ/READ_FLUSH */ | |
3e722f3c TJ |
43 | }; |
44 | ||
45 | /* Used for every IP entry */ | |
46 | /* Size is 16 bytes so that 256 (class C network) * 16 fits in one kernel (zero) page */ | |
47 | struct ipt_account_ip | |
48 | { | |
49 | unsigned int src_packets; | |
50 | unsigned int src_bytes; | |
51 | unsigned int dst_packets; | |
52 | unsigned int dst_bytes; | |
53 | }; | |
54 | ||
55 | /* | |
56 | Used for every IP when returning data | |
57 | */ | |
58 | struct ipt_account_handle_ip | |
59 | { | |
60 | unsigned int ip; | |
61 | unsigned int src_packets; | |
62 | unsigned int src_bytes; | |
63 | unsigned int dst_packets; | |
64 | unsigned int dst_bytes; | |
65 | }; | |
66 | ||
67 | /* | |
68 | The IPs are organized as an array so that direct slot | |
69 | calculations are possible. | |
70 | Only 8 bit networks are preallocated, 16/24 bit networks | |
71 | allocate their slots when needed -> very efficent. | |
72 | */ | |
73 | struct ipt_account_mask_24 | |
74 | { | |
75 | struct ipt_account_ip ip[256]; | |
76 | }; | |
77 | ||
e5da6d22 | 78 | struct ipt_account_mask_16 |
3e722f3c TJ |
79 | { |
80 | struct ipt_account_mask_24 *mask_24[256]; | |
81 | }; | |
82 | ||
83 | struct ipt_account_mask_8 | |
84 | { | |
85 | struct ipt_account_mask_16 *mask_16[256]; | |
86 | }; | |
87 | ||
35a8230b | 88 | #endif /*_IPT_ACCOUNT_H*/ |