求一个VK32系列芯片SPI扩展UART的51例子
最近用到VK3232,但是自己是个新手对SPI通讯不了解,希望各位大神能给个C51程序,小弟学习一下。谢谢! VK3232{:sad:}
神马神器?传pdf上来让大家看看 #include "def.h"
//************************************************************************************
void config_vkxx()
{
//***********************************************************
write_reg(1,SCTLR,0X38); //使能串口1,波特率为28800//晶振为11.0592
write_reg(2,SCTLR,0X38);
write_reg(3,SCTLR,0X38);
write_reg(4,SCTLR,0X38);
//使能子串口,设置子串口的波特率,具体参看数据手册中,子串口波特率设置
//************************************************************
//************************************************************
write_reg(1,SFOCR,0XFF); //使能FIFO并且清空接收和发送FIFO
write_reg(2,SFOCR,0XFF);
write_reg(3,SFOCR,0XFF);
write_reg(4,SFOCR,0XFF);
write_reg(1,SFOCR,0XFC);
write_reg(2,SFOCR,0XFC);
write_reg(3,SFOCR,0XFC);
write_reg(4,SFOCR,0XFC);
//清空发送接收FIFO中的数据,使能发送接收FIFO
//**************************************************************
//**************************************************************
/* while(read_reg(1,SFSR))
read_reg(1,SFDR);
while(read_reg(2,SFSR))
read_reg(2,SFDR);
while(read_reg(3,SFSR))
read_reg(3,SFDR);
while(read_reg(4,SFSR))
read_reg(4,SFDR);*/
//查看发送接收FIFO中是否有数据,如果有则把FIFO中的数据读出来,
//使发送接收FIFO中的数据为0
//**************************************************************
}
//*********************************************************************************
//******************************************************
void stop_bit(port)
{
write_reg(port-1,SCONR,0X48);
}
//需要说明的是:有奇偶校验的时候,数据位必须设置为9位;这里是偶校验
//这里还可以设置该路子串口的强制校验模式
//***************************************************************
//***************************************************************
void net_add(port)
{ unsigned char reg;
reg=read_reg(port-1,SCONR);
write_reg(port-1,SCONR,reg|0x03);
}
//设置网络地址可见设置,网络地址自动识别,网络地址是否
//写入FIFO的设置
//*******************************************************
//********************************************************
void address(unsigned char port,unsigned char add)
{
write_reg(port-1,SADR,add);
}
//485模式下的网络地址
//*********************************************************
//*******************************************************
void mode(port)
{
write_reg(port-1,SCTLR,0X38);
}
//子串口波特率设置为上电默认值,使能该子串口,设置普通232模式,非IR模式。这里可以设置为485模式,红外232模式
//还可以设置该路子串口是否接收广播数据
//***************************************************
//***************************************************
void aoto_flow(port)
{
write_reg(port-1,SFWCR,0XCE);
}
//设置自动硬件流量控制
//若要改为自动软件流量控制将0XCE改为0X09,写GXOFF和GXON寄存器即可
//这里还可以设置暂停发送数据和继续发送数据的触发点
//****************************************************
//*****************************************************
void idle()
{
write_reg(1,GCR,0X40);
}
//进入低功耗模式;把4改为零即可进入正常模式
//******************************************************
//******************************************************
void broadcast()
{
write_reg(1,GCR,0X80);
}
//使能广播模式,把8改为0即可进入正常模式
//******************************************************
//******************************************************
void m_uart()
{
write_reg(1,GMUCR,0X30);
}
//主串口控制,波特率设置为默认值,无校验,1位停止位
//******************************************************
//******************************************************
void gx_off()
{
write_reg(1,GXOFF,0X48);
}
//gxoff的值设置为0x48
//*******************************************************
//******************************************************
void gx_on()
{
write_reg(1,GX0N,0X58);
}
//gxoff的值设置为0x58
//*******************************************************
#include "stc51reg.h"
#include <intrins.h>
//************************************************************
void config()
{
WDT_CONTR = 0x00; // Watchdog Timer Control Register
}
//初始化单片机,
//***********************************************************
//***********************************************************
unsigned char send(unsigned char _data1,unsigned char _data2)
{ unsigned char i;
clk=0;
ness=0;
i=0;
if(_data1&0x80)
mosi=1;
else mosi=0;
clk=1;
// if(miso==1)
// i=i+0x80;
clk=0;
if(_data1&0x40)
{
mosi=1;
}
else mosi=0;
clk=1;
// if(miso==1)
// i=i+0x40;
clk=0;
if(_data1&0x20)
{
mosi=1;
}
else mosi=0;
clk=1;
// if(miso==1)
// i=i+0x20;
clk=0;
if(_data1&0x10)
{
mosi=1;
}
else mosi=0;
clk=1;
// if(miso==1)
// i=i+0x10;
clk=0;
if(_data1&0x08)
{
mosi=1;
}
else mosi=0;
clk=1;
// if(miso==1)
// i=i+0x08;
clk=0;
if(_data1 & 0x04)
{
mosi=1;
}
else mosi=0;
clk=1;
// if(miso==1)
// i=i+0x04;
clk=0;
if(_data1&0x02)
{
mosi=1;
}
else mosi=0;
clk=1;
// if(miso==1)
// i=i+0x02;
clk=0;
if(_data1&0x01)
{
mosi=1;
}
else mosi=0;
clk=1;
// if(miso==1)
// i=i+0x01;
clk=0;
if(_data2&0x80)
{
mosi=1;
}
else mosi=0;
clk=1;
if(miso)
i=i+128;
clk=0;
if(_data2&0x40)
{
mosi=1;
}
else mosi=0;
clk=1;
if(miso)
i=i+64;
clk=0;
if(_data2&0x20)
mosi=1;
else mosi=0;
clk=1;
if(miso)
i=i+32;
clk=0;
if(_data2&0x10)
mosi=1;
else mosi=0;
clk=1;
if(miso)
i=i+16;
clk=0;
if(_data2&0x08)
mosi=1;
else mosi=0;
clk=1;
if(miso)
i=i+8;
clk=0;
if(_data2&0x04)
mosi=1;
else mosi=0;
clk=1;
if(miso)
i=i+4;
clk=0;
if(_data2&0x02)
mosi=1;
else mosi=0;
clk=1;
if(miso)
i=i+2;
clk=0;
if(_data2&0x01)
mosi=1;
else mosi=0;
clk=1;
if(miso)
i=i+1;
clk=0;
mosi=0;
ness=1;
return i;
}
//模拟SPI时序,data1,data2是写入的两个数据,这里仅返回第二个数据
//*************************************************************************
//*************************************************************************
void write_reg(unsigned char port,unsigned char reg,unsigned char dat)
{
send(0x60+port*32+reg*2,dat);
}
//写寄存器,port为子串口的路数,reg为寄存器的地址,dat为写入寄存器的数据
//*************************************************************************
//*************************************************************************
unsigned char read_reg(unsigned char port,unsigned char reg)
{
return send(((port-1)<<5)+(reg<<1),0x00);
}
//读寄存器,琾ort为子串口的路数,reg为寄存器的地址,返回寄存器的值
//*************************************************************************** 包括SPI的我都给了,单片机用的是STC的,SPI控制的,基本都是一些初始化,具体的功能需要自己写 其实个人觉得,用这类芯片还不如直接选一款串口多的MCU,这样还方便,成本也低,STM32有3个串口的单片机! 谢谢3楼的朋友,能不能给解释下return i; 这是如何返回第二个数据的。 我用的单片机是C8051F040,需要用到4个串口,所以用SPI扩扩展2个串口
页:
[1]