Commit 4f8a91ad authored by John Fastabend's avatar John Fastabend Committed by Jeff Kirsher

ixgbe: align flow control DV macros with datasheet

The flow control DV macros are used to calculate the flow control
high and low thresholds. This patch annotates these macros slightly
better and fixes the issues below.

The macro variables are renamed LINK to _max_frame_link and TC to
_max_frame_tc. This was to avoid confusion and make them more
readable. It was found that people auditing the code read TC to be
'traffic class' in the 802.1Q definition instead of the max frame
size of the tc. Hopefully it is clear now.

This audit also found the following real deviations from the
theoretical values. Fixed in this patch.

  * I multiplied the DV calculations by (36/25) which always
    evaluates to 1. This does not match the intended theoretical
    value of 1.44.

  * IXGBE_BT2KB added 1023 to account for rounding however this
    really should be 8 * 1023 - 1 to account for division by 8k.

  * x2 multiplication of max frame in DV calculations to account
    for updated hardware recommendations.

With this patch the DV values are inline with the recommendations
in the 82599 and 82598 data sheets. Its worth noting I did not
see any dropped frames with flow control on in my experiments without
this patch. However aligning with the hardware specs and
recommendations seems like a good idea here to account for worst
case scenarios.
Signed-off-by: default avatarJohn Fastabend <john.r.fastabend@intel.com>
Tested-by: default avatarRoss Brattain <ross.b.brattain@intel.com>
Signed-off-by: default avatarJeff Kirsher <jeffrey.t.kirsher@intel.com>
parent 185095fb
...@@ -2419,7 +2419,7 @@ typedef u32 ixgbe_physical_layer; ...@@ -2419,7 +2419,7 @@ typedef u32 ixgbe_physical_layer;
*/ */
/* BitTimes (BT) conversion */ /* BitTimes (BT) conversion */
#define IXGBE_BT2KB(BT) ((BT + 1023) / (8 * 1024)) #define IXGBE_BT2KB(BT) ((BT + (8 * 1024 - 1)) / (8 * 1024))
#define IXGBE_B2BT(BT) (BT * 8) #define IXGBE_B2BT(BT) (BT * 8)
/* Calculate Delay to respond to PFC */ /* Calculate Delay to respond to PFC */
...@@ -2450,24 +2450,31 @@ typedef u32 ixgbe_physical_layer; ...@@ -2450,24 +2450,31 @@ typedef u32 ixgbe_physical_layer;
#define IXGBE_PCI_DELAY 10000 #define IXGBE_PCI_DELAY 10000
/* Calculate X540 delay value in bit times */ /* Calculate X540 delay value in bit times */
#define IXGBE_FILL_RATE (36 / 25) #define IXGBE_DV_X540(_max_frame_link, _max_frame_tc) \
((36 * \
#define IXGBE_DV_X540(LINK, TC) (IXGBE_FILL_RATE * \ (IXGBE_B2BT(_max_frame_link) + \
(IXGBE_B2BT(LINK) + IXGBE_PFC_D + \ IXGBE_PFC_D + \
(2 * IXGBE_CABLE_DC) + \ (2 * IXGBE_CABLE_DC) + \
(2 * IXGBE_ID_X540) + \ (2 * IXGBE_ID_X540) + \
IXGBE_HD + IXGBE_B2BT(TC))) IXGBE_HD) / 25 + 1) + \
2 * IXGBE_B2BT(_max_frame_tc))
/* Calculate 82599, 82598 delay value in bit times */ /* Calculate 82599, 82598 delay value in bit times */
#define IXGBE_DV(LINK, TC) (IXGBE_FILL_RATE * \ #define IXGBE_DV(_max_frame_link, _max_frame_tc) \
(IXGBE_B2BT(LINK) + IXGBE_PFC_D + \ ((36 * \
(2 * IXGBE_CABLE_DC) + (2 * IXGBE_ID) + \ (IXGBE_B2BT(_max_frame_link) + \
IXGBE_HD + IXGBE_B2BT(TC))) IXGBE_PFC_D + \
(2 * IXGBE_CABLE_DC) + \
(2 * IXGBE_ID) + \
IXGBE_HD) / 25 + 1) + \
2 * IXGBE_B2BT(_max_frame_tc))
/* Calculate low threshold delay values */ /* Calculate low threshold delay values */
#define IXGBE_LOW_DV_X540(TC) (2 * IXGBE_B2BT(TC) + \ #define IXGBE_LOW_DV_X540(_max_frame_tc) \
(IXGBE_FILL_RATE * IXGBE_PCI_DELAY)) (2 * IXGBE_B2BT(_max_frame_tc) + \
#define IXGBE_LOW_DV(TC) (2 * IXGBE_LOW_DV_X540(TC)) (36 * IXGBE_PCI_DELAY / 25) + 1)
#define IXGBE_LOW_DV(_max_frame_tc) \
(2 * IXGBE_LOW_DV_X540(_max_frame_tc))
/* Software ATR hash keys */ /* Software ATR hash keys */
#define IXGBE_ATR_BUCKET_HASH_KEY 0x3DAD14E2 #define IXGBE_ATR_BUCKET_HASH_KEY 0x3DAD14E2
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment