仿做的板子,SDRAM测试已通过,但我操作39vf160时居然都得到错误的回码。我按照手册写了最简单测试39vf160厂商ID和芯片ID程序,都返回0xFF,偶心急如焚,特来求助各位高手。
主控芯片为:AT91RM9200
程序片断
#define AT91_FLASH_BASIC 0x10000000
#define CMD_ADDR0 *((volatile INT16U *)(0x5555*2+AT91_FLASH_BASIC))
#define CMD_ADDR1 *((volatile INT16U *)(0x2aaa*2+AT91_FLASH_BASIC))
下面是主函数中的
CMD_ADDR0=0xAA;
CMD_ADDR1=0x55;
CMD_ADDR0=0x90;
for(i=100;i>0;i--);
SST_id1=*(INT16U *)(AT91_FLASH_BASIC);
SST_id2=*(INT16U *)(AT91_FLASH_BASIC+2);
AT91F_DBGU_Printf("SST_ID=0x%x\n\r",SST_id1);
AT91F_DBGU_Printf("39VF160=0x%x\n\r",SST_id1);
最后结果为SST_ID=0xffff
39VF160=0xffff
正确结果应为0xbf , 0x2782,但我就是没办法得到
我一直怀疑地址设置是不是有问题,为什么地址(如0x5555)要乘以2(左移一位)我就想不通,希望高手能预解答。
我的板子上39VF160地址线A0到A19与9200上A0到A19一一对应,我今天又看9200手册,好像要求错开一位接,如9200上A1对应39VF160A0,是不是我这个搞错了,反正我搞糊涂啦。
希望大家能帮我分析一下,花了这么多时间精力做这个板子,如果卡在NORFLASH上就太亏了,小弟先说声谢谢。
我要赚赏金打赏帖 |
|
|---|---|
| OK1126B-S开发板下函数构建及步进电机驱动控制被打赏¥25元 | |
| 【S32K3XX】LPI2C 参数配置说明被打赏¥20元 | |
| OK1126B-S开发板的脚本编程及应用设计被打赏¥27元 | |
| 5v升压8.4v两节锂电池充电芯片,针对同步和异步的IC测试被打赏¥35元 | |
| 【S32K3XX】S32DS LPI2C 配置失败问题解决被打赏¥22元 | |
| 【S32K3XX】FLASH 的 DID 保护机制被打赏¥19元 | |
| OK1126B-S开发板串口通信及其使用被打赏¥18元 | |
| 【S32K3XX】多核 CORE ID 获取被打赏¥18元 | |
| OK1126B-S开发板的GPIO资源及其使用被打赏¥20元 | |
| 【分享开发笔记,赚取电动螺丝刀】三分钟快速上手驱动屏幕(Arduino IDE环境)被打赏¥23元 | |
我要赚赏金
