当前位置:首页 > 单片机 > 单片机
[导读]1)那就是在之前的介绍中说过,在说一遍~~主机和从机的两个移位寄存器可以被认为是一个公开的16位环形移位寄存器,当数据从主机移向从机时,同时从机饿数据也向相反的放向移向主机。这就意味着在一个以为周期内,主机

1)那就是在之前的介绍中说过,在说一遍~~

主机和从机的两个移位寄存器可以被认为是一个公开的16位环形移位寄存器,当数据从主机移向从机时,同时从机饿数据也向相反的放向移向主机。这就意味着在一个以为周期内,主机和从机的数据进行了交换。(不过这个例子里没有用到这个,下个会用到~~呵呵~~),早知道对谁都好~~

2)配置为SPI主机时,SPI接口不自动控制SS引脚,必须由用户软件来处理。还有配置为从机时,只要SS引脚为高,SPI接口将一直保持睡眠状态,并保持MISO为三态。(这个章节的第一篇文章有详细的介绍~~自己可以看看~~)

3)SPI系统的发送方向只有一个缓冲器,而接收方向有两个缓冲器。也就是说,在发送时一定要等到移位过程全部结束后才能对SPI数据寄存器执行写操作(这里也就是要有这个语句:while(!(SPSR&(1<

4)具体的SPI引脚的配置~~看这一章的第一篇文章~~

十、ATMEGA16的同步串行接口SPI

十—(02)、ATMEGA16的同步串行接口SPI的串行通讯实验



然后就是程序喽:

IAR10_1_M.c:(主机发送)

//------------------------------------------------------------------------------
//这个是ATMEGA16作为主机的情况下的文件
//主机每隔1s发送数据0x55给从机,从机的D1指示灯每1s闪烁一次
#include"ioavr.h"
#include"delayics.h"
#include"macroandconst.h"
//------------------------------------------------------------------------------
#define SPIF 7
//------------------------------------------------------------------------------
//端口初始化函数
void port_init()
{
DDRB=0XB0;//SCK、MOSI、SS置位为输出,MISO设置为输入
PORTB=0X00;//输出低电平,输入也是低电平
}
//------------------------------------------------------------------------------
//SPI初始化函数
void spi_init()
{
SPCR=0x51;//使能SPI;时钟选择为16分频;时钟极性(CPOL)为低电平,起始沿为上升沿,结束沿为下降沿;
//时钟相位(CPHA)在起始沿采样
}
//------------------------------------------------------------------------------
//芯片初始化函数
void device_init()
{
port_init();
spi_init();
}
//------------------------------------------------------------------------------
//SPI主机发送函数
void spi_master_send(uchar dat)
{
SPDR=dat;
while(!(SPSR&(1<}
//------------------------------------------------------------------------------
//main
void main()
{
device_init();
while(1)
{
spi_master_send(0x55);
delay_s(1);
}
}

IAR10_1_S.c:(从机接收)

//------------------------------------------------------------------------------
//这就是ATMEGA16从机接收的文件了
#include"ioavr.h"
#include"delayics.h"
#include"macroandconst.h"
#include"bitics.h"
#include"intrinsics.h"
//------------------------------------------------------------------------------
#define SPIF 7
//------------------------------------------------------------------------------
//端口初始化函数
void port_init()
{
DDRB=0X41;//SCK、MOSI、SS置位为输入,MISO设置为输出
PORTB=0X01;//上面的输出低电平,输入也是低电平;同时PB0为输出高电平~~用于点亮法官二极管
}
//------------------------------------------------------------------------------
//SPI初始化函数
void spi_init()
{
SPCR=0x41;//使能SPI;为从机模式;时钟选择为16分频;时钟极性(CPOL)为低电平,起始沿为上升沿,结束沿为下降沿;
//时钟相位(CPHA)在起始沿采样
}
//------------------------------------------------------------------------------
//芯片初始化函数
void device_init()
{
port_init();
spi_init();
}
//------------------------------------------------------------------------------
//SPI主机发送函数
uchar spi_slave_receive()
{
while(!(SPSR&(1<return(SPDR);
}
//------------------------------------------------------------------------------
//main
void main()
{
uchar temp;
device_init();
while(1)
{
temp=spi_slave_receive();
CLR_BIT(SPSR,SPIF);
if(temp==0x55)
{
CPL_BIT(PORTB,0);
temp=0;
}
}
}


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

SPI 是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。是Motorola(摩托罗拉)首先在其MC68HCXX系列处理器上定义的。SPI是一种单主机、高速的,全双工,同步...

关键字: spi spi通信原理

为什么要加锁在SMP系统中,如果仅仅是需要串行地增加一个变量的值,那么使用原子操作的函数(API)就可以了。但现实中更多的场景并不会那么简单,比如需要将一个结构体A中的数据提取出来,然后格式化、解析,再添加到另一个结构体...

关键字: spi ic ck

为什么要加锁在SMP系统中,如果仅仅是需要串行地增加一个变量的值,那么使用原子操作的函数(API)就可以了。但现实中更多的场景并不会那么简单,比如需要将一个结构体A中的数据提取出来,然后格式化、解析,再添加到另一个结构体...

关键字: spi ic ck

SPI接口通信原理

关键字: spi 通讯

引言   现场总线作为生产过程自动化发展的重点,对推动自动化技术起到巨大的推动作用,是现代化工业的标志。MODBUS作为现场总线的一种通信协议,它实现了PLC控制器、工控仪表与设备间的通

关键字: avr单片机 智能控制系统 modbus协议

Linux 点击上方蓝字 记得关注我们哦! 内核里已经提供spi接口小屏的设备驱动,在内核的配置选项: make menuconfig ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf...

关键字: spi 内核

  SPI即串行外围设备接口,是一种高速的,全双工,同步的通信总线,由于其在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,出于这种简单易用的特性,很多AD转

关键字: spi 隔离芯片

你知道首款2Gb大容量高性能SPI NOR Flash产品吗?业界领先的半导体器件供应商兆易创新GigaDevice(股票代码 603986)今日宣布,隆重推出国内首款容量高达2Gb、高性能SPI NOR Flash——...

关键字: 2gb nor spi 兆易创新 flash产品

摘 要: Xilinx 7系列FPGA是Xilinx公司最新推出的一个芯片系列,Kintex7是该系列芯片中的一种,拥有大量的可编程资源。即便如此,在一些多模式的大型复杂的系统设计中,芯片的资源

关键字: Flash FPGA spi
关闭
关闭