嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 3 元微信扫码支付:3 元
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
# include <reg52.h>//头文件
# include <intrins.h>//头文件
# define U8 unsigned char
# define U16 unsigned int
sbit SCK = P2^0;//位定义时钟
//sbit CS = P2^3;//位定义片选(使能) 此项目可以不使用
sbit SDI = P2^1;//位定义Input
sbit SDO = P2^2;//位定义Output
/*-----函数声明-----*/
void delay5us();
void SpiSend(U8 dat1);
U8 SpiReceive();
void Com_Init(void);
/*-----主函数-----*/
void main()
{
Com_Init();
while(1)
{
SBUF = SpiReceive();// 循环接收数据
}
;//空语句
}
/*-----5微秒延时函数-----*/
void delay5us()
{
_nop_();
}
/*-----CPHA=0;CPOL=1 模式2-----*/
/*-----SPI发送函数-----*/
/*-----上升沿发送-----*/
void SpiSend(U8 dat1)
{
U8 i;
for (i=0; i<8; i)//8bit,一位一位写
{
SCK = 0;
if (dat1 & 0x80)//判断当前最高位为1还是0
{
SDO = 1;
}
else
{
SDO = 0;
}
SCK = 1;//上升沿发送数据
dat1 <<= 1;
delay5us();
}
}
/*-----SPI接收函数-----*/
/*-----下降沿接收-----*/
U8 SpiReceive()
{
U8 i, dat0;
dat0 = 0x00;//dat0初始化
for (i=0; i<8; i)//8bit,一位一位读
{
dat0 <<= 1;
while(SCK == 1);
while(SCK == 0);//等待下降沿,下降沿读取数据
dat0 |= SDI;
}
return (dat0);//收到数据(返回值)dat0
}
/*-----串口(中断)初始化-----*/
void Com_Init(void)
{
SCON=0x50;
PCON=0x00;
TMOD=0x20;
TH1=0xfd;
TL1=0xfd;
TR1=1;
EA=1;
ES=1;
}
/*-----串口中断服务函数-----*/
void UART() interrupt 4
{
if (RI)//判断是否接收完成
{
RI = 0;//软件清零
SpiSend(SBUF); // 转发接收到的数据
}
if (TI)//判断是否发送完成
{
TI = 0;//软件清零
}
}