2440 dm9000 到底咋确定地址端口和数据端口

下面是大侠给我的解释:
“DM9000对外来说只有两个端口——地址口和数据口,地址口用于输入内部寄存器的地址,而数据口则完成对某一寄存器的读写。DM9000的CMD引脚用来区分这两个端口,当CMD引脚为0时,DM9000的数据线上传输的是寄存器地址,当CMD引脚为1时,传输的是读写数据。我们把DM9000的AEN接到s3c2440的nGCS4引脚上,则DM9000的端口基址为0x20000300,如果再把DM9000的CMD引脚接到s3c2440的ADDR2引脚上”
 
我们所说的地址:0x20000000 和 0x20000004是由ARM芯片的地址引脚决定的,注意,这个地址表示是用的16进制,那么,0x20000004的每一位的值都可以是0~f,它由ARM的4根地址线的电平高,比如最低的一位,就是由ADDR3~ADDR0 这4个引脚的电平决定,如果 ADDR3~ADDR0 = 1111,则该位为f ,如果LADDR3~LADDR0 = 0100,则该位为 4
因此,如果将DM9000的CMD引脚接到s3c2440的ADDR2,由于CMD引脚的高低电平决定地址口和数据口,那么,ADDR2为0时,访问的就是地址口,所以地址口的起始地址为ARRD2为0的情况,即0x20000000 ;ADDR2为1时,(LADDR3~LADDR0 =0100)访问的就是数据口,所以数据口的地址即 0x20000004。
 
可能这是很基础的知识,但是我不懂,人家不嫌弃咱这么菜,这么详细的跟我讲,真的很感谢!!
如果大家都互帮互助的,多好啊!! 2440 <wbr>dm9000 <wbr>到底咋确定地址

你可能感兴趣的:(2440 dm9000 到底咋确定地址端口和数据端口)