硬件开发——UART/I2C/SPI协议

硬件开发——UART/I2C/SPI协议

小狼@http://blog.csdn.net/xiaolangyangyang


1、UART

电压:

  • TTL电平:1:(+3.3V~+5V),0:(0V
  • RS232电平:1:(-3V~-15V),0:(+3V~+15V)
  • RS485电平:1:(+2V~+6V),0:(-2V~-6V),差分

时钟:波特率(如115200),没有时钟线
中断:

  • 流控状态中断:流控状态改变时触发
  • 发送中断:tx fifo发送完成后触发
  • 接收中断:rx fifo有足够数据触发
  • 发送超时中断:tx fifo有数据但不发送,超时后触发中断
  • 错误中断:rx/tx fifo溢出时触发

2、I2C

I2C基础波形

I2C_EEPROM写数据

I2C_EEPROM读数据

电压:+3.3V/+5v
时钟:100K/400K/1M,数据传输时才有时钟
中断:

  • MASTER_ON_HOLD:主机占线
  • RESTART_DET:寻址时reset中断
  • GEN_CALL:general call中断
  • START_DET:总线发生start中断
  • STOP_DET:总线发生stop中断
  • ACTIVITY:总线活动中断
  • RX_DONE:slave数据传送完成(即master不发送ack)
  • TX_ABRT:tx fifo数据无法正常发送
  • RD_REQ:slave被请求数据(即被master寻址)
  • TX_EMPTY:tx fifo数据不足中断
  • TX_OVER:tx fifo数据溢出
  • RX_FULL:rx fifo有足够数据中断
  • RX_OVER:rx fifo溢出中断
  • RX_UNDER:rx fifo读空中断

3、SPI

  • 指令:进行控制行为的定义及识别
  • 地址:拟操作的目标地址
  • Mode Bits:模式位,一般只存在Nor Flash设备中,用于标注 是否支持SIOO模式
  • Dummy Cycles:等于Wait Cycles,等待周期,给予从设备的数据输出等待时间
  • DATA:数据

电平:3.3V/5V
时钟:1M~50M,数据传输时才有时钟
中断:

  • 多master冲突中断
  • rx fifo满中断
  • rx fifo上溢中断
  • rx fifo下溢中断
  • tx fifo上溢中断
  • tx fifo空中断

QSpi Flash内部寄存器:

QSpi Flash命令:

问题

1、flash正在写或擦除时,其他线程或是cpu读取指令会出现什么情况?
        限定了只有一个cpu使用XIP,写或擦除时,使用flash suspend/resume机制


串行Flash控制器设计介绍(QSPI)
串行Flash控制器设计介绍(Final)
QSPI Flash存储控制器(概述)
QSPI Flash存储控制器(AHB从设备接口)
QSPI Flash存储控制器(直接访问控制器DAC)
QSPI Flash存储控制器(间接读访问控制器)
QSPI Flash存储控制器(间接写访问控制器)
QSPI Flash存储控制器(DMA外设控制器)
QSPI Flash驱动代码分析(等待QSPI空闲)
QSPI Flash驱动代码分析 (QSPI控制器初始化)
QSPI Flash驱动代码分析(spi主设备驱动框架)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/47801.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C++题解】1212. 移动数组元素

问题:1212. 移动数组元素 类型:数组找数 题目描述: 在一个不重复的数组中,请将这个数组的最小数和数组第一个数交换,最大数和数组最后一个数交换。 输入: 第一行有一个整数 n ( 5≤n≤100 )…

Windows 11登录密码遗忘后如何在登录

在现代社会中,随着信息技术的迅猛发展,计算机操作系统如Windows 11已经成为我们日常生活和工作中不可或缺的一部分。然而,有时我们可能会遇到忘记登录密码的尴尬情况。为了帮助大家解决这个问题,本文将详细讲解如何快速破解Window…

浅谈端到端(自动驾驶)

一、 引言 端到端是近期非常火的话题,尤其在自动驾驶、具身智能等领域。去年UniAD的发布,给大家普及了端到端的网络设计,带动了行业的发展。产业界,特斯拉FSD Beta V12效果惊艳,近期理想也推出了双系统的E2E自动驾驶系…

MySQL 分组函数

目录 1. 单/多行处理 2. 分组函数分类 3. 分组函数组合使用 4. 注意 1. 单/多行处理 分组函数又被叫做多行处理函数(多个输入,一个输出); 前面提到的数据处理函数又叫做单行处理函数(一个输入,一个输出…

<Qt> 信号和槽

目录 一、信号和槽概述 二、信号和槽的使用​​​​​​ (一)connect函数 (二)实现一个点击按钮关闭窗口的功能 (三)再谈connect 三、自定义槽函数 四、自定义信号 五、带参数的信号和槽 六、信号…

哈喽GPT-4o,程序员如何通过GPT-4o保护自己的合法权益

目录 一、法律研究Prompt:派遣合同和劳务外包合同有什么区别?详细说一下在被裁员时的区别? 二、法律条文检索Prompt:检索《劳动合同法》,以下情况属于第几条,如果公司进行技能考试,并以技能考试…

在Ubuntu上安装redis

Ubuntu上安装redis 一、通过下载redis的压缩包安装二、通过apt包管理器安装Redis三、修改redis的配置文件四、控制redis启动 Redis是一种开源的内存数据存储,可以用作数据库、缓存和消息代理等。本文将会介绍两种不同的安装方式,包括通过压缩包安装以及通…

Linux 性能优化:轻松入门

文章目录 前言一、磁盘性能优化1、 磁盘 RAID 模式选择2、文件系统优化 二、优化 CPU1、性能监控 :2、进程优先级调整 :3、进程与 CPU 绑定 : 三、优化内存四、网络性能优化1、调整 TCP 缓冲区大小2、修改系统级别的文件描述符的数量3、调整 …

js中基础数据类型与引用数据类型的种类以及区分

一、js有哪几种数据类型?几种新增数据类型? 1.分基础类型和引用型类型 基础数据类型有: number、String、boolean、undefined、null 引用数据类型有 Object(Array/数组和 function/函数 也属于对象的一种) 新增的数据类…

微信小程序:3.页面开发

页面配置 注意 1.不需要添加window作为父级 窗口表现 "navigationBarBackgroundColor": "#ffffff","navigationBarTextStyle": "black","navigationBarTitleText": "第二个页面","backgroundColor": &…

求职学习day5

安排明天hr面 投一下平安可能。 hr面准备,复习java核心技术,复习java项目。 正视自己,调整心态。 也是很早接触了javaguide但是没有持续学习,项目介绍 | JavaGuide,面试前复习一下感觉还是很有收获的。 还有一些…

studio编译报错java.lang.NullPointerException

安卓studio编译报错,这个是一个新建的项目就报错,原因是 implementation androidx.appcompat:appcompat:1.7.0版本太高,修改后版本 implementation androidx.appcompat:appcompat:1.4.0, 编译又报错 18 issues were found wh…

【MQTT(3)】开发一个客户端,QT-Android安卓手机版本

手机版本更加方便 生成安卓库 参考了这个代码 在编译Mosquitto以支持安卓平台时,主要涉及到使用Android NDK(Native Development Kit)进行交叉编译。环境的准备参考之前的博客【QT开发(17)】2023-QT 5.14.2实现Andr…

视频联网共享平台LntonCVS视频监控汇聚平台视频云解决方案

LntonCVS流媒体平台是一款遵循国家GB28181标准协议的先进视频监控与云服务平台。该平台设计独特,能够同时接入并处理多路设备的视频流,支持包括RTSP、RTMP、FLV、HLS、WebRTC在内的多种视频流格式的分发。其功能丰富多样,涵盖了视频直播监控、…

我国化工园区产业耦合发展的四种典型模式

化工园区产业耦合发展是石化化工行业走新型工业化道路,协同推进降碳、减污、扩绿、增长的必然要求,是行业实现高质量发展的必由之路。目前,我国化工园区产业耦合发展正处于探索阶段,赛迪研究院通过对石油化工、煤化工、盐化工和精…

进程与线程(一)进程相关

目录 一. 概念二 . 组成进程控制块程序段数据段 三. 特征四. 进程的状态与转换五. 进程控制进程创建进程终止进程阻塞与进程唤醒进程切换 六. 进程通信共享存储消息传递管道通信 一. 概念 多道程序环境下,允许多个程序并发执行,此时它们将失去封闭性&…

Linux-交换空间(Swap)管理

引入概念 在计算机中,硬盘的容量一般比内存大,内存(4GB 8GB 16GB 32GB 64GB…),硬盘(512GB 1T 2T…)。 冯诺依曼的现代计算机结构体系里面的存储器就是内存 内存是一种易失性存储器&#xff0c…

白骑士的C++教学实战项目篇 4.3 多线程网络服务器

系列目录 上一篇:白骑士的C教学实战项目篇 4.2 学生成绩管理系统 在这一节中,我们将实现一个多线程网络服务器项目,通过该项目,我们将学习套接字编程的基础知识以及如何使用多线程处理并发连接。此外,我们还将实现一个…

路由数据获取及封装方法

数据库设计 自联表 定义tree字段 public class LabelValue{public int label { get; set; }public string? value { get; set; }public List<LabelValue> children { get; set; }}获取路由方法 public Response<object> getMenuList() {Response<object>…

利用patch-package补丁,解决H5预览PDF时电子签章不显示问题

利用patch-package补丁&#xff0c;解决H5预览PDF时电子签章不显示问题 一、问题描述 在生产环境中&#xff0c;遇到了一个紧急的技术问题&#xff1a;用户在移动端H5页面上查看电子票时&#xff0c;PDF文件预览功能正常&#xff0c;但其中的电子签章未能正常显示。这一问题直…