diff options
| author | Vladimir Oltean <[email protected]> | 2019-12-27 02:59:54 +0200 | 
|---|---|---|
| committer | David S. Miller <[email protected]> | 2019-12-30 20:10:20 -0800 | 
| commit | 9fcf024dd6fae082f05e8c1fcdae23972b2f6971 (patch) | |
| tree | 27c722ec2d1a949526acdc40c91c5871f4df20bb /lib/timerqueue.c | |
| parent | 0caeaf6ad532f9be5a768a158627cb31921cc8b7 (diff) | |
net: dsa: sja1105: Take PTP egress timestamp by port, not mgmt slot
The PTP egress timestamp N must be captured from register PTPEGR_TS[n],
where n = 2 * PORT + TSREG. There are 10 PTPEGR_TS registers, 2 per
port. We are only using TSREG=0.
As opposed to the management slots, which are 4 in number
(SJA1105_NUM_PORTS, minus the CPU port). Any management frame (which
includes PTP frames) can be sent to any non-CPU port through any
management slot. When the CPU port is not the last port (#4), there will
be a mismatch between the slot and the port number.
Luckily, the only mainline occurrence with this switch
(arch/arm/boot/dts/ls1021a-tsn.dts) does have the CPU port as #4, so the
issue did not manifest itself thus far.
Fixes: 47ed985e97f5 ("net: dsa: sja1105: Add logic for TX timestamping")
Signed-off-by: Vladimir Oltean <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'lib/timerqueue.c')
0 files changed, 0 insertions, 0 deletions