源:Atmega162串行外设接口SPI

一、Atmega162的SPI接口基本概念与工作原理

SPI接口的全称是"Serial Peripheral Interface",意为串行外围接口。SPI主要使用4个信号:MOSI(master in slave out)、MISO(master out slave in)、SCK(串行时钟)、CS(片选)。其中SCK由主机产生,作为传输的同步时钟,控制所有的数据传输。主机和外设都包含一个串行移位寄存器。主机通过向自己的SPI串行寄存器写入一个字节来发起一次传输,然后通过MOSI信号线将数据传给外围设备,同时外设将自己移位寄存器中的内容通过MISO信号线返给主机。这样两个移位寄存器中的内容完成交换。也就是说,外设的写操作和读操作是同步完成的。在实际应用中,如果只进行写操作,则主机只需忽略收到的字节即可;如果主机要读外设的数据,必须发送一个自己来引发从机的传输,发送的这个字节可以是任意数据。

二、SN74HC166与TPIC6A595

SN74HC166 是8-BIT 并行加载移位寄存器。A~H为并行输入管脚,SER串行输入管脚,QH为输出管脚,SH/LD管脚用于设置并行加载和移位模式,CLK为同步时钟,控制数据传输。

TPIC6A595是8-BIT移位寄存器。SER IN管脚串行输入数据, SER OUT管脚并行输出数据,  SRCK为串行移位的脉冲, RCK的上升沿将使数据并行输出到DRAIN0~DRAIN7。

在电路中使用了4片74HC166的级联,采集32个IO点,使用3片595控制24个输出端口。电路如下图所示

74H166数据采集

595数据并行输出

电路中SCK,OEN,IEN分别接Atmega162的SPI接口。

三、SPI接口和外设之间的数据传输

使用Atemga162的SPI接口传输数据,只要往其移位寄存器写入要发送的数据即可。

  1. void SPIMasterTransmit(unsigned char TranData)
  2. {
  3. SPDR=TranData;                       //数据放入SPI寄存器中
  4. while(!(SPSR&(1<<7)));               //等待数据传输完毕
  5. }
void SPIMasterTransmit(unsigned char TranData)
{
SPDR=TranData; //数据放入SPI寄存器中
while(!(SPSR&(1<<7))); //等待数据传输完毕
}

使用3片595级联,可以并行输出3个字符的数据。先在3*8个CLK时钟脉冲下将要发送的数据移入595,最后在RCK的上升沿数据将并行充DRAINx口输出。

  1. OEN=0;
  2. for(i=0;i<3;i++)
  3. SPIMasterTransmit(Data[i]);
  4. OEN=1;
OEN=0;
for(i=0;i<3;i++)
SPIMasterTransmit(Data[i]);
OEN=1;

使用4片74HC166级联,将4个字节的数据移位通过SPI发送给Atemga162。

  1. int i;
  2. OEN=0;      //关闭SPI的输出;
  3. IEN=0;      //控制74HC166处于并行加载数据模式
  4. SPIMasterTransmit(0);//产生SPI数据传送的时钟,完成并行数据加载
  5. IEN=1;      //控制74HC166处于移位模式
int i;
OEN=0; //关闭SPI的输出;
IEN=0; //控制74HC166处于并行加载数据模式
SPIMasterTransmit(0);//产生SPI数据传送的时钟,完成并行数据加载
IEN=1; //控制74HC166处于移位模式
  1. for(i=0;i<4;i++)
  2. {
  3. SPIMasterTransmit(0);
  4. IOCELL[i]=SPDR;
  5. }
  6. IEN=0;
for(i=0;i<4;i++)
{
SPIMasterTransmit(0);
IOCELL[i]=SPDR;
}
IEN=0;

在最开始介绍了SPI的数据传输CLK需要主机发出,主机需要想移位寄存器写随意的一个数。因为我们只是需要采集输入.所以关闭SPI的输出即OEN = 0;

四、总结

当Atmega162只对外设进行读操作,我们通过写SPI移位寄存器来发出SCK,外设通过该时钟才能将数据交换给SPI移位寄存器。对于数字芯片74HC166和595的操作,以及移位寄存器、锁存器、触发器等基本概念有些模糊,先学习再下篇继续总结。

源:74HC166与TPIC6A595分析

一、功能介绍

在上一篇中介绍了在电路中,我们将采集的外部32个IO点通过74HC166转换成串行,经SPI的MISO线传送给Atmega162;使用TPIC6A595将MOSI串行输出的3个字节数据转换成并行输出。

二、74HC166使用方式介绍

74HC166是8-BIT的并行加载移位寄存器。它的功能表如下图2.1,逻辑图如图2.2所示。

图2.1:   74HC166功能表

图2.2: 74HC166逻辑图

  1. 15管脚的输入通过2个反相器控制2个与门的输入,从而实现控制74HC166的并行输入模式或者移位模式。在功能表中可以看出,当SH/!LD置0,在CLK的上升沿,并行口a~h的数据将写入D触发器。
  2. SER管脚是串行输入口,当15管脚设置成1,74HC166出于移位模式,在CLK的上升沿SER的数据将写入D触发器,原先D触发器中的数据将移入下一个D触发器,最高位D触发器中的数据将输出。在8个时钟脉冲下完成8位D触发器数据的更新。
  3. CLK INH用于关闭CLK相当于74HC166的使能控制,CLR用于清除D触发器中的数据。
三、TPIC6A595使用方式介绍

TPIC6A595是一个8-BIT的串行输入,并行输出移位寄存器。其逻辑图如图3.1所示。

图3.1

SER IN为串行输入,在SRCK的上升沿数据移位输入D触发器。移位完成后,RCK上升沿将数据并行输出。G为TPIC6A595并行输出使能。SRCLR将清除D触发器中的数据。

四、总结

74HC166和TPIC6A595的移位时钟信号都接在Atmega162的SPI接口的CLK时钟线上。当SPI发送数据时,就会产生时钟用于和外围设备数据的发送和接收。

74HC166与TPIC6A595分析(转)的更多相关文章

  1. alias导致virtualenv异常的分析和解法

    title: alias导致virtualenv异常的分析和解法 toc: true comments: true date: 2016-06-27 23:40:56 tags: [OS X, ZSH ...

  2. 火焰图分析openresty性能瓶颈

    注:本文操作基于CentOS 系统 准备工作 用wget从https://sourceware.org/systemtap/ftp/releases/下载最新版的systemtap.tar.gz压缩包 ...

  3. 一起来玩echarts系列(一)------箱线图的分析与绘制

    一.箱线图 Box-plot 箱线图一般被用作显示数据分散情况.具体是计算一组数据的中位数.25%分位数.75%分位数.上边界.下边界,来将数据从大到小排列,直观展示数据整体的分布情况. 大部分正常数 ...

  4. 应用工具 .NET Portability Analyzer 分析迁移dotnet core

    大多数开发人员更喜欢一次性编写好业务逻辑代码,以后再重用这些代码.与构建不同的应用以面向多个平台相比,这种方法更加容易.如果您创建与 .NET Core 兼容的.NET 标准库,那么现在比以往任何时候 ...

  5. UWP中新加的数据绑定方式x:Bind分析总结

    UWP中新加的数据绑定方式x:Bind分析总结 0x00 UWP中的x:Bind 由之前有过WPF开发经验,所以在学习UWP的时候直接省略了XAML.数据绑定等几个看着十分眼熟的主题.学习过程中倒是也 ...

  6. 查看w3wp进程占用的内存及.NET内存泄露,死锁分析

    一 基础知识 在分析之前,先上一张图: 从上面可以看到,这个w3wp进程占用了376M内存,启动了54个线程. 在使用windbg查看之前,看到的进程含有 *32 字样,意思是在64位机器上已32位方 ...

  7. ZIP压缩算法详细分析及解压实例解释

    最近自己实现了一个ZIP压缩数据的解压程序,觉得有必要把ZIP压缩格式进行一下详细总结,数据压缩是一门通信原理和计算机科学都会涉及到的学科,在通信原理中,一般称为信源编码,在计算机科学里,一般称为数据 ...

  8. ABP源码分析一:整体项目结构及目录

    ABP是一套非常优秀的web应用程序架构,适合用来搭建集中式架构的web应用程序. 整个Abp的Infrastructure是以Abp这个package为核心模块(core)+15个模块(module ...

  9. HashMap与TreeMap源码分析

    1. 引言     在红黑树--算法导论(15)中学习了红黑树的原理.本来打算自己来试着实现一下,然而在看了JDK(1.8.0)TreeMap的源码后恍然发现原来它就是利用红黑树实现的(很惭愧学了Ja ...

随机推荐

  1. Udp发送

    string message = "0302"; byte[] sendbytes = Encoding.ASCII.GetBytes(message); remoteIpep = ...

  2. 深入Java单例模式

    在GoF的23种设计模式中,单例模式是比较简单的一种.然而,有时候越是简单的东西越容易出现问题.下面就单例设计模式详细的探讨一下.  所谓单例模式,简单来说,就是在整个应用中保证只有一个类的实例存在. ...

  3. A*算法实现

    A* 算法非常简单.算法维护两个集合:OPEN 集和 CLOSED 集.OPEN 集包含待检测节点.初始状态,OPEN集仅包含一个元素:开始位置.CLOSED集包含已检测节点.初始状态,CLOSED集 ...

  4. Git学习 -- 工作区和暂存区

    工作区(working directory): 就是能看到的目录,如我的git文件夹 版本库(repository): 工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库 里面最重要的就 ...

  5. 转:用​C​语​言​的​r​a​n​d​(​)​和​s​r​a​n​d​(​)​产​生​伪​随​机​数​的​方​法​总​结

    标准库<cstdlib>(被包含于<iostream>中)提供两个帮助生成伪随机数的函数: 函数一:int rand(void): 从srand (seed)中指定的seed开 ...

  6. JavaScript 小技巧汇总

    判断一个变量是否申明 if (typeof v === "undefined") { // ... } 判断一个变量是否是函数 function f() {} typeof f / ...

  7. Json解析要点

    解析Json时,昨天遇到了新的问题,之前都是解析的数组,不是数组的用类来做. 这是Json串; {"status":"00001","ver" ...

  8. 基于JAVA语言的多线程技术

    1.简介 多线程技术属于操作系统范围内的知识: 进程与线程 可以这么理解,一个应用程序就是一个进程,在一个进程中包含至少一个线程:进程就是线程的容器,真正工作.处理任务的是线程. 进程是操作系统分配资 ...

  9. [转]异常:android.os.NetworkOnMainThreadException

    Android 4.1项目:使用新浪微博分享时报: android.os.NetworkOnMainThreadException 网上搜索后知道是因为版本问题,在4.0之后在主线程里面执行Http请 ...

  10. margin问题

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...