u-boot/board/cm_t35/eeprom.c
Nikita Kiryanov e4e2bf5e4c cm-t35: use the new EEPROM module to read the MAC address
Switch to the new EEPROM module and fix the problem of MAC address
being read from the wrong offset due to lack of distinction between
EEPROM layouts.

Signed-off-by: Nikita Kiryanov <nikita@compulab.co.il>
Signed-off-by: Igor Grinberg <grinberg@compulab.co.il>
2012-01-16 08:40:11 +01:00

124 lines
2.9 KiB
C

/*
* (C) Copyright 2011 CompuLab, Ltd. <www.compulab.co.il>
*
* Authors: Nikita Kiryanov <nikita@compulab.co.il>
* Igor Grinberg <grinberg@compulab.co.il>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of
* the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc.
*/
#include <common.h>
#include <i2c.h>
#define EEPROM_LAYOUT_VER_OFFSET 44
#define BOARD_SERIAL_OFFSET 20
#define BOARD_SERIAL_OFFSET_LEGACY 8
#define BOARD_REV_OFFSET 0
#define BOARD_REV_OFFSET_LEGACY 6
#define BOARD_REV_SIZE 4
#define BOARD_REV_SIZE_LEGACY 2
#define MAC_ADDR_OFFSET 4
#define MAC_ADDR_OFFSET_LEGACY 0
#define LAYOUT_INVALID 0
#define LAYOUT_LEGACY 0xff
static int eeprom_layout; /* Implicitly LAYOUT_INVALID */
static int cm_t3x_eeprom_read(uint offset, uchar *buf, int len)
{
return i2c_read(CONFIG_SYS_I2C_EEPROM_ADDR, offset,
CONFIG_SYS_I2C_EEPROM_ADDR_LEN, buf, len);
}
static int eeprom_setup_layout(void)
{
int res;
if (eeprom_layout != LAYOUT_INVALID)
return 0;
res = cm_t3x_eeprom_read(EEPROM_LAYOUT_VER_OFFSET,
(uchar *)&eeprom_layout, 1);
if (res) {
eeprom_layout = LAYOUT_INVALID;
return res;
}
if (eeprom_layout == 0 || eeprom_layout >= 0x20)
eeprom_layout = LAYOUT_LEGACY;
return 0;
}
void get_board_serial(struct tag_serialnr *serialnr)
{
u32 serial[2];
uint offset;
memset(serialnr, 0, sizeof(*serialnr));
if (eeprom_setup_layout())
return;
offset = (eeprom_layout != LAYOUT_LEGACY) ?
BOARD_SERIAL_OFFSET : BOARD_SERIAL_OFFSET_LEGACY;
if (cm_t3x_eeprom_read(offset, (uchar *)serial, 8))
return;
if (serial[0] != 0xffffffff && serial[1] != 0xffffffff) {
serialnr->low = serial[0];
serialnr->high = serial[1];
}
}
/*
* Routine: cm_t3x_eeprom_read_mac_addr
* Description: read mac address and store it in buf.
*/
int cm_t3x_eeprom_read_mac_addr(uchar *buf)
{
uint offset;
if (eeprom_setup_layout())
return 0;
offset = (eeprom_layout != LAYOUT_LEGACY) ?
MAC_ADDR_OFFSET : MAC_ADDR_OFFSET_LEGACY;
return cm_t3x_eeprom_read(offset, buf, 6);
}
/*
* Routine: get_board_rev
* Description: read system revision
*/
u32 get_board_rev(void)
{
u32 rev = 0;
uint offset = BOARD_REV_OFFSET_LEGACY;
int len = BOARD_REV_SIZE_LEGACY;
if (eeprom_setup_layout())
return 0;
if (eeprom_layout != LAYOUT_LEGACY) {
offset = BOARD_REV_OFFSET;
len = BOARD_REV_SIZE;
}
if (cm_t3x_eeprom_read(offset, (uchar *)&rev, len))
return 0;
return rev;
};