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的更多相关文章

  1. SPI总线协议及SPI时序图详解

    SPI,是英语Serial Peripheral Interface的缩写,顾名思义就是串行外围设备接口.SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚 ...

  2. SPI总线协议及SPI时序图详解【转】

    转自:https://www.cnblogs.com/adylee/p/5399742.html SPI,是英语Serial Peripheral Interface的缩写,顾名思义就是串行外围设备接 ...

  3. SPI总线(同步)

    一.SPI总线简介 串行外围设备接口SPI(serial peripheral interface)总线技术是Motorola公司推出的一种同步串行接口.SPI 用 于CPU与各种外围器件进行全双工. ...

  4. 总线接口与计算机通信(二)SPI总线

    SPI总线协议及SPI时序图详解  : http://blog.163.com/sunshine_linting/blog/static/44893323201181482335951/ 浅谈SPI总 ...

  5. SPI总线工作模式

    一.SPI总线工作模式 SPI总线有四种工作模式,是由时钟极性选择(CPOL)和时钟相位选择(CPHA)决定的. CPOL = 0 ,SPI总线空闲为低电平,CPOL = 1, SPI总线空闲为高电平 ...

  6. 关于I2C和SPI总线协议【转】

    关于I2C和SPI总线协议 IICvs SPI 现今,在低端数字通信应用领域,我们随处可见IIC (Inter-Integrated Circuit) 和 SPI (Serial Peripheral ...

  7. ARM与FPGA通过spi通信设计1.spi基础知识

    SPI(Serial Peripheral Interface--串行外设接口)总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息.SPI总线可直接与各个厂家生产 ...

  8. [转]SPI通信原理简介

    [转自]http://www.cnblogs.com/deng-tao/p/6004280.html 1.前言 SPI是串行外设接口(Serial Peripheral Interface)的缩写.是 ...

  9. 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及 ...

随机推荐

  1. cesium 之自定义气泡窗口 infoWindow 后续优化篇(附源码下载)

    前言 cesium 官网的api文档介绍地址cesium官网api,里面详细的介绍 cesium 各个类的介绍,还有就是在线例子:cesium 官网在线例子,这个也是学习 cesium 的好素材. 该 ...

  2. ubuntu16.04 部署配置LVS主从

    实验环境---ubuntu16.04 四台机器:10.211.55.13—55.16 具体实验环境配置如下: 10.211.55.102  LVS_VIP 10.211.55.13  LVS_MAST ...

  3. Windows7 WIN 7 64位 环境编译6sv2.1版本的大气传输模型

    从来没见过Fortran...这次为了添加国产卫星光谱响应的支持,只能从零开始肯了. 6S模型主页:http://6s.ltdri.org/index.html. 下载最新的2015年更新的6SV2. ...

  4. WPF:在DataTemplate中使用DataType

    DataTemplate中的DataType的功能实际上和Style中的TargetType很类似. 在Style中,使用了TargetType之后,如果不定义Style的Key,那么这个Style将 ...

  5. QT中pro文件编写的详细说明

    如果用QTCreator开发的小伙伴,可能都知道.pro文件,但是里面的具体配置可能比较模糊,今天我就来给大家好好讲解下 一.名称解释 QT += :这个是添加QT需要的模块 TARGET = :生成 ...

  6. 南京邮电大学java第四次实验报告

    实 验 报 告 ( 2017 / 2018学年 第2学期) 课程名称 JAVA语言程序设计 实验名称 Java集成开发环境的安装与使用. Java变量.表达式与控制结构 实验时间 2018 年 6 月 ...

  7. Cube的高级设置

    分享来源地址:http://bigdata.51cto.com/art/201705/538648.htm Cube的高级设置 随着维度数目的增加,Cuboid 的数量会爆炸式地增长.为了缓解 Cub ...

  8. 【转载】FPGA 中的latch 锁存器

    以下这篇文章讲述了锁存器的一些概念和注意事项.原文标题及链接: FPGA 中的latch 锁存器 - 快乐至永远上的博客 - 与非博客 - 与网 http://www.eefocus.com/liuy ...

  9. Linux IO 模型

    Linux 中主要有五种IO模式:阻塞IO, 非阻塞IO, IO 多路复用,信号驱动IO和异步IO; 如果从同步非同步,阻塞非阻塞角度来看,又可以分为:同步阻塞IO, 同步非阻塞IO,异步阻塞IO和异 ...

  10. DB2 因版本问题 Reorg 出错 解决办法

    call Sysproc.admin_cmd('REORG TABLE MY_TABLE_NAME');