Skip to content

Commit 44a13a5

Browse files
aneftinanguy11
authored andcommitted
e1000e: Fix the max snoop/no-snoop latency for 10M
We should decode the latency and the max_latency before directly compare. The latency should be presented as lat_enc = scale x value: lat_enc_d = (lat_enc & 0x0x3ff) x (1U << (5*((max_ltr_enc & 0x1c00) >> 10))) Fixes: cf8fb73 ("e1000e: add support for LTR on I217/I218") Suggested-by: Yee Li <[email protected]> Signed-off-by: Sasha Neftin <[email protected]> Tested-by: Dvora Fuxbrumer <[email protected]> Signed-off-by: Tony Nguyen <[email protected]>
1 parent 691bd4d commit 44a13a5

File tree

2 files changed

+16
-1
lines changed

2 files changed

+16
-1
lines changed

drivers/net/ethernet/intel/e1000e/ich8lan.c

Lines changed: 13 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1006,6 +1006,8 @@ static s32 e1000_platform_pm_pch_lpt(struct e1000_hw *hw, bool link)
10061006
{
10071007
u32 reg = link << (E1000_LTRV_REQ_SHIFT + E1000_LTRV_NOSNOOP_SHIFT) |
10081008
link << E1000_LTRV_REQ_SHIFT | E1000_LTRV_SEND;
1009+
u16 max_ltr_enc_d = 0; /* maximum LTR decoded by platform */
1010+
u16 lat_enc_d = 0; /* latency decoded */
10091011
u16 lat_enc = 0; /* latency encoded */
10101012

10111013
if (link) {
@@ -1059,7 +1061,17 @@ static s32 e1000_platform_pm_pch_lpt(struct e1000_hw *hw, bool link)
10591061
E1000_PCI_LTR_CAP_LPT + 2, &max_nosnoop);
10601062
max_ltr_enc = max_t(u16, max_snoop, max_nosnoop);
10611063

1062-
if (lat_enc > max_ltr_enc)
1064+
lat_enc_d = (lat_enc & E1000_LTRV_VALUE_MASK) *
1065+
(1U << (E1000_LTRV_SCALE_FACTOR *
1066+
((lat_enc & E1000_LTRV_SCALE_MASK)
1067+
>> E1000_LTRV_SCALE_SHIFT)));
1068+
1069+
max_ltr_enc_d = (max_ltr_enc & E1000_LTRV_VALUE_MASK) *
1070+
(1U << (E1000_LTRV_SCALE_FACTOR *
1071+
((max_ltr_enc & E1000_LTRV_SCALE_MASK)
1072+
>> E1000_LTRV_SCALE_SHIFT)));
1073+
1074+
if (lat_enc_d > max_ltr_enc_d)
10631075
lat_enc = max_ltr_enc;
10641076
}
10651077

drivers/net/ethernet/intel/e1000e/ich8lan.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -274,8 +274,11 @@
274274

275275
/* Latency Tolerance Reporting */
276276
#define E1000_LTRV 0x000F8
277+
#define E1000_LTRV_VALUE_MASK 0x000003FF
277278
#define E1000_LTRV_SCALE_MAX 5
278279
#define E1000_LTRV_SCALE_FACTOR 5
280+
#define E1000_LTRV_SCALE_SHIFT 10
281+
#define E1000_LTRV_SCALE_MASK 0x00001C00
279282
#define E1000_LTRV_REQ_SHIFT 15
280283
#define E1000_LTRV_NOSNOOP_SHIFT 16
281284
#define E1000_LTRV_SEND (1 << 30)

0 commit comments

Comments
 (0)