共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网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
vscode+cmake搭建雅特力AT32L021开发环境被打赏30分 | |
【换取逻辑分析仪】自制底板并驱动ArduinoNanoRP2040ConnectLCD扩展板被打赏47分 | |
【分享评测,赢取加热台】RISC-V GCC 内嵌汇编使用被打赏38分 | |
【换取逻辑分析仪】-基于ADI单片机MAX78000的简易MP3音乐播放器被打赏48分 | |
我想要一部加热台+树莓派PICO驱动AHT10被打赏38分 | |
【换取逻辑分析仪】-硬件SPI驱动OLED屏幕被打赏36分 | |
换逻辑分析仪+上下拉与多路选择器被打赏29分 | |
Let'sdo第3期任务合集被打赏50分 | |
换逻辑分析仪+Verilog三态门被打赏27分 | |
换逻辑分析仪+Verilog多输出门被打赏24分 |