51模擬SPI同步收發(fā)程序.C
以前弄的 51與FPGA用SPI進(jìn)行通信的測(cè)試程序, 模擬的具體是SPI的哪種模式記不清了,
只要改下sclk的時(shí)序就可以了.
#include
#include
#include
#include
//SPI接口
sbit cs = P2^3;
sbit sclk = P2^4;
sbit din = P2^2;
sbit dout = P2^1;
//
sbit ACC7=ACC^7;
unsigned char da1;
/***********************************************************************/
void LCD_Init();
void COM_Init();//測(cè)試用
void delay(t);//延時(shí)函數(shù)
unsigned char SPI_InOut(unsigned char input);
/***********************************************************************/
void main() //主函數(shù)
{
unsigned char m,i,s[10];
int a[2];
unsigned char j[10]={0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09};
COM_Init();
LCD_Init();
while(1)
{
for(i=0;i<9;i++)
{
m=j;
a[0]=SPI_InOut(m);
//a[0]=da1;
sprintf(s,"%2x",a[0]);
PutStr(0,0,s);
SBUF=m;
while(!TI);
TI=0;
delay(2000);
}
}
}
/***********************************************************************/
//測(cè)試用COM
void COM_Init()//9600
{
TMOD=0x20;
SCON=0x50;
TH1=0xfd;
TL0=0xfd;
TR1=1;
}
//******************************
void LCD_Init()
{
delay(10); //等待復(fù)位
LcmInit();
LcmClearTXT();
LcmClearBMP();
}
//**********************************************************************
void delay(t)//延時(shí)函數(shù)
{
unsigned int i,j;
for(i=0;i
{
for(j=0;j<121;j++)
{;}
}
}
//..******************************************************************
//模擬SPI,發(fā)送和接收數(shù)據(jù),同時(shí)
//輸入值 input
//返回值 getdata
//。******************************************************************
unsigned char SPI_InOut(unsigned char input)//
{
unsigned char i="8",getdata;
cs=0;
while(i--)
{
//sclk=1;
din=(bit)(input&0x80);//輸出
//_nop_();
//delay(1);
sclk=0; //下降沿
//*****************************
getdata>>=1;//接收
ACC="getdata";
ACC7=dout;
getdata="ACC";//數(shù)據(jù)到getchar中
_nop_();
sclk=1;
input=input<<1;
// if(i==0)
// da1=getdata;
}
//_nop_();
//_nop_();
//_nop_();
cs=1;
return(getdata);
}