[PATCH 2/2] ARM: mxs: TX28: Setup MAC addresses for both FEC MACs from OTP fuses.
Lothar Waßmann
LW at KARO-electronics.de
Tue Mar 22 10:35:21 EDT 2011
Hi,
Shawn Guo writes:
> On Mon, Mar 21, 2011 at 05:48:06PM +0100, Lothar Waßmann wrote:
> > Signed-off-by: Lothar Waßmann <LW at KARO-electronics.de>
> > ---
> > arch/arm/mach-mxs/module-tx28.c | 39 +++++++++++++++++++++++++++++++++++++++
> > 1 files changed, 39 insertions(+), 0 deletions(-)
> >
> > diff --git a/arch/arm/mach-mxs/module-tx28.c b/arch/arm/mach-mxs/module-tx28.c
> > index 7d44936..7a9e7b6 100644
> > --- a/arch/arm/mach-mxs/module-tx28.c
> > +++ b/arch/arm/mach-mxs/module-tx28.c
> > @@ -74,6 +74,43 @@ static struct fec_platform_data tx28_fec1_data = {
> > .phy = PHY_INTERFACE_MODE_RMII,
> > };
> >
> > +#define HW_OCOTP_CUST0 0x20
> > +#define HW_OCOTP_CUST(n) (HW_OCOTP_CUST0 + (n) * 0x10)
> > +#define HW_OCOTP_CTRL 0x00
> > +#define HW_OCOTP_CTRL_SET (HW_OCOTP_CTRL + 4)
> > +#define HW_OCOTP_CTRL_CLR (HW_OCOTP_CTRL + 8)
> > +
> > +#define BM_OCOTP_CTRL_BUSY (1 << 8)
> > +#define BM_OCOTP_CTRL_RD_BANK_OPEN (1 << 12)
> > +
> > +static int __init tx28_set_mac(int id, unsigned char mac[])
> > +{
> > + int i;
> > + void __iomem *ocotp_base = ioremap(MX28_OCOTP_BASE_ADDR, SZ_4K);
> > + u32 reg = 0;
> > + long timeout = 1000;
> > +
> > + if (ocotp_base == NULL)
> > + return -ENOMEM;
> > +
> > + /* set this bit to open the OTP banks for reading */
> > + writel(BM_OCOTP_CTRL_RD_BANK_OPEN, ocotp_base + HW_OCOTP_CTRL_SET);
> > +
> > + while (readl(ocotp_base + HW_OCOTP_CTRL) & BM_OCOTP_CTRL_BUSY) {
> > + if (timeout-- < 0)
> > + return -ETIMEDOUT;
> > + udelay(100);
> > + }
> > +
> > + for (i = 0; i < ETH_ALEN; i++) {
> > + if (i % 4 == 0)
> > + reg = readl(ocotp_base + HW_OCOTP_CUST(id * 2 + i / 4));
> > + mac[i] = reg >> (24 - ((i % 4) * 8));
> > + }
> > + iounmap(ocotp_base);
> > + return 0;
> > +}
> > +
>
> Why don't you use mxs_get_ocotp() to read otp?
>
Good question... I'll change it.
Lothar Waßmann
--
___________________________________________________________
Ka-Ro electronics GmbH | Pascalstraße 22 | D - 52076 Aachen
Phone: +49 2408 1402-0 | Fax: +49 2408 1402-10
Geschäftsführer: Matthias Kaussen
Handelsregistereintrag: Amtsgericht Aachen, HRB 4996
www.karo-electronics.de | info at karo-electronics.de
___________________________________________________________
More information about the linux-arm-kernel
mailing list