Page MenuHomeFreeBSD

mvneta: Fix 64-bit MIB reads
ClosedPublic

Authored by markj on Dec 31 2020, 6:54 PM.
Tags
None
Referenced Files
F108340185: D27870.diff
Fri, Jan 24, 12:24 AM
Unknown Object (File)
Sat, Jan 18, 5:44 PM
Unknown Object (File)
Sat, Jan 18, 5:13 PM
Unknown Object (File)
Sat, Jan 18, 4:05 AM
Unknown Object (File)
Dec 9 2024, 2:18 PM
Unknown Object (File)
Dec 1 2024, 5:03 PM
Unknown Object (File)
Nov 25 2024, 7:20 AM
Unknown Object (File)
Nov 2 2024, 10:57 PM
Subscribers

Details

Summary

It appears we must read them as 2 4-byte words, lower address first.
Otherwise both reads return the same value, resulting in bogus byte
counter values.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 35845
Build 32734: arc lint + arc unit

Event Timeline

markj requested review of this revision.Dec 31 2020, 6:54 PM
mw requested changes to this revision.Dec 31 2020, 11:50 PM
mw added inline comments.
sys/dev/neta/if_mvneta.c
1193

Please replace the for loop with mvneta_clear_mib()

This revision now requires changes to proceed.Dec 31 2020, 11:50 PM
markj marked an inline comment as done.

Use mvneta_clear_mib().

mw requested changes to this revision.Jan 2 2021, 7:39 AM
mw added inline comments.
sys/dev/neta/if_mvneta.c
3540

Sorry for not spotting this before - val is unitialized, so we need to make sure, the upper half of it is not a random data. Please add:

val = 0;

Otherwise LGTM.

This revision now requires changes to proceed.Jan 2 2021, 7:39 AM
sys/dev/neta/if_mvneta.c
3540

I don't follow. We assign val = MVNETA_READ_MIB(sc, mib->regnum) a couple of lines below. The right-hand side of that statement will be promoted to a 64-bit value before the assignment.

mw added inline comments.
sys/dev/neta/if_mvneta.c
3540

You are right.

This revision is now accepted and ready to land.Jan 4 2021, 1:19 AM
This revision was automatically updated to reflect the committed changes.