unsigned char i;
ADDR_SW_Data = 0;
GPIO_ResetBits(GPIOC, 2);//clock_en ´ò¿ª165ѡͨ¶Ë
GPIO_ResetBits(GPIOC, 1);//PL //ÔËÐÐÊý¾Ý¼ÆÈë165
delay_ms(1);
GPIO_SetBits(GPIOC, 1);//PL //ÔÊÐíÊý¾ÝÒÆλ
delay_ms(1);
for(i=0;i<16;i++) //¶Á16´ÎÊý¾Ý
{
GPIO_ResetBits(GPIOC, 0);//clock
delay_ms(1);
ADDR_SW_Data = GPIO_ReadInputDataBit(GPIOC, GPIO_Pin_3) | (ADDR_SW_Data<<1);//¶ÁÊäÈëÊý¾Ýλ
GPIO_SetBits(GPIOC, 0);//clock
delay_ms(1);
}
GPIO_SetBits(GPIOC, 2);//clock_en //¹Ø±Õ165ѡͨ¶Ë
GPIO_ResetBits(GPIOC,1);//PL //ÔËÐÐÊý¾Ý¼ÆÈë165
ADDR_SW_Data = ~ADDR_SW_Data; //²¦Â뿪¹ØÈ¡·´
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
你这个应该用上升沿或下降沿读取吧,你用电平肯定不行呀,而且中间没有延时,循环太快太快了。你循环结束了,一个位还没完呢。
按照你例程每接收1个bit延时1毫秒,接收1个字节就需要8毫秒,怎么受得了?如果不可靠,顶多在时钟沿到来之后加1-2个NOP足够矣。
纳秒级的呀:
曾做过测试,使用电平方式特别容易受干扰,而是用上升沿/下降沿触发方式则可靠得多
不好意,看错了。以为是楼主的帖子,被程序给误导了。
一周热门 更多>