Page MenuHomeFreeBSD

mvneta: Fix 64-bit MIB reads
ClosedPublic

Authored by markj on Dec 31 2020, 6:54 PM.
Tags
None
Referenced Files
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
Unknown Object (File)
Oct 17 2024, 1:43 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
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

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.