嵌入式爱好者

查看: 6710|回复: 1

OK6410 DM9000 没响应

[复制链接]

2

主题

3

帖子

2

积分

扫一扫,手机访问本帖
发表于 2010-11-24 23:08:51 | 显示全部楼层 |阅读模式
OK6410 板,DM9000的CS脚连接到XM0CSN1 (SROM Bank1 : 0x1800_0000  0x1FFF_FFFF ),CMD连接到ADDR2,所以INDEX口地址应该是0x18000000,DATA口地址应该是0x18000004。现在的问题是读写DM9000没反应,读ID返回0,程序如下:

#define __REG(x)                        (*(volatile unsigned int *)(x))

#define rSROM_BW                __REG(0x70000000)
#define rSROM_BC0                __REG(0x70000004)
#define rSROM_BC1                __REG(0x70000008)
#define rSROM_BC2                __REG(0x7000000C)
#define rSROM_BC3                __REG(0x70000010)
#define rSROM_BC4                __REG(0x70000014)
#define rSROM_BC5                __REG(0x70000018)

#define rGPNCON                __REG(0x7F008830)
#define rGPNDAT                        __REG(0x7F008834)
#define rGPNPUD                        __REG(0x7F008838)

#define rEINT0CON0                __REG(0x7F008900)
#define rEINT0FLTCON0                __REG(0x7F008910)
#define rEINT0MASK                __REG(0x7F008920)
#define rEINT0PEND                __REG(0x7F008924)

#define rVIC0INTENABLE        __REG(0x71200010)
#define rVIC1INTENABLE        __REG(0x71300010)

static void iow(u32 adr, u32 dat)
{
        __REG(0x18000300) = adr;
        __REG(0x18000304) = dat;
}

static u32 ior(u32 adr)
{
        __REG(0x18000300) = adr;
        return (__REG(0x18000304));
}

void DM9000A_Init(void)
{
        u8 rMAC[8];
        u32 id_val;

        Uart_Printf("\r\nS3C6410: DM9000 Init...");
       
        //SROM: Bank1, Not using UB/LB, WAIT disable, 16-bit
        rSROM_BW = (rSROM_BW & 0xFFFFFF0F) | (0<<7) | (0<<6) | (0<<5) | (1<<4) ;
        rSROM_BC1 = (0x2<<28)|(0x4<<24)|(0x6<<16)|(0x4<<12)|(0x2<<8)|(0x6<<4)|(0x0<<0);
       
        //GPIO:GPN,For EINT7
        rGPNCON = (rGPNCON & (~(0x3<<14))) | (0x2 << 14);
        rGPNPUD = rGPNPUD & (~(0x3<<14));
       
        //EINT7 Enable
        rEINT0CON0 = (rEINT0CON0 & (~(0x7 <<12))) | (0x1 << 12); //High Level Interrupt
        rEINT0PEND = rEINT0PEND | (0x01<<7);        //Clear EINT7
        rEINT0MASK = rEINT0MASK & (~(0x1<<7));        //Enable EINT7

        iow(0x1F, 0x00);        //GPR: Power on
               
        iow(0x00, 0x03);        //NCR: Reset
        delay(200000);
        iow(0x00, 0x03);        //
        delay(200000);
       
        iow(0x00, 0x00);        //NCR: Normal Mode
       
        id_val =  ior(DM9000_VIDL);
        id_val |= (ior(DM9000_VIDH) << 8);
        id_val |= (ior(DM9000_PIDL) << 16);
        id_val |= (ior(DM9000_PIDH) << 24);
        Uart_Printf("\r\nS3C6410: DM9000 ID:%d",id_val);
       
        if (id_val != 0x90000A46)
        {
                Uart_Printf("\r\nS3C6410: Warning!!! DM9000 is not working."); //--------------------只能读到0
                return;
        }
       
        iow(0x02, 0x00);        //TCR: TX Polling clear
        iow(0x08, 0x3F);        //BPTR: Less 3Kb, 200us
        iow(0x09, 0x38);        //FCTR: Flow Control : High/Low Water
        iow(0x0A, 0x00);        //FCR: Flow Control
        iow(0x2F, 0x00);        //SMCR: Special Mode
       
        iow(0xFF, 0x80);        //IMR:Enable Pointer Auto Return
       
        iow(0x10, MAC[0]);        //Physical Address Registers
        iow(0x11, MAC[1]);
        iow(0x12, MAC[2]);
        iow(0x13, MAC[3]);
        iow(0x14, MAC[4]);
        iow(0x15, MAC[5]);
       
        rMAC[0] = ior(0x10);
        rMAC[1] = ior(0x11);
        rMAC[2] = ior(0x12);
        rMAC[3] = ior(0x13);
        rMAC[4] = ior(0x14);
        rMAC[5] = ior(0x15);
       
        Uart_Printf("\r\nS3C6410: DM9000 MAC: %02x:%02x:%02x:%02x:%02x:%02x\n",rMAC[0],rMAC[1],rMAC[2],rMAC[3],rMAC[4],rMAC[5]);//--------------------读MAC也返回不对的值
       
        iow(0x16, 0xFF);        //Multicast Address Registers
        iow(0x17, 0xFF);
        iow(0x18, 0xFF);
        iow(0x19, 0xFF);
        iow(0x1A, 0xFF);
        iow(0x1B, 0xFF);
        iow(0x1C, 0xFF);
        iow(0x1D, 0xFF);
       
        iow(0xFE, 0x3F);        //ISR: Clear Interrupt;
        iow(0x01, 0x2D);        //NSR: Clear Interrupt;
       
        //Enable EINT7
        iow(0xFF, 0x83);        //IMR: Enable Rx / Tx Interrupt
        iow(0x05, 0x31);        //RCR: Discard Long Packet  , Discard CRC Error Packet , Enable Rx

        Eth.IO_Width         = (ior( 0xFE ) >> 7 ) & 0x01;

}

GPOCON GPPCON GPQCON 默认已设置为MEM PORT, MEM PORT 的时钟也默认打开了。
怀疑是时序问题 ,HCLK = 133MHz ,照上面的时序应该是没问题的。在官方提供的Linux源码里找到一个时序:
rSROM_BC1 = (0x0<<28)|(0x4<<24)|(0xd<<16)|(0x1<<12)|(0x4<<8)|(0x6<<4)|(0x0<<0);
结果还是一样。。。

我是初学者,现在找不到原因了,或许还漏掉什么东西,请高手帮忙~
回复

使用道具 举报

zj19871002 该用户已被删除
发表于 2010-12-21 14:28:01 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋| 飞凌嵌入式 ( 冀ICP备12004394号-1 )

GMT+8, 2025-1-10 22:08

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表