|
@@ -41,8 +41,13 @@ static int smx911x_handle_mac_address(bd_t *bd)
|
|
unsigned long addrh, addrl;
|
|
unsigned long addrh, addrl;
|
|
uchar m[6];
|
|
uchar m[6];
|
|
|
|
|
|
- /* if the environment has a valid mac address then use it */
|
|
|
|
- if (!eth_getenv_enetaddr("ethaddr", m)) {
|
|
|
|
|
|
+ if (eth_getenv_enetaddr("ethaddr", m)) {
|
|
|
|
+ /* if the environment has a valid mac address then use it */
|
|
|
|
+ addrl = m[0] | (m[1] << 8) | (m[2] << 16) | (m[3] << 24);
|
|
|
|
+ addrh = m[4] | (m[5] << 8);
|
|
|
|
+ smc911x_set_mac_csr(ADDRL, addrl);
|
|
|
|
+ smc911x_set_mac_csr(ADDRH, addrh);
|
|
|
|
+ } else {
|
|
/* if not, try to get one from the eeprom */
|
|
/* if not, try to get one from the eeprom */
|
|
addrh = smc911x_get_mac_csr(ADDRH);
|
|
addrh = smc911x_get_mac_csr(ADDRH);
|
|
addrl = smc911x_get_mac_csr(ADDRL);
|
|
addrl = smc911x_get_mac_csr(ADDRL);
|