|
原理圖如下
SPI.png (120.83 KB, 下載次數(shù): 59)
下載附件
protues接線圖
2019-12-9 17:24 上傳
實(shí)驗(yàn)現(xiàn)象 會(huì)有數(shù)碼管1到8的顯示 從機(jī)跟隨主機(jī)
單片機(jī)源程序如下:
#include <reg52.h>//頭文件
#include <intrins.h>//頭文件
#define uchar unsigned char
#define uint unsigned int
sbit SCK = P1^0;//位定義時(shí)鐘
//sbit CS = P1^1;//位定義片選(使能) 此項(xiàng)目可以不使用
sbit SDI = P1^2;//位定義Input
sbit SDO = P1^3;//位定義Output
/*-----函數(shù)聲明-----*/
void delay5us();
void delay();
void SpiSend(uchar dat1);
uchar SpiReceive();
/*-----主函數(shù)(主機(jī))-----*//
void main()
{
unsigned char i;
P2 = 8;
while(1)
{
for(i = 0; i<10 ;i++)
{
P2 = i;
SpiSend(i);
delay();
}
}
;//空語句
}
/*-----5微秒延時(shí)函數(shù)-----*/
void delay5us()
{
_nop_();
}
/*-----延時(shí)函數(shù)-----*/
void delay()
{
uchar i=1000,j=1000;
while(i--)
while(j--);
}
/*-----CPHA=0;CPOL=1 模式2-----*/
/*-----SPI發(fā)送函數(shù)-----*/
/*-----上升沿發(fā)送-----*/
void SpiSend(uchar dat1)
{
uchar i;
for (i=0; i<8; ++i)//8bit,一位一位寫
{
SCK = 0;
if (dat1 & 0x80)//判斷當(dāng)前最高位為1還是0
{
SDO = 1;
}
else
{
SDO = 0;
}
SCK = 1;//上升沿發(fā)送數(shù)據(jù)
dat1 <<= 1;
delay5us();
}
}
/*-----SPI接收函數(shù)-----*/
/*-----下降沿接收-----*/
uchar SpiReceive()
{
uchar i, dat0;
dat0 = 0x00;//dat0初始化
for (i=0; i<8; ++i)//8bit,一位一位讀
{
dat0<<=1;
while(SCK == 1);
while(SCK == 0);//下降沿讀取數(shù)據(jù)
dat0 |= SDI;
}
return (dat0);//收到數(shù)據(jù)(返回值)dat0
}
# include <reg52.h>//頭文件
# include <intrins.h>//頭文件
# define uchar unsigned char
# define uint unsigned int
sbit SCK = P1^0;//位定義時(shí)鐘
//sbit CS = P1^1;//位定義片選(使能) 此項(xiàng)目可以不使用
sbit SDI = P1^2;//位定義Input
sbit SDO = P1^3;//位定義Output
/*-----函數(shù)聲明-----*/
void delay5us();
void SpiSend(uchar dat1);
uchar SpiReceive();
/*-----主函數(shù)(從機(jī))-----*/
void main()
{
//UARTInit();
while(1)
{
P2 = SpiReceive();// 循環(huán)接收數(shù)據(jù)
}
;//空語句
}
/*-----5微秒延時(shí)函數(shù)-----*/
void delay5us()
{
_nop_();
}
/*-----CPHA=0;CPOL=1 模式2-----*/
/*-----SPI發(fā)送函數(shù)-----*/
/*-----上升沿發(fā)送-----*/
void SpiSend(uchar dat1)
{
uchar i;
for (i=0; i<8; ++i)//8bit,一位一位寫
{
SCK = 0;
if (dat1 & 0x80)//判斷當(dāng)前最高位為1還是0
{
SDO = 1;
}
else
{
SDO = 0;
}
SCK = 1;//上升沿發(fā)送數(shù)據(jù)
dat1 <<= 1;
delay5us();
}
}
/*-----SPI接收函數(shù)-----*/
/*-----下降沿接收-----*/
uchar SpiReceive()
{
uchar i, dat0;
dat0 = 0x00;//dat0初始化
for (i=0; i<8; ++i)//8bit,一位一位讀
{
dat0<<=1;
while(SCK == 1);
while(SCK == 0);//下降沿讀取數(shù)據(jù)
dat0 |= SDI;
}
return (dat0);//收到數(shù)據(jù)(返回值)dat0
}
全部代碼51hei下載地址,仿真工程不小心刪了,大家自己畫一下吧:
spi.zip
(45.12 KB, 下載次數(shù): 120)
2019-12-9 17:30 上傳
點(diǎn)擊文件名下載附件
下載積分: 黑幣 -5
|
評(píng)分
-
查看全部評(píng)分
|