通过底层AVR方法实现SPI数据传输
主机端:
/*********************************
代码功能:通过底层AVR方法实现SPI数据传输(主机端)
创作时间:2016*10*17
使用资源:
更低阶的 aTmega(AVR) 库
SPI三个寄存器SPCR(控制寄存器),SPCR(状态寄存器),SPDR(数据的暂存器)
SPCR(SPI Control Register暂存寄存器)
7bit SPIE 片选使能,SPIE = 1;片选无效,SPIE = 0片选有效(主机无需片选)(单机通信也无需片选)
6bit SPE
5bit DORD
4bit MSTR
3bit CPOL 时钟极性,CPOL = 0(时钟空闲为低电平);CPOL = 1(时钟空闲为高电平)
2bit CPHA 相位极性,CPHA = 0(表示第一个边沿);CPHA = 1(表示第二个边沿);都是表示数据采样,数据有效的时刻。
1bit SPR1
0bit SPR0
SPCR(SPI Status Register 暂存寄存器)
SPDR(SPI Control Register数据的暂存器)
作者邮箱:jikexianfeng@outlook.com
********************************/
#define SCK_PIN 13 //宏定义时钟端口
#define MISO_PIN 12 //宏定义主机输出线
#define MOSI_PIN 11 //宏定义从机输出线
#define SS_PIN 10 //片选
boolean SlaveDataFlag; //数据标志位
void MasterInit(void) //初始化SPI引脚设置
{
pinMode(SCK_PIN,OUTPUT); //SCK_PIN为输出模式,(主机模式)
pinMode(MOSI_PIN,OUTPUT); //初始化主机输出总线
pinMode(MISO_PIN,INPUT); //初始化从机输出总线
pinMode(SS_PIN,OUTPUT); //初始化片选引脚(主机高电平,从机低电平)
//启动SPI
SPCR = B00000000;
SPCR = (<<SPE)|(<<MSTR);
}
byte ReadByte(void)
{
<<SPIF)));
return SPDR;
}
void WriteByte(byte value)
{
SPDR = value;
<<SPIF)));
return ;
}
void setup()
{
Serial.begin();
MasterInit();
Serial.println("jikexianfeng@outlook.com");
digitalWrite(SS_PIN,HIGH);
SlaveDataFlag = true;
}
void loop()
{
byte rxData;
while(true)
{
if(SlaveDataFlag)
{
digitalWrite(SS_PIN,LOW);
WriteByte();
Serial.println("Done writing data...");
Serial.println("Reading data from slave ...");
rxData = ReadByte();
digitalWrite(SS_PIN,HIGH);
Serial.println("Dome Reading data ...");
Serial.print("From Slave :");
Serial.println(rxData,DEC);
SlaveDataFlag = false;
}
}
}
从机端:
/*********************************
代码功能:通过底层AVR方法实现SPI数据传输(主机端)
创作时间:2016*10*17
使用资源:
更低阶的 aTmega(AVR) 库
作者邮箱:jikexianfeng@outlook.com
********************************/
#define SCK_PIN 13
#define MISO_PIN 12
#define MOSI_PIN 11
#define SS_PIN 10
void SlaveInit(void)
{
pinMode(SCK_PIN,INPUT);
pinMode(MISO_PIN,INPUT);
pinMode(MISO_PIN,OUTPUT);
pinMode(SS_PIN,INPUT);
SPCR = B00000000;
SPCR = (<<SPE);
}
byte ReadByte(void)
{
<<SPIF)));
return SPDR;
}
void writeByte(byte value)
{
SPDR = value;
<<SPIF)));
return ;
}
void setup()
{
Serial.begin();
SlaveInit();
}
void loop()
{
if(digitalRead(SS_PIN) == LOW)
{
writeByte();
byte rxData;
rxData = ReadByte();
Serial.print("Command :");
Serial.println(rxData);
}
}
通过底层AVR方法实现SPI数据传输的更多相关文章
- 进阶之路(基础篇) - 009 通过底层AVR方法实现SPI数据传输
主机端: /********************************* 代码功能:通过底层AVR方法实现SPI数据传输(主机端) 创作时间:2016*10*17 使用资源: 更低阶的 aTme ...
- SPI数据传输(库函数方法)
主机端: /********************************* 代码功能:SPI数据传输(主机端) 引脚说明: SS/CS:片选(高电平屏蔽,低电平启用) MOSI :主机送出信号 M ...
- 进阶之路(基础篇) - 008 SPI数据传输(库函数方法)
主机端: /********************************* 代码功能:SPI数据传输(主机端) 引脚说明: SS/CS:片选(高电平屏蔽,低电平启用) MOSI :主机送出信号 M ...
- 选择排序法、冒泡排序法、插入排序法、系统提供的底层sort方法排序之毫秒级比较
我的代码: package PlaneGame;/** * 选择排序法.冒泡排序法.插入排序法.系统提供的底层sort方法排序之毫秒级比较 * @author Administrator */impo ...
- Linux SPI总线和设备驱动架构之四:SPI数据传输的队列化
我们知道,SPI数据传输可以有两种方式:同步方式和异步方式.所谓同步方式是指数据传输的发起者必须等待本次传输的结束,期间不能做其它事情,用代码来解释就是,调用传输的函数后,直到数据传输完成,函数才会返 ...
- Linux驱动 - SPI驱动 之四 SPI数据传输的队列化
我们知道,SPI数据传输可以有两种方式:同步方式和异步方式.所谓同步方式是指数据传输的发起者必须等待本次传输的结束,期间不能做其它事情,用代码来解释就是,调用传输的函数后,直到数据传输完成,函数才会返 ...
- 2019-5-29-Roslyn-让-VisualStudio-急速调试底层库方法
title author date CreateTime categories Roslyn 让 VisualStudio 急速调试底层库方法 lindexi 2019-5-29 20:2:9 +08 ...
- EF 底层封装方法(供参考)
闲暇之余,整理了一下EF底层的一些基础方法,供查看,只有接口,具体实现需要你们自己写了. 建议:接口的实现定义为虚方法,当父类的方法不满住子类需求时,可以重写此方法 此接口都为公用方法,基本上满足小系 ...
- jQuery晦涩的底层工具方法们
这里整理的是jQuery源码中一些比较晦涩难懂的.内部的.最底层的工具方法,它们多为jQuery的上层api方法服务,目前包括: jQuery.access jQuery.access: functi ...
随机推荐
- Qt 手动添加ui文件到工程(转)
制作ui文件 先应该用Qt Designer绘制一个自己的界面,并存为myform.ui(这里的myform可以用自己喜欢的名字代替).在制作自己的界面文件时要注意以下几个要点: 1.要记住ui文件的 ...
- Flume+Kafka+Strom基于伪分布式环境的结合使用
目录: 一.Flume.Kafka.Storm是什么,如何安装? 二.Flume.Kafka.Storm如何结合使用? 1) 原理是什么? 2) Flume和Kafka的整合 3) Kafka和St ...
- [转]Mysql命令行常用操作
Mysql命令行常用操作 一.从命令行登录MySQL数据库服务器 1.登录使用默认3306端口的MySQL /usr/local/mysql/bin/mysql -u root -p 2.通过TCP连 ...
- 使用Visual Studio Code搭建TypeScript开发环境
使用Visual Studio Code搭建TypeScript开发环境 1.TypeScript是干什么的 ? TypeScript是由微软Anders Hejlsberg(安德斯·海尔斯伯格,也是 ...
- Docker实践(3)—浅析device mapper的thin provision
thin provision是在 kernel3.2 中引入的.它主要有以下一些特点: (1)允许多个虚拟设备存储在相同的数据卷中,从而达到共享数据,节省空间的目的: (2)支持任意深度的快照.之前的 ...
- 为什么在注册和注销的时候intent要改成隐式调用
显式意图:调用Intent.setComponent()或Intent.setClass()方法明确指定了组件名的Intent为显式意图,显式意图明确指定了Intent应该传递给哪个组件. 隐式意图: ...
- git patch
http://www.cnblogs.com/y041039/articles/2411600.html
- IDEA中PlantUML的使用
PlantUML官网地址:http://www.plantuml.com/ IDEA中安装PlantUML Plugins File-->Settings-->Plugins-->I ...
- Linux下的GNU Emacs 24命令_信息竞赛使用_C++
C代表Ctrl,M代表Alt 一.文件命令 C-x b 新建 build C-x C-f 打开文件 find C-s 保存文件 save C-x C-w 另存为 为wei w C-x C-b 打开所有 ...
- 类似新浪 腾讯微博字数统计 控制js(区分中英文 符号)
<script> ; function Q(s) { return document.getElementById(s); } function checkWord(c) { len = ...