共2条
1/1 1 跳转至页
SmartARM,SPI SmartARM的SPI通信问题
问
最近我在用SmartARM2200的J5口(GPIO)做一个网络芯片enc28j60的驱动.但我在硬件层通过EasyJTag调试的时候发现不能对SPDR送数据,不管给他什么值SPDR和SPSR都是0x00,不知道是为什么?
这是我里面的一个函数:
uint8
senDSPi(unsigned char indata)
{
uint32 failsafe;
uint8 receivedByte;
S1PDR = indata;
failsafe = 0; //到这一步的时候S1PDR=0x00,我明明把indata给他了的啊?
while(((S1PSR & 0x80) == 0) && (failsafe < FAILSAFE_VALUE))
failsafe++;//这里S1PDR也为0x00
receivedByte = S1PDR;
if (failsafe >= FAILSAFE_VALUE)
{
receivedByte = 0x00;
S1PCCR = 0x08;
S1PCR = 0x20;
}
return receivedByte;
} 答 1: 请参考zlg/sd软件包里面的SPI操作函数 答 2: 我想知道正常情况下S1PDR和S1PSR的值是会变的吧? 答 3: 造成SPDR和SPSR恒为0x00的原因可能是什么? 答 4: 问题解决了J5口那里SSEL1和EINT3复用了,我把p0.20作为EINT3用,没把SSEL1拉高,估计是这个原因吧,明天把硬件改了,再测试一下,还没测试呢. 答 5: 看来管脚配置很关键了
这是我里面的一个函数:
uint8
senDSPi(unsigned char indata)
{
uint32 failsafe;
uint8 receivedByte;
S1PDR = indata;
failsafe = 0; //到这一步的时候S1PDR=0x00,我明明把indata给他了的啊?
while(((S1PSR & 0x80) == 0) && (failsafe < FAILSAFE_VALUE))
failsafe++;//这里S1PDR也为0x00
receivedByte = S1PDR;
if (failsafe >= FAILSAFE_VALUE)
{
receivedByte = 0x00;
S1PCCR = 0x08;
S1PCR = 0x20;
}
return receivedByte;
} 答 1: 请参考zlg/sd软件包里面的SPI操作函数 答 2: 我想知道正常情况下S1PDR和S1PSR的值是会变的吧? 答 3: 造成SPDR和SPSR恒为0x00的原因可能是什么? 答 4: 问题解决了J5口那里SSEL1和EINT3复用了,我把p0.20作为EINT3用,没把SSEL1拉高,估计是这个原因吧,明天把硬件改了,再测试一下,还没测试呢. 答 5: 看来管脚配置很关键了
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图四被打赏50分 | |
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 |