共2条
1/1 1 跳转至页
dataflash 谁有ATMEL dataflash AT45DB系列的430 SPI程序给偶一个
问
偶调8出来
急需 :rolleyes:
或者谁告诉偶哪有 答 1: 另外偶想问:为什么UCLK不一直开着,只有在发送的时候才开,这样的话命令发送完了,还得发送空指令才能等接收回来的数据 :face7: 答 2: 关注啊! 答 3: void readFlahsBuffer(unsigned char bufNum, unsigned char address, unsigned char n)
{
unsigned char i = 0;
ATCS0; //片选
_NOP();
if (bufNum == 1) //选择BUFFER
{
s1Tx(0xD4);
}
else
{
s1Tx(0xd6);
}
s1Tx(0x00);
s1Tx(0x00);
s1Tx(address); //发送地址
for (i=0; i<n; i++)
{
s1Tx(0x00); //发送N个空指令接收收据
}
s1Tx(0x00); //additional don't care bytes
ATCS1; //片选
_NOP();
}
为什么偶用这个函数读BUFFER的时候读是读上来了,但产生读上来数量不对
比如
readFlahsBuffer(1, 0x00 , 0x0a); //读10个字节
只产生13次中断,数据读不全 :face11: 答 4: void readFlashStatus(void) //读FLASH状态寄存器
{
ATCS0;
_NOP();
s1Tx(0xD7); //发送读状态寄存器指令
s1Tx(0x00);
s1Tx(0x00); //发空指令
ATCS1;
_NOP();
}
为什么非得在发送读命令后跟两个空指令才能把状态寄存器读上来 :face14: 答 5: 问题解决,把UCLK频率提高就OK了,搞8明白,频率低中断出问题 :rolleyes: 答 6: 能否将你的解决办法说的详细些?
我现在卡在通过SPI访问FLASH这了。单步调试没问题,连续执行就不行,返回数据不是晚了2个字节,就是没有值!很是苦恼!你是过来人能否帮小弟分析一下!
谢谢! 答 7: 楼上的兄弟可以帮忙看一下我的程序吗?我怎么连状态也读不出来啊?我的通讯时钟用的32768系统子时钟,程序如下:
//串行通讯初始化,SPI1口,波特率为9600
UCTL1 = CHAR+SYNC+MM;
UTCTL1 =CKPH+STC+SSEL1;
UBR11 = 0x00;
UBR01 = 0X03;
UMCTL1 = 0X43;
UCTL1 &= ~SWRST;
ME2 |= USPIE1;
//读积存器状态自程序
void check_spi()
{
P5OUT &= ~0X01;
delay(2);
TXBUF1=0xD7;
while(UTXIFG1==1);
do{
TXBUF1=0;
while(UTXIFG1==1);}
while((RXBUF1&0xD4)=0);
P5OUT |= 0X01;
}
这样是不是应该能够读出存储器的状态啊,我怎么读不出来,请有经验的兄弟指点一二 答 8: while((RXBUF1&0xD4)=0);这句没看懂!
没看见你有读RXBUF的代码呀?
在你发为数据(为了让存储器发回数据而进行的TX)期间应该每字节间加一定量延时,大约30uS以上!
你试试!
急需 :rolleyes:
或者谁告诉偶哪有 答 1: 另外偶想问:为什么UCLK不一直开着,只有在发送的时候才开,这样的话命令发送完了,还得发送空指令才能等接收回来的数据 :face7: 答 2: 关注啊! 答 3: void readFlahsBuffer(unsigned char bufNum, unsigned char address, unsigned char n)
{
unsigned char i = 0;
ATCS0; //片选
_NOP();
if (bufNum == 1) //选择BUFFER
{
s1Tx(0xD4);
}
else
{
s1Tx(0xd6);
}
s1Tx(0x00);
s1Tx(0x00);
s1Tx(address); //发送地址
for (i=0; i<n; i++)
{
s1Tx(0x00); //发送N个空指令接收收据
}
s1Tx(0x00); //additional don't care bytes
ATCS1; //片选
_NOP();
}
为什么偶用这个函数读BUFFER的时候读是读上来了,但产生读上来数量不对
比如
readFlahsBuffer(1, 0x00 , 0x0a); //读10个字节
只产生13次中断,数据读不全 :face11: 答 4: void readFlashStatus(void) //读FLASH状态寄存器
{
ATCS0;
_NOP();
s1Tx(0xD7); //发送读状态寄存器指令
s1Tx(0x00);
s1Tx(0x00); //发空指令
ATCS1;
_NOP();
}
为什么非得在发送读命令后跟两个空指令才能把状态寄存器读上来 :face14: 答 5: 问题解决,把UCLK频率提高就OK了,搞8明白,频率低中断出问题 :rolleyes: 答 6: 能否将你的解决办法说的详细些?
我现在卡在通过SPI访问FLASH这了。单步调试没问题,连续执行就不行,返回数据不是晚了2个字节,就是没有值!很是苦恼!你是过来人能否帮小弟分析一下!
谢谢! 答 7: 楼上的兄弟可以帮忙看一下我的程序吗?我怎么连状态也读不出来啊?我的通讯时钟用的32768系统子时钟,程序如下:
//串行通讯初始化,SPI1口,波特率为9600
UCTL1 = CHAR+SYNC+MM;
UTCTL1 =CKPH+STC+SSEL1;
UBR11 = 0x00;
UBR01 = 0X03;
UMCTL1 = 0X43;
UCTL1 &= ~SWRST;
ME2 |= USPIE1;
//读积存器状态自程序
void check_spi()
{
P5OUT &= ~0X01;
delay(2);
TXBUF1=0xD7;
while(UTXIFG1==1);
do{
TXBUF1=0;
while(UTXIFG1==1);}
while((RXBUF1&0xD4)=0);
P5OUT |= 0X01;
}
这样是不是应该能够读出存储器的状态啊,我怎么读不出来,请有经验的兄弟指点一二 答 8: while((RXBUF1&0xD4)=0);这句没看懂!
没看见你有读RXBUF的代码呀?
在你发为数据(为了让存储器发回数据而进行的TX)期间应该每字节间加一定量延时,大约30uS以上!
你试试!
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |