初级会员

- 积分
- 135
- 金钱
- 135
- 注册时间
- 2012-8-17
- 在线时间
- 0 小时
|

楼主 |
发表于 2013-5-6 10:36:34
|
显示全部楼层
回复【2楼】正点原子:
---------------------------------
我是参照您的程序修改的,还请麻烦您给看一下,我感觉是没问题的,谢谢!!
//寄存器清零
//bank1有NE1~4,每一个有一个BCR+TCR,所以总共八个寄存器。
//这里我们使用NE1 ,也就对应BTCR[0],[1]。
FSMC_Bank1->BTCR[0]=0X00000000;
FSMC_Bank1->BTCR[1]=0X00000000;
FSMC_Bank1E->BWTR[0]=0X00000000;
//操作BCR寄存器 使用异步模式
FSMC_Bank1->BTCR[0]|=1<<12; //存储器写使能
FSMC_Bank1->BTCR[0]|=1<<14; //读写使用不同的时序
FSMC_Bank1->BTCR[0]|=1<<4; //存储器数据宽度为16bit
//操作BTR寄存器
//读时序控制寄存器
FSMC_Bank1->BTCR[1]|=0<<28; //模式A FSMC_Bank1->BTCR[1]|=1<<0; //地址建立时间(ADDSET)为2个HCLK 1/36M=27ns FSMC_Bank1->BTCR[1]|=0XF<<8; //数据保存时间为16个HCLK
//写时序控制寄存器
FSMC_Bank1E->BWTR[0]|=0<<28; //模式A
FSMC_Bank1E->BWTR[0]|=0<<0; //地址建立时间(ADDSET)为1个HCLK
FSMC_Bank1E->BWTR[0]|=3<<8; //数据保存时间为4个HCLK
FSMC_Bank1->BTCR[0]|=1<<0; //使能BANK1,区域1 |
|