net/fec: cleanup types in fec_get_mac()
My static checker complains that on some arches unsigned longs can be 8 characters which is larger than the buffer is only 6 chars. Additionally, Ben Hutchings points out that the buffer actually holds big endian data and the buffer we are reading from is CPU endian. Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Reviewed-by: Ben Hutchings <bhutchings@solarflare.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f91b29f5b8
commit
7d7628f371
@ -1099,10 +1099,10 @@ static void fec_get_mac(struct net_device *ndev)
|
|||||||
* 4) FEC mac registers set by bootloader
|
* 4) FEC mac registers set by bootloader
|
||||||
*/
|
*/
|
||||||
if (!is_valid_ether_addr(iap)) {
|
if (!is_valid_ether_addr(iap)) {
|
||||||
*((unsigned long *) &tmpaddr[0]) =
|
*((__be32 *) &tmpaddr[0]) =
|
||||||
be32_to_cpu(readl(fep->hwp + FEC_ADDR_LOW));
|
cpu_to_be32(readl(fep->hwp + FEC_ADDR_LOW));
|
||||||
*((unsigned short *) &tmpaddr[4]) =
|
*((__be16 *) &tmpaddr[4]) =
|
||||||
be16_to_cpu(readl(fep->hwp + FEC_ADDR_HIGH) >> 16);
|
cpu_to_be16(readl(fep->hwp + FEC_ADDR_HIGH) >> 16);
|
||||||
iap = &tmpaddr[0];
|
iap = &tmpaddr[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user