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

相关文章

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD