Re: [PATCH v3 5/7] net: cpsw: Add am33xx MACID readout
From: Steven Rostedt <rostedt@goodmis.org>
Date: 2014-08-18 19:41:12
Also in:
linux-arm-kernel, linux-omap
On Mon, 18 Aug 2014 23:54:26 +0530 Mugunthan V N [off-list ref] wrote:
On Saturday 16 August 2014 08:48 PM, Markus Pargmann wrote:quoted
+ mac_addr[5] = (macid_lo >> 8) & 0xff; + mac_addr[4] = macid_lo & 0xff; + mac_addr[3] = (macid_hi >> 24) & 0xff; + mac_addr[2] = (macid_hi >> 16) & 0xff; + mac_addr[1] = (macid_hi >> 8) & 0xff; + mac_addr[0] = macid_hi & 0xff; +This will fail incase of DRA74x and DRA72x platforms, please check for u-boot src for parsing logic as TRM is not out yet. Below is the actual code for DRA7 platforms for MAC address parsing mac_addr[0] = (mac_hi & 0xFF0000) >> 16; mac_addr[1] = (mac_hi & 0xFF00) >> 8; mac_addr[2] = mac_hi & 0xFF; mac_addr[3] = (mac_lo & 0xFF0000) >> 16; mac_addr[4] = (mac_lo & 0xFF00) >> 8; mac_addr[5] = mac_lo & 0xFF;
But this fails with my beaglebone white. I tested Markus's patches and it came up with the same ethaddr that U-Boot had.
From U-Boot:
ethaddr=d4:94:a1:8b:ec:78
With Markus's changes:
eth0 Link encap:Ethernet HWaddr D4:94:A1:8B:EC:78
But when I changed the code to match what you wrote, I got this:
eth0 Link encap:Ethernet HWaddr CE:5A:8B:0E:44:45
but it also gave me:
cpsw 4a100000.ethernet: Random MACID = ce:5a:8b:0e:44:45
which means it failed the valid mac test.
Here's how I implemented your change:
#if 1
mac_addr[0] = (macid_hi & 0xFF0000) >> 16;
mac_addr[1] = (macid_hi & 0xFF00) >> 8;
mac_addr[2] = macid_hi & 0xFF;
mac_addr[3] = (macid_lo & 0xFF0000) >> 16;
mac_addr[4] = (macid_lo & 0xFF00) >> 8;
mac_addr[5] = macid_lo & 0xFF;
#else
mac_addr[5] = (macid_lo >> 8) & 0xff;
mac_addr[4] = macid_lo & 0xff;
mac_addr[3] = (macid_hi >> 24) & 0xff;
mac_addr[2] = (macid_hi >> 16) & 0xff;
mac_addr[1] = (macid_hi >> 8) & 0xff;
mac_addr[0] = macid_hi & 0xff;
#endif
Just to be consistent, I updated the code as this too:
mac_addr[0] = (macid_hi >> 16) & 0xFF;
mac_addr[1] = (macid_hi >> 8) & 0xFF;
mac_addr[2] = macid_hi & 0xFF;
mac_addr[3] = (macid_lo >> 16) & 0xFF;
mac_addr[4] = (macid_lo >> 8) & 0xFF;
mac_addr[5] = macid_lo & 0xFF;
With the same affect.
Thus, for this patchset, as is:
Tested-by: Steven Rostedt <rostedt@goodmis.org>
-- Steve