162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (c) 2017 Nicira, Inc. 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#ifndef METER_H 762306a36Sopenharmony_ci#define METER_H 1 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#include <linux/init.h> 1062306a36Sopenharmony_ci#include <linux/module.h> 1162306a36Sopenharmony_ci#include <linux/kernel.h> 1262306a36Sopenharmony_ci#include <linux/netlink.h> 1362306a36Sopenharmony_ci#include <linux/openvswitch.h> 1462306a36Sopenharmony_ci#include <linux/genetlink.h> 1562306a36Sopenharmony_ci#include <linux/skbuff.h> 1662306a36Sopenharmony_ci#include <linux/bits.h> 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci#include "flow.h" 1962306a36Sopenharmony_cistruct datapath; 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci#define DP_MAX_BANDS 1 2262306a36Sopenharmony_ci#define DP_METER_ARRAY_SIZE_MIN BIT_ULL(10) 2362306a36Sopenharmony_ci#define DP_METER_NUM_MAX (200000UL) 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_cistruct dp_meter_band { 2662306a36Sopenharmony_ci u32 type; 2762306a36Sopenharmony_ci u32 rate; 2862306a36Sopenharmony_ci u32 burst_size; 2962306a36Sopenharmony_ci u64 bucket; /* 1/1000 packets, or in bits */ 3062306a36Sopenharmony_ci struct ovs_flow_stats stats; 3162306a36Sopenharmony_ci}; 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_cistruct dp_meter { 3462306a36Sopenharmony_ci spinlock_t lock; /* Per meter lock */ 3562306a36Sopenharmony_ci struct rcu_head rcu; 3662306a36Sopenharmony_ci u32 id; 3762306a36Sopenharmony_ci u16 kbps:1, keep_stats:1; 3862306a36Sopenharmony_ci u16 n_bands; 3962306a36Sopenharmony_ci u32 max_delta_t; 4062306a36Sopenharmony_ci u64 used; 4162306a36Sopenharmony_ci struct ovs_flow_stats stats; 4262306a36Sopenharmony_ci struct dp_meter_band bands[]; 4362306a36Sopenharmony_ci}; 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_cistruct dp_meter_instance { 4662306a36Sopenharmony_ci struct rcu_head rcu; 4762306a36Sopenharmony_ci u32 n_meters; 4862306a36Sopenharmony_ci struct dp_meter __rcu *dp_meters[]; 4962306a36Sopenharmony_ci}; 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_cistruct dp_meter_table { 5262306a36Sopenharmony_ci struct dp_meter_instance __rcu *ti; 5362306a36Sopenharmony_ci u32 count; 5462306a36Sopenharmony_ci u32 max_meters_allowed; 5562306a36Sopenharmony_ci}; 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ciextern struct genl_family dp_meter_genl_family; 5862306a36Sopenharmony_ciint ovs_meters_init(struct datapath *dp); 5962306a36Sopenharmony_civoid ovs_meters_exit(struct datapath *dp); 6062306a36Sopenharmony_cibool ovs_meter_execute(struct datapath *dp, struct sk_buff *skb, 6162306a36Sopenharmony_ci struct sw_flow_key *key, u32 meter_id); 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci#endif /* meter.h */ 64