forked from luck/tmp_suning_uos_patched
net: openvswitch: use u64 for meter bucket
When setting the meter rate to 4+Gbps, there is an overflow, the meters don't work as expected. Cc: Pravin B Shelar <pshelar@ovn.org> Cc: Andy Zhou <azhou@ovn.org> Signed-off-by: Tonghao Zhang <xiangxia.m.yue@gmail.com> Acked-by: Pravin B Shelar <pshelar@ovn.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
c773500890
commit
e57358873b
|
@ -392,7 +392,7 @@ static struct dp_meter *dp_meter_create(struct nlattr **a)
|
|||
*
|
||||
* Start with a full bucket.
|
||||
*/
|
||||
band->bucket = (band->burst_size + band->rate) * 1000;
|
||||
band->bucket = (band->burst_size + band->rate) * 1000ULL;
|
||||
band_max_delta_t = band->bucket / band->rate;
|
||||
if (band_max_delta_t > meter->max_delta_t)
|
||||
meter->max_delta_t = band_max_delta_t;
|
||||
|
|
|
@ -26,7 +26,7 @@ struct dp_meter_band {
|
|||
u32 type;
|
||||
u32 rate;
|
||||
u32 burst_size;
|
||||
u32 bucket; /* 1/1000 packets, or in bits */
|
||||
u64 bucket; /* 1/1000 packets, or in bits */
|
||||
struct ovs_flow_stats stats;
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user