mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-08-28 03:40:04 +00:00
50dc9a8572
The only factor differentiating per-CPU bstats data type (struct gnet_stats_basic_cpu) from the packed non-per-CPU one (struct gnet_stats_basic_packed) was a u64_stats sync point inside the former. The two data types are now equivalent: earlier commits added a u64_stats sync point to the latter. Combine both data types into "struct gnet_stats_basic_sync". This eliminates redundancy and simplifies the bstats read/write APIs. Use u64_stats_t for bstats "packets" and "bytes" data types. On 64-bit architectures, u64_stats sync points do not use sequence counter protection. Signed-off-by: Ahmed S. Darwish <a.darwish@linutronix.de> Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Signed-off-by: David S. Miller <davem@davemloft.net>
27 lines
717 B
C
27 lines
717 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _XT_RATEEST_H
|
|
#define _XT_RATEEST_H
|
|
|
|
#include <net/gen_stats.h>
|
|
|
|
struct xt_rateest {
|
|
/* keep lock and bstats on same cache line to speedup xt_rateest_tg() */
|
|
struct gnet_stats_basic_sync bstats;
|
|
spinlock_t lock;
|
|
|
|
|
|
/* following fields not accessed in hot path */
|
|
unsigned int refcnt;
|
|
struct hlist_node list;
|
|
char name[IFNAMSIZ];
|
|
struct gnet_estimator params;
|
|
struct rcu_head rcu;
|
|
|
|
/* keep this field far away to speedup xt_rateest_mt() */
|
|
struct net_rate_estimator __rcu *rate_est;
|
|
};
|
|
|
|
struct xt_rateest *xt_rateest_lookup(struct net *net, const char *name);
|
|
void xt_rateest_put(struct net *net, struct xt_rateest *est);
|
|
|
|
#endif /* _XT_RATEEST_H */
|