总线复习之SPI
SPI总线协议以ds1302为例讲解
1.1概述。
1.2根据时序图来分析。
1.3再熟读一下DS1302的数据手册和SPI总线协议的使用。
1.4结合ds1302功能实现一定的功能。
1.1概述SPI总线协议
首先 SPI,Serial perripheral Interface,串行外围设备接口,全双工同步串行方式,SPI是四根线 SDO、SDI、SCK、CS。
特点是:我们可以采用硬件SPI或者软件模拟SPI。
1.采用主-从模式(Master-Slave)控制方式,而且时钟是由主机产生的。片选信号是主机用来是否使能从机。也是由主机产生。
2.采用同步方式传输数据,这里要注意 时钟极性(CPOL)和时钟相位(CPHA),这两个特别的属性控制着两个SPI设备间何时进行数据交换以及何时对接受到的数据进行采样,来保证数据是在两个设备之间是同步传输的。
3.数据交换
SPI设备间的数据传输之所以又被称为数据交换,是因为SPI设备在每一个时钟周期,SPI设备都会发送并接受一个bit大小的数据,相当于该设备有一个bit大小的数据被交换了。也就是说当发送完一个byte的数据时,也会收到一个Byte的数据,

时序图:这里要说一下时钟极性和时钟相位。时钟极性(CPOL)表示的是SPI在空闲时,时钟信号是高电平还是低电平
时钟相位(CPHA):表示SPI设备在SCK管脚在时钟上升沿时触发数据,还是在时钟信号变为下降沿时触发数据采样。

SSPSR: SPI设备内部的移位寄存器(Shift Register),主要是根据SPI时钟信号状态,往SSPBUF里移入或者移出数据,每次移动的数据大小由 Bus-Width 和 Channel Width决定。
1.2&1.3


先来ds1302与主控芯片的硬件连接
CE---片选 IO---数据线(本来SPI协议需要4根线,但是在读取时间时并不能写,也就是说即使是两根数据线也不能同时使用两条数据线,即就是每次只有一条数据线在使用,那么我们只需要一根数据线就可以了,用读写来区分,这样可以减少一根数据线) SCK---时钟线
1.往DS1302中的地址为add的寄存器中写入数据。
// 往ds1302中adder中写入date 传输数据时是低位在前,高位在后
void Write_date(char add,char date)
{
char i=;
CE=; //先将片选拉低置低电平
Delay();
CLK=; //CLK也拉低
Delay();
CE=; // CE然后拉高
for(i=;i<;i++) //上升沿写入数据
{
IO=add&0x01;
Delay();
add=add>>;
CLK=; //CLK也拉高
Delay();
CLK=; //CLK也拉低
Delay();
}
//在第九个时钟周期的时候
for(i=;i<;i++)
{
IO=date&0x01;
Delay();
date=date<<;
SCK=;
Delay();
SCK=;
Delay();
}
CE=0; //拉低片选
Delay();
}
2.往ds1302地址为 add 读出数据
// 从地址为add中读出数据 传输数据时是低位在前,高位在后
char Write_date(char add)
{
char i=;
char date=;date1; //date1是做一个数据中转
CE=; //先将片选拉低置低电平
Delay();
CLK=; //CLK也拉低
Delay();
CE=; // CE然后拉高
for(i=;i<;i++) //上升沿写入数据
{
IO=add&0x01;
Delay();
add=add>>;
CLK=; //CLK也拉高
Delay();
CLK=; //CLK也拉低
Delay();
}
//在第九个时钟周期的时候
for(i=;i<;i++)
{
date1=IO; // 这里已经有数据了。
date=(date>>1)|(date1>>7);
Delay();
date=date<<;
SCK=;
Delay();
SCK=;
Delay();
}
CE=; //拉低片选
Delay();
return date;
}
接下来就要熟悉ds1302的控制字了,贴上

1.4:我们实现的一些功能
先往ds1302中写入数据,然后我们每个0.5秒读出数据在数码管上显示,这样就实现了一个实时时钟,
当然再读数据手册时,自己要注意一些DS1302的一些特定的规定,这就要仔细读数据手册了,熟悉每一部分的功能作用。
总线复习之SPI的更多相关文章
- SPI总线协议及SPI时序图详解
SPI,是英语Serial Peripheral Interface的缩写,顾名思义就是串行外围设备接口.SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚 ...
- SPI总线协议及SPI时序图详解【转】
转自:https://www.cnblogs.com/adylee/p/5399742.html SPI,是英语Serial Peripheral Interface的缩写,顾名思义就是串行外围设备接 ...
- SPI总线(同步)
一.SPI总线简介 串行外围设备接口SPI(serial peripheral interface)总线技术是Motorola公司推出的一种同步串行接口.SPI 用 于CPU与各种外围器件进行全双工. ...
- 总线接口与计算机通信(二)SPI总线
SPI总线协议及SPI时序图详解 : http://blog.163.com/sunshine_linting/blog/static/44893323201181482335951/ 浅谈SPI总 ...
- SPI总线工作模式
一.SPI总线工作模式 SPI总线有四种工作模式,是由时钟极性选择(CPOL)和时钟相位选择(CPHA)决定的. CPOL = 0 ,SPI总线空闲为低电平,CPOL = 1, SPI总线空闲为高电平 ...
- 关于I2C和SPI总线协议【转】
关于I2C和SPI总线协议 IICvs SPI 现今,在低端数字通信应用领域,我们随处可见IIC (Inter-Integrated Circuit) 和 SPI (Serial Peripheral ...
- ARM与FPGA通过spi通信设计1.spi基础知识
SPI(Serial Peripheral Interface--串行外设接口)总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息.SPI总线可直接与各个厂家生产 ...
- [转]SPI通信原理简介
[转自]http://www.cnblogs.com/deng-tao/p/6004280.html 1.前言 SPI是串行外设接口(Serial Peripheral Interface)的缩写.是 ...
- RTT下spi flash+elm fat文件系统移植小记
背景: MCU:STM32F207 SPI flash: Winbond W25Q16BV OS: RTT V1.1.1 bsp: STM32F20x 1 将spi_core.c,spi_dev.c及 ...
随机推荐
- cesium 之自定义气泡窗口 infoWindow 后续优化篇(附源码下载)
前言 cesium 官网的api文档介绍地址cesium官网api,里面详细的介绍 cesium 各个类的介绍,还有就是在线例子:cesium 官网在线例子,这个也是学习 cesium 的好素材. 该 ...
- ubuntu16.04 部署配置LVS主从
实验环境---ubuntu16.04 四台机器:10.211.55.13—55.16 具体实验环境配置如下: 10.211.55.102 LVS_VIP 10.211.55.13 LVS_MAST ...
- Windows7 WIN 7 64位 环境编译6sv2.1版本的大气传输模型
从来没见过Fortran...这次为了添加国产卫星光谱响应的支持,只能从零开始肯了. 6S模型主页:http://6s.ltdri.org/index.html. 下载最新的2015年更新的6SV2. ...
- WPF:在DataTemplate中使用DataType
DataTemplate中的DataType的功能实际上和Style中的TargetType很类似. 在Style中,使用了TargetType之后,如果不定义Style的Key,那么这个Style将 ...
- QT中pro文件编写的详细说明
如果用QTCreator开发的小伙伴,可能都知道.pro文件,但是里面的具体配置可能比较模糊,今天我就来给大家好好讲解下 一.名称解释 QT += :这个是添加QT需要的模块 TARGET = :生成 ...
- 南京邮电大学java第四次实验报告
实 验 报 告 ( 2017 / 2018学年 第2学期) 课程名称 JAVA语言程序设计 实验名称 Java集成开发环境的安装与使用. Java变量.表达式与控制结构 实验时间 2018 年 6 月 ...
- Cube的高级设置
分享来源地址:http://bigdata.51cto.com/art/201705/538648.htm Cube的高级设置 随着维度数目的增加,Cuboid 的数量会爆炸式地增长.为了缓解 Cub ...
- 【转载】FPGA 中的latch 锁存器
以下这篇文章讲述了锁存器的一些概念和注意事项.原文标题及链接: FPGA 中的latch 锁存器 - 快乐至永远上的博客 - 与非博客 - 与网 http://www.eefocus.com/liuy ...
- Linux IO 模型
Linux 中主要有五种IO模式:阻塞IO, 非阻塞IO, IO 多路复用,信号驱动IO和异步IO; 如果从同步非同步,阻塞非阻塞角度来看,又可以分为:同步阻塞IO, 同步非阻塞IO,异步阻塞IO和异 ...
- DB2 因版本问题 Reorg 出错 解决办法
call Sysproc.admin_cmd('REORG TABLE MY_TABLE_NAME');