MCU GPIO模拟spi

/*片选 控制*/
#define SimSpiCsHigh() GPIO_SetBits  (GPIO_CS )
#define  SimSpiCsLow()  GPIO_ResetBits(GPIO_HR_CS )




/*时钟电平控制*/
#define  SimSpiSckHigh() GPIO_SetBits  (GPIO_SCLK)
#define  SimSpiSckLow()  GPIO_ResetBits(GPIO_SCLK)


#define SimSpiSdoGet() GPIO_ReadInputDataBit(GPIO_SDO)


/*写数据输出*/
#define SimSpiSdiHigh() GPIO_SetBits (GPIO_SDI)
#define SimSpiSdiLow() GPIO_ResetBits(GPIO_SDI)

void MCU_SimSpiInit(void)
{
GPIO_InitTypeDef GPIO_InitStructure;


/********************模拟spi总线GPIO初始化****************/
        
/* DMR_SPI SCLK SDO CS设置为输出 */
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_25MHz;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;


GPIO_InitStructure.GPIO_Pin = GP_GetPin(GPIO_CS);
GPIO_Init(GP_GetPort(GPIO_CS), &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GP_GetPin(GPIO_SCLK);
GPIO_Init(GP_GetPort(GPIO_SCLK), &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GP_GetPin(GPIO_SDI);
GPIO_Init(GP_GetPort(GPIO_SDI), &GPIO_InitStructure);

/* 模拟SPI 的SDO 设置为输入 */
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
    
GPIO_InitStructure.GPIO_Pin = GP_GetPin(GPIO_SDO);
GPIO_Init(GP_GetPort(GPIO_HR_SDO), &GPIO_InitStructure);
        
SimSpiCsHigh();
SimSpiSckHigh();

}
void MCU_SimSpiCs(IoHiLoType iosta)
{
if(iosta==IOHILO_HI)
{
SimSpiCsHigh();
 MCU_DlyXus(1);
}
else
{
SimSpiCsLow();
}
}

void MCU_SimSpiWrite(INT8U* pData, INT16U Len)
{
INT8U  cBit;
INT16U iLoop;
INT8U  cTemp;


for (iLoop=0; iLoop<Len; iLoop++)
{
cTemp = *pData++;

for (cBit=0; cBit<8; cBit++)
{
SimSpiSckHigh();
if (cTemp&0x80)
{
SimSpiSdiHigh();
}
else
{
SimSpiSdiLow();
}
MCU_DlyXus(1);
SimSpiSckLow();
MCU_DlyXus(1);
cTemp <<= 1;
}
}
}


void MCU_SimSpiRead(INT8U* pData, INT16U Len)
{
INT8U  iBit;
INT16U iLoop;
INT8U  cTemp;


for (iLoop=0; iLoop<Len; iLoop++)
{
cTemp = 0;
for (iBit=0; iBit<8; iBit++)
{
cTemp <<= 1;
SimSpiSckHigh();

MCU_DlyXus(5);

SimSpiSckLow();


if (SimSpiSdoGet())
{
cTemp |= 1;
}

MCU_DlyXus(5);
}
*pData++ = cTemp;
}

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

缥缈孤鸿_jason

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值