S5PV210开发之1.0.12------I2C通信

2023-12-12 10:08

本文主要是介绍S5PV210开发之1.0.12------I2C通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  1. 什么是I2C
  2. I2C的通信时序
  3. I2C的寄存器解析
  4. 什么是G-Sensor
  5. I2C总线的通信流程

1.什么是I2C

  1. 物理接口:SCL + SDA
    (1)SCL:时钟线,传输CLK信号,一般是I2C主设备向从设备提供时钟的通道。
    (2)SDA: 数据线,通信数据都通过SDA线传输。

  2. 原理图:
    在这里插入图片描述

  3. 通信特征:
    (1)串行通信
    (2)同步
    (3)非差分(对应电平信号)
    (4)低速率

  4. 主要用途:SoC和周边外设之间的通信(典型的如EEPROM、电容触摸IC、各种sensor等)

2. I2C的通信时序

在这里插入图片描述
其中
S:起始位,当SCL和SDA都为高电平时,为总线空闲状态,当SDA从1->0时,为起始状态,SDA从0->1时,为结束状态
在这里插入图片描述
时序图:
在这里插入图片描述
解读:为了完成一个字节的传输操作,接收端向发送端发送一个ACK位。ACK脉冲发生在SCL线路的第九个时钟。一个字节的数据传输需要8个时钟。主机产生发送ACK位所需的时钟脉冲。

如果接收到ACK时钟脉冲,发射机将SDA线设置为高,释放SDA线:In Tx mode, the I2CSDA is free in the ACK time.
在ACK时钟脉冲期间,接收器驱动SDA线Low,以便在第九个SCL脉冲的高周期期间SDA保持低。

软件(I2CSTAT)开启或关闭ACK位传输功能。但是,在SCL的第9个时钟上的ACK脉冲需要完成一个字节的数据传输操作。

3. I2C的寄存器解析

  1. 结构框图:
    在这里插入图片描述
    (1)时钟部分,时钟来源是PCLK_PSYS,经过内部分频最终得到I2C控制器的CLK,通信中这个CLK会通过SCL线传给从设备。
    (2)I2C总线控制逻辑(前台代表是I2CCON、I2CSTAT这两个寄存器),主要负责产生I2C通信时序。实际编程中要发送起始位、停止位、接收ACK等都是通过这两个寄存器(背后所代表的电路模块)实现的。
    (3)移位寄存器(shift register),将代码中要发送的字节数据,通过移位寄存器变成1个位一个位的丢给SDA线上去发送/接收。学过数字电路的同学应该对移位寄存器不陌生。
    (4)地址寄存器+比较器。本I2C控制器做从设备的时候用。(理论分析)

在这里插入图片描述
I2CCON寄存器:
在这里插入图片描述
时钟分析:
(1)I2C时钟源头来源于PCLK(PCLK_PSYS,等于65MHz),经过了2级分频后得到的。
(2)第一级分频是I2CCON的bit6,可以得到一个中间时钟I2CCLK(等于PCLK/16或者PCLK/512)
(3)第二级分频是得到最终I2C控制器工作的时钟,以I2CCLK这个中间时钟为来源,分频系数为[1,16]
(4)最终要得到时钟是2级分频后的时钟,譬如一个可用的设置是:65000KHz/512/4=31KHz

中断分析
(1)如果1字节的发送或接收操作完成,则i2c总线中断发生。换句话说,ack周期结束了
(2)bit[4]: I2C-BUS TX / RX中断待定标志.如果该位读取为1,则I2CSCL为低电平,和I2Cstop。要恢复操作,请清除此位为0。

(2)I2CSTAT寄存器
在这里插入图片描述
(3)I2CADD寄存器

在这里插入图片描述
(4)I2CDS寄存器
在这里插入图片描述

4. G-Sensor(KXTE9)

(1) 概念:重力加速度传感器
(2)

  1. KXTE9的I2C地址固定为0b0001111(0x0f)
  2. I2C从设备地址本身是7位的,但是在I2C通信中发送I2C从设备地址时实际发送的是8位,这8位中高7位(bit7-bit1)对应I2C从设备的7位地址,最低一位(LSB)存放的是R/W信(就是说下一个数据是主设备写从设备读(对应0),还是主设备读从设备写(对应1)
  3. 基于上面讲的,对于KXTE9来说,主设备(SoC)发给gsensor信息时,SAD应该是:0b00011110(0x1E)
    如果是主设备读取gsensor信息时,SAD应该是:0b0001111(0x1F)

5.I2C总线的通信流程

在这里插入图片描述

在这里插入图片描述
框架分析:
我们最终目的是通过读写gsensor芯片的内部寄存器来得到一些信息。为了完成这个目的,我们需要能够读写gsensor的寄存器,根据gsensor的规定我们需要按照一定的操作流程来读写gsensor的内部寄存器,这是一个层次(协议层);我们要按照操作流程去读写寄存器,就需要考虑I2C接口协议(这就是所谓的物理层,本质就是那些时序)。此时主机SoC有或者没有控制器,有控制器时考虑控制器的寄存器,没控制器时要自己软件模拟时序。
协议层的代码主要取决于gsensor芯片;物理层代码主要取决于主机SoC。

这篇关于S5PV210开发之1.0.12------I2C通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/484224

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.