Vivado+PetaLinux 系统搭建教程

news2024/11/14 5:49:07

PetaLinux 是基于 Yocto project

DDR SDRAM
双倍数据率同步动态随机存取存储器(英语:Double Data Rate Synchronous Dynamic Random Access Memory,简称DDR SDRAM)为具有双倍资料传输率的SDRAM,其资料传输速度为系统主频的两倍,由于速度增加,其传输性能优于传统的SDRAM。

FTP文件传输
在ubuntu系统下搭建FTP服务器
在windows系统下安装FTP客户端

传输方式是使用网络进行传输

遇到的问题
**

问题一

**
sudo 密码忘记了始终报错 不正确 但是root 密码知道
通过命令
su -
passwd rgw
输入新密码进行更改即可

问题二

在安装petalinux时 安装vsftpd 通过命令安装 sudo apt-get install vsftpd
但是一直安装不上 显示网络问题 是下载源的问题

通过
sudo cp /etc/apt/sources.list /etc/apt/sources.list.backup # 备份原始配置
sudo nano /etc/apt/sources.list # 使用 nano 编辑器打开 sources.list 文件

通过这个命令更改下载源

deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal main restricted universe multiverse
deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal main restricted universe multiverse

deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-updates main restricted universe multiverse
deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-updates main restricted universe multiverse

deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-backports main restricted universe multiverse
deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-backports main restricted universe multiverse

deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-security main restricted universe multiverse
deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-security main restricted universe multiverse

把下载源改成以上的清华大学的镜像源 然后更难改后
sudo apt-get update

再通过命令更新下 在 sudo apt-get install vsftpd 对vsftpd进行下载

这样vsftpd就下载成功了

然后sudo vi /etc/vsftpd.conf

通过命令对 vsftpd配置进行更改
在这里插入图片描述
这样就可以启动vsftpd服务了 长度
再通过命令sudo /etc/init.d/vsftpd restart 启动
在这里插入图片描述
这里启动后检查FTP服务是否正常运行 通过命令
sudo systemctl status vsftpd
遇到问题时 报错
在这里插入图片描述
显示的是配置资源有问题 但是我根据文档改的配置资源没有问题 最后没有解决问题 最终我又直接把vsftpd卸载重新安装了一下 就可以了 再次检查是否成功启动 显示已经成功了
在这里插入图片描述

客户端windows安装fileZilla
在这里插入图片描述
博客的安装教程

https://blog.csdn.net/SoloVersion/article/details/124579221?ops_request_misc=&request_id=&biz_id=102&utm_term=fiezila%E5%AE%89%E8%A3%85%E6%95%99%E7%A8%8B&utm_medium=distribute.pc_search_result.none-task-blog-2allsobaiduweb~default-0-124579221.142v99pc_search_result_base2&spm=1018.2226.3001.4187

安装好后 开始搭建

第一步就是对所选的板卡进行配置 设置一些PS配置

建立vivado工程 首先创建一个工程 选择板子对应的型号
建立blockdesign 选择好zynq ps zynq这里是一个基本的配置 当之前你选择完板子型号 然后run block automation 勾选Apply Board Preset 就会根据选择的板卡型号 增加一些其他的ps接口
在这里插入图片描述
顶层设计的理解: FPGA所有设计的最高层 把所有的子模块 IP核 与FPGA外部相连的接口 集合在一起。 然后与外部世界交互 这里的外部世界指的就是pl端 非ps端的内容

在这里插入图片描述
对这句话的理解就是 ps端是cpu中央处理器 ps里的DDR接口 通过映射的方式 把ps的地址 数据 信号连接到pl端的地址上 一般ps的DDR与外部pl端的DDR SDRAM存储器通过映射的方式连接在一起。 PS中的FIXED_IO与DDR一致 都是需要将这些接口引出到FPGA顶层。然后通过映射的方式与外部引脚连接起来

PS中的固定引脚
外部引脚不能直接访问PS中的MIO引脚,而只能通过PS内部的映射关系进行访问。这是硬件设计中的一种限制和规定,确保系统的可靠性和一致性。 例如 PS_MIO0 只能对应 G6引脚。
在这里插入图片描述

DDR:是动态随机存取存储器(DDR SDRAM)

这是zedboard板子上的信息
在这里插入图片描述
丝印XXX就是指pcb板子上的丝印XXX在板子上的位置 具体是为了原理图与实际物理板之间建立关联

这是PS配置

观看下DDR配置

在这里插入图片描述
这里就是DDR的配置 为什么必须要有DDR ?
PS-DDR(DDR 是运行 PS所需的最基本的外设,显然一个系统没内存就没法运行) 以上是zedboard的版上的DDR的配置。

设置下MIO EMIO 的I/O接口

在这里插入图片描述
看一下MIO的引脚配置 哪些功能对应哪些引脚

因为后面用不到USB控制器 所以取消掉 后面还要用到UART1 从外部控制选择EMIO 将PL连接到PS上

配置一下PS PL端的

主要是用到什么协议进行配置
在这里插入图片描述
可以看到只有 M AXI GP0被勾选了。我们额外勾选上 S AXI HP0 interface,这是为了提供 PL访问 PS-DDR 的
路径,为 Central DMA IP 核提供搬运 PS-DDR 数据的可能

PL 访问 PS 中PS-DDR 要用到S AXI HP0 interface

在这里插入图片描述
这里主要指的是 以下这三个含义
在这里插入图片描述

修改PS 提供给PL的时钟

PL中的一些逻辑需要的时钟不同 所以要把ps提供给pl的时钟进行修改

在这里插入图片描述
比如这里用到的就是 FCLK_CLK0 这个时钟

添加PL to PS 的中断

在这里插入图片描述
IRQ_F2P 是 PL提供给 PS的中断,通常用于把 PL外设的中断反馈给 PS。例如,PL中部署的 UART控制器可
能需要在收到数据后用中断告知 CPU“我收到了数据”。另外,可以把这些中断连接到 PL外的按键上,用来实现按
键中断。

然后就可以搭建PL系统

第二步就是设置PL端 搭建PL系统

原本ps端都有的 如果你想用到外设PL端上 设置好后他就会在芯片上显现

因为我们ps uart用得是与外部相连接EMIO 扩展得外部接口 所以这里我们要用uart 1 引出去 来实现PS PL得数据交互 缺点就是速率较慢 优点是较方便 一般可以用AXI总线来实现 速率比较快
在这里插入图片描述
右击Make External 就可以把这个接口引出block design

在这里插入图片描述
这样就把uart_1引出block design了

搭建AXI-GPIO外设

AXI GPIO这是一个外设控制得IP核 ps能通过 M_AXI_GP0接口访问 axi_gpio_0 的 AXI从接
口,但他们之间并不能直接连接,而是要通过一个 AXI Interconnection(AXI交叉开关,简称 AXI桥)

ps上得AXI 与axi_gpio上得axi相连接 是不能直接相连的需要一个axi得交叉开关 简称AXI桥
通过Run connection Automation 自动生成 并且连接起来 新的block design 就已经建立了
在这里插入图片描述

这是新的增得一些ip核
在这里插入图片描述
其中ZYNQ右下角得两个时钟信号FCLK_CLK0 FCLK_RESET0_N从ps端输出到rst_ps_100M这个IP核当中根据ps输入得时钟连线顺序可以看出 经过rst_ps_100M这个ip核 输出了一个信号 这里就是把两个不同时钟得信号进行了 时钟上得统一

这个rst_ps_100M这个IP核得作用在于同步复位时钟
在这里插入图片描述
又新增了一个ps_axi_periph这个ip核 他主要得作用是处理PS与PL之间得地址映射 确保PL可以正确得访问PS提供得地址空间 以及正确得数据位宽读取或写入数据
地址转换和数据位宽变换

在这里插入图片描述
对于这个ip核 左侧得从机接口连接得是zynq得AXI_GPIO接口 右侧主接口连接其他外设 也就是这里得axi_gpio

配置GPIO 应为要用8个led 所以这里得GPIO的位宽应设置8位
在这里插入图片描述
这里的Default Output Value这个值为55 这里设置输出的值为55
在这里插入图片描述
再把这个输出的引脚 引出到block design 外
在这里插入图片描述
这样这里的GPIO引脚就引到外边去了 这样GPIO的配置就结束了

搭建AXI-UARTlite外设

在这里插入图片描述

加入这个IP核
首先auto 这里就可以根据连接得时钟是多少,从而设置它自己的工作时钟
设置没有校验位
**校验位:**校验位(Parity Bit)是在串行通信中用于检测传输错误的一种方法。它是通过在数据位中插入一个额外的位来实现的。校验位的作用是使得数据的位数具有一定的特定性,以便在接收端检测出传输过程中是否发生了错误
**在传输过程中,**发送端和接收端必须使用相同的校验方式。发送端计算校验位并将其添加到数据中,接收端在接收数据后计算校验位,如果校验不通过,则表明在传输过程中可能发生了错误。

在这里插入图片描述
这里又复制了一个 这样就有了两个axi_uartlite 我们需要配置一下 因为想要与pl进行通信 使用得axi总线 需要axi桥来进行地址数据得映射 所以需要与axi桥进行连接 从而与ps端相连
所以双击ps_axi_periph进行配置
在这里插入图片描述
这里设置成3 因为额外连接两个从机
配置完后这里多出现了两主接口
在这里插入图片描述
右侧不只多加了 俩个这个 左侧还多加了 M01 ACLK , M01 ARESETN ,M02 ACLK ,M02 ARESETN .

右侧是把axi_uartlite 挂载到AXI桥上 左侧是解决时钟问题
在这里插入图片描述
**

搭建 Central DMA (CDMA)

**
用来实现 PS-DDR 的数据的快速拷贝
对CDMA模块进行配置
在这里插入图片描述
去掉
“Enable Scatter Gather”(启用分散聚集)通常是指在输入/输出(I/O)系统中启用分散聚集(Scatter-Gather)功能。这是一种用于提高数据传输效率和灵活性的技术,通常在操作系统、驱动程序或硬件控制器中实现。

这里配置的读写位宽64位 是因为外设 通过ps的HP接口访问ps中的ddr 这个HP 接口的宽度就为64bit 所以这个位宽设置在高也不会有提升了因为 那个通道也就是64bit 所以DMA这个性能瓶颈也就是跟接口也有关系

CDMA DMA区别
在这里插入图片描述
我们勾选掉 Enable Scatter Gather功能,使用最简单的 DMA 机制,这种 DMA只需要配置源地址、目的地址、
长度,就能进行 DMA 传输。 配置好后 ok

在这里插入图片描述

点击 OK配置好 Central-DMA模块。可以看到,新添加的 Central-DMA模块(axi_cdma_0)具有一个 AXI从
接口(S_AXI_LITE)和一个 AXI主接口(M_AXI)。其中,S_AXI_LITE 接口需要连接到 ps_axi_periph 上,PS
通过 S_AXI_LITE 接口来控制 DMA;M_AXI是 DMA搬运数据使用的接口,M_AXI需要通过 ps 的 HP 接口来访
问 PS-DDR,这样才能实现 DDR数据的搬迁。

s_axi_lite_aclk和 s_axi_lite_aresetn 分别是 S_AXI_LITE 接口
的时钟和复位;而 m_axi_aclk 是 M_AXI接口的时钟。

连接中断信号

在zedboard中中断信号IRQ_F2P

axi_uartlite_0、axi_uartlite_1、axi_cdma_0 都各有一个中断输出信号,它们需要连接到 ps 的中断输入引
脚(IRQ_F2P) 目的是把这三个中断合并成3个信号组 由PS板子上的IRQ_F2P中断信号一同控制。

PL系统搭建完毕 开始分配地址

分配地址

AXI Interconnect 负责对地址进行转换,根据主机的读写请求中的地址把请求路由到对应的外设中
在这里插入图片描述
对这些进行地址分配

可以看到上图只有一个分配了地址 然后其他都没有分配地址
在这里插入图片描述
可以按照这种方式进行分配

在这里插入图片描述
这里就配置好了

在这里插入图片描述
Base Name 是 HP0_DDR_LOWOCM,这意味着对于 axi_cdma_0 来说,它能访问 0x00000000~0x1FFFFFFF这
512MB的地址空间,这个空间对应的就是 PS 的 DDR

Block Design 综合、生成 Wrapper

这样就完成了block design的设计 然后进行验证设计的是否有问题 通过
在这里插入图片描述
通过这里去检查验证。

在这里插入图片描述
我这里就报错了 显示一个ps_axi_periph的时钟没有连接

检查错误进行连接就ok了
在这里插入图片描述
在进行验证 就没有报错误了。

对你设计好的部分生成IP核

在这里插入图片描述
对设计好的进行生成 Generate Output Products

在这里插入图片描述
这三个选项的含义是:

  1. Global:全局综合、当 Block Design被改变时,重新综合 Block Design 内部的所有 IP 以及 Block Design
    外部的所有 Verilog 代码。这种方法很低效,有时候我只是修改一点东西就要重新综合整个工程,因此
    不推荐。
  2. Out of context per IP:每个 IP 核独立进行综合,当修改 Block Design内的一个 IP 核时,只重新综合这个
    IP,不需要综合其它没有变的 IP,推荐选这个
  3. Out of context per Block Design:如果 Block Design中的一个 IP 被修改,那么整个 Block Design中的所有
    IP 都要重新综合。
    然后生成

然后我们用 vivado 自动生成该 Block Design 的 HDL Wrapper,这个 Wrapper文件其实就是一个套在 Block
Design外面的 Verilog 文件,以方便 Block Design 能被其它 Verilog文件调用。右键 bd,点 Generate HDL Wrapper,
在这里插入图片描述
然后生成Generate HDL Wrapper这个文件

  1. Copy generated wrapper to allow user edits:生成的 Verilog 文件不会自动更新,当用户修改 Block Design
    时,需要手动的重新生成 HDL Wrapper。
  2. Let Vivado manage wrapper and auto-update:当用户 Block Design后,HDL Wrapper 会被自动修改。
    我们选择 Let Vivado manage wrapper and auto-update,然后点 OK。生成了一个 bd_wrapper.v,打开它可以发现,
    该 Verilog 模块包含了 Block Design 中所有引出的接口,例如 DDR、FIXED_IO、UART 等。

对wrapper的理解
在FPGA设计中,将PL(Programmable Logic,可编程逻辑)端的各个IP核、模块或接口结合成一个模块,然后使用Verilog或VHDL语言进行描述,形成一个包装(wrapper)模块。这个包装模块会包含所需的接口、信号连接、时钟和复位逻辑等。

第三步就是写编写 Verilog 顶层文件

以上生成了bd_wrapper.v的文件

不建议大家修改 bd_wrapper.v,而是在
bd_wrapper.v 外套一层 top.v,在 top.v 内编写你 Verilog 的逻辑,因为 bd_wrapper.v 可能会被 Vivado 自动修改,从
而导致你编写的代码消失。

新建一个 top.v 文件作为整个工程的顶层,右键 Sources 选项卡中的 Design Sources,在弹出的框中点 Add
Sources
在这里插入图片描述
创建一个top.c的文件
在这里插入图片描述
根据生成的wrapper文件 连编写top.v的文件
在这里插入图片描述

建立引脚约束

需要把 top 模块中的所有属于 PL 的引脚约束到 PL 的 IO 口上,其中 DDR 和 FIXED_IO 开头的信号是属
于 PS 的,不需要约束
,只需要约束 3 对 UART 和 8个 LED。
在这里插入图片描述
然后创建.xdc文件 实现引脚约束

引脚的约束要根据手册进行配置

进行制作SD卡启动镜像

zynq的linux启动有三个步骤
步骤一 zynq上电后,会根据5个模式进行引脚配置 MODE[4:0]=00000 对应JTAG模式 MODE[4:0]=01000 对应QSPIflash启动
MODE[4:0]=01100 对应从SD卡启动
步骤二 zynq开始运行BOOT程序,BOOT程序先后分为三部分 1 FSBL 、Bitstream和UBOOT。
FSBL负责初始化PS-DDR;
Bitstream是加载到PL里的比特流;
UBOOT负责从QSPI、SD卡、以太网等外设中加载Linux镜像(Linux镜像一般是一个叫image.ub的文件),并运行。

		   进入UBOOT时,如果打断倒计时,会进入一个简易的命令行(UBOOT命令行)我们可以在UBOOT命令行输入命令来从外设加载Linux镜像到memory 然后从memory中启动Linux   不打断倒计时 UBOOT就会从默认的外设中加载Linux镜像并启动  默认的配置可以在Petalinux中设置

步骤三 运行Linux镜像 Linux启动 进入Linux 命令行终端

安装petalinux

linux上的共享文件和vmwaretools工具都安装好见文章linux学习有讲解

安装petalinux要先进行安装依赖具体依赖如下

在这里插入图片描述
不要在root超级用户下安装 切回普通用户 先创建一个petalinux2019文件夹 然后进入到文件夹后 安装完依赖在对下载的petalinux进行安装 这里注意 安装petalinux要的磁盘大小在100g左右运行给到了8g 之前不知道 扩展磁盘一堆问题又重新安装了一遍 麻烦的很
安装好后要运行source settings.sh脚本文件 设置petalinux运行环境 导出petalinux的环境变量

遇到个小插曲就是虚拟机上复制东西到不了windows上 解决问题就是
解决方法一:安装 VMware Tools

  1. 查看vmware Tools是否安装

     打开虚拟机 ,点击上方导航栏 ‘虚拟机’ 查看VMware Tools是否安装,如果未安装,安装即可
    

加粗样式
解决方法二:命令行解决
如果第一种方法不行,可以试试第二种方法

    1.输入命令,切换到 /usr/bin 目录下
       输入命令     vmware-user

解决方法三:重新安装组件

这里petalinux主要的设计流程是
1 搭建vivado工程 主要的目的是导出hdf文件硬件描述语言
2创建一个petalinxu工程
3在把hdf文件导入petalinxu工程当中(就是将vivado设计应用到petalinux工程中)
4配置petalinux 并且配置内核 配置U-boot以及根文件系统
5编译petalinux工程(U-boot镜像、内核镜像以及rootfs,bitstream,fsbl镜像文件)这是编译得到的结果
6启动开发板
**

要把刚才在vivado中生成hdf硬件描述语言传过来可以用ftp share方式将文件从windows穿过来

传完之后

开始创建petalinux工程

第二步 通过petalinux -create -t project -n zynq7060 --template zynq 创建一个petalinux工程 名字为zynq7060 平台是zynq平台创建
在这里插入图片描述
第三步 把hdf导入这个petalinux创建的工程当中
也就相当于配置信息的一部分
在创建的petalinux目录下把hdf文件复制过去
在这里插入图片描述
根据你设置的工程名称和生成的sdk以及相应的目录进行配置
在这里插入图片描述
会进入这个对话框 键盘控制选项
在这里插入图片描述
进行硬件配置
选择memory setting
在这里插入图片描述
这里页面是根据你vivado配置的一些数据相配置的 比如这里的System Memory Size 大小是0x4000000(大小为1G) 这个意思是制作出来的系统会使用1G地址空间作为内存 我们把这里设置成0x20000000 512MB 这样linux内核和应用会使用前的一半的DDR 而后一半的DDR我们用来Central-DMA数据搬运

在这里插入图片描述
改好后退回原来的地方

进入serial settings选项
在这里插入图片描述

这里一般是你vivado中生成hdf的配置的一些设置
在回退进行配置
在这里插入图片描述
在这里插入图片描述
配置primary以太网 这里的以太网只是对Uboot而言 为linxu提供以太网启动方式
在这里插入图片描述
因为不需要以太网启动 所以这里设置manual
再回退一步
在这里插入图片描述
进入flash settings
在这里插入图片描述
partition 0 存放FSBL Bitestrem UBOOT 这里Bitestream较大 FSBL和UBOOT较小 大概不会超过8M 所以把partition大小放 置8M
partition 1 使用默认0x20000 不做改动
partition 2 存放 Linux Kernel(image.ub),一般 image.ub 一般在 5MB~20MB 之间。考虑 QSPI flash 有 32MB,我们可以给 partition 2 分配尽量多的空间,这里我们分配 0x1500000(21MB)
前三个分区加起来大小是 0x1d20000(29.125MB),注意在分配空间时前三个分区不要把 32MB 全用完,会
出一些莫名的 bug。
partition 3 和 partition 4 不要动,
在这里插入图片描述
配置好后 这几个分区配置后
在回退到原来的地方
进入SD/SDIO
在这里插入图片描述
这里可以设置 Primary SD 控
制器,例如这里默认设置的是 ps7_sd_0,这样,UBOOT 会默认从 PS 的 SDIO0 中加载 image.ub
**在这里插入图片描述**
然后回退 1 步回到 Subsystem AUTO Hardware Settings,进入 Advanced bootable images storage Settings,这里,
我们把 boot image settings和 kernel image settings 设为 primary sd(保持默认设置即可)。
这样,BOOT 程序和 Linux 镜像都会从 SD 卡中加载
在这里插入图片描述
在这里插入图片描述

然后回退 2 步回到 ZYNQ Configuration,进入 Ycoto Settings,勾选 Enable Debug Tweaks(使用 y键)
至此我们完成了 petalinux 工程的基本设置,然后在下方多次点 Exit 一路退出,在最后一部点保存(Save),回到
命令行终端,然后 PetaLinux 会花一些时间完成配置。配置完后如下图:
在这里插入图片描述
需要等待一些时间
在这里插入图片描述
这里就是配置完成了

然后我们配置 Linux 镜像,给它加入 axi_uartlite IP 核的设备驱动的支持,这样,PL_UART0 和 PL_UART1 会
在 Linux 中变成两路 tty(字符终端设备)。
运行一下命令:
petalinux-config -c kernel 这里是linux 内核会以内核的核心功能为出发点,描述Linux内核的整体架构,以及架构之下主要的软件子系统。之后,会介绍Linux内核源文件的目录结构,并和各个软件子系统对应。
在这里插入图片描述

这里要花一定的时间才能够打开
在这里插入图片描述
经过一段时间后会弹出一个和上一步类似的配置界面,我们进入 Device Drivers → Character Devices → Serial
drivers ,勾选 Xilinx uartlite serial port support(默认一般是勾选上的)。然后一路按 Exit退出,最后保存。回到命
令行终端。PetaLinux 会花一写时间进行配置。

在这里插入图片描述

配置好后 进行编译

petalinux-build 编译好后进入目录进行查看
在这里插入图片描述
petalinux-package --force --boot --fsbl images/linux/zynq_fsbl.elf --fpga
images/linux/system.bit --u-boot images/linux/u-boot.elf

通过该命令把
把 FSBL、Bitstream、UBOOT 打包成 SD 卡的 BOOT 程序
在这里插入图片描述
解释下uboot是什么?
u-boot全称universal boot loader 通用启动 引导程序
主要作用终极目标就是启动 引导 Linux内核或其他的内核
需要
1把镜像文件一般存放在sd卡或qspi等这些外存设备中
2一定将内核镜像文件拷贝DDR内存当中
3所以u-boot 需要将内核镜像文件从sd卡或qspi中读取出来 并且拷贝到ddr中
4uboot程序中肯定包含了sd卡或者qspi等这些设备的驱动程序
5还需要DDR的驱动程序 需要拷贝到ddr之前将ddr进行初始化

u-boot作用启动linux内核
fsbl是开发板在开机上电之后运行的第一段代码
要先制作一个启动文件boot.bin
这个启动文件一般包括fsbl+用户裸机程序+bit
静态情况下 boot.bin是存放在qspi或者SD卡里边的
系统启动后fsbl 代码会第一个运行 作用是引导 启动用户裸机程序

这里就会生成一个boot.bin 之后就可以用sd卡启动

了解SD卡
先说下sd卡的问题 一般单片机 一般断电数据会丢失掉 但是有一些数据需要保存起来 所以有一些芯片就要断电后要把数据保存起来,
第一个就是e方prom 就是用来当断电后保存相应数据的 e2prom一般与微控制器mcu之间通过i2c协议进行传输使用2跟线一个是scl 一个是sda

iic 短距离 抗干扰能力差 一般适用于电路版上的芯片间传输 因为发收器接收器共用一根总线 所以可以发送任意字节 9个时钟发送一个数据
起始位是高电平 uart是低电平

一般三种i情况 1.主机给从机发数据
2.从机给主机发数据
3.主机先给从机发数据 在从从机给主机发数据
1.主机给从机发数据
在这里插入图片描述
首先主机发一个7位 找到从机地址 然后0就是主机给从机发数据 然后从机应答 然后主机发数据从机应答一直循环 当主机发送最后一个字节数据后 从机应答 然后停止 还有是主机发送最后一个字节 从机不想接收就不应答 直接停止(注意这里是主机发送停止)

2.从机给主机发数据
在这里插入图片描述
主机发送一个7位地址找到从机的地址然后1表示从机给主机发送数据 然后从机应答A 然后从机发送数据 主机在应答A 从机在发送主机在应答 主机发停止信号 从机发送数据 主机不应答 主机发送停止信号。

3.主机先给从机发数据 在从从机给主机发数据
在这里插入图片描述
主机先发起始信号 发送字节数据发送从机地址 然后是0 主机给从机发送数据 从机应答 主机在发送数据 从机可应答不应答 主机发送起始信号 在发送从机地址 然后1是从机给主机发数据 从机应答从机发送数据主机非应答 主机发送停止信号。

总结一下 都是先主机发送起始信号 然后发送从机地址 然后通过0 1来判断是主机给从机发还是从机给主机发 然后发送到被接收的一方来判断应答还是非应答 然后主机发送停止信号。

e方prom优点
1 每个单元可独立访问 读和写
2 数量少
3 写入前不用擦除

在这里插入图片描述
在这里插入图片描述
scl迟到早退

在这里插入图片描述
scl低电平 主机把数据依次放到SDA上 并释放SCL 从机在scl高电平期间读取数据位
在这里插入图片描述
在这里插入图片描述

flash存储器 (一闪 顾名思义写入速度读出速度快) 常用芯片为w25x16
1 容量大
2扇区地址 字节地址
3写入之前必须先擦除
4擦除是以扇区为单位的
大多数flash存储器与mcu的协议是spi协议进行传输的

flash流程 就是先把flash中的扇形区内的所有数据拷贝到mcu中然后在mcu的ram中改对应数据 然后再把数据传回flash中
(这里单片机ram空间要容纳flash扇区内的数据 才可以实现写入)

(文件系统是为了解决大容量数据的存储器的)
sd卡 安全数据存储卡

1读取sd卡的一个扇区
2写sd卡的一个扇区
3获取sd卡的状态
4给sd卡做一个配置用什么通信方式进行传递数据 成为sd卡初始化

这个整体成为时sd卡的驱动程序

sd卡的驱动
1.磁盘概念的推广
2.sd卡驱动的实现
1sd卡的硬件接口
三种方式
1 spi 串行外设接口 cs mosi miso sclk 这是spi通信协议
2 sd模型 一个是一线sd 一个是4线sd模式

SDIO控制器 不支持spi模式

SD/SDIO控制器与arm之间是通过AHB总线进行数据通信

sd卡 FATFS系统

文件系统是什么 就是负责管理和存储文件信息软件机构称为 文件管理系统 称文件系统
FAT/FATFS系统

在这里插入图片描述
ps端实现读写txt文本实验

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

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

相关文章

Matplotlib | 绘制饼图

目录 简介安装 Matplotlib开始绘制简单饼图添加标签添加百分比修改显示方式突出扇形设置标题修改颜色实践:绘制七大洲面积比例图 简介 饼图(Pie Chart),用扇形的面积,也就是圆心角的度数来表示数量。 饼图能够十分直…

【Java】ApiPost请求返回 `406` 状态码(jackson)

Java系列文章目录 补充内容 Windows通过SSH连接Linux 第一章 Linux基本命令的学习与Linux历史 文章目录 Java系列文章目录一、前言二、学习内容:三、问题描述3.1 问题截图3.2 错误简介3.2.1 HTTP状态码 406 Not Acceptable3.2.2 序列化和反序列化 3.3 后端问题位置…

yaml文件查看模型的架构

最近在看hrnet模型代码,想查看hrnet的模型架构,输出一下,但是模型参数需要cfg,我就想着怎么把yaml文件导进来然后打印模型呢,直接chat就可以了,下面解释一下每一部分,非常的好理解 yaml文件格式…

传神论文中心|第24期人工智能领域论文推荐

在人工智能领域的快速发展中,我们不断看到令人振奋的技术进步和创新。近期,开放传神(OpenCSG)传神社区发现了一些值得关注的成就。传神社区本周也为对AI和大模型感兴趣的读者们提供了一些值得一读的研究工作的简要概述以及它们各自…

ChatGPT 3.5/4.0使用手册:解锁人工智能的无限潜能

1. 引言 在人工智能的浪潮中,ChatGPT以其卓越的语言理解和生成能力,成为了一个革命性的工具。它不仅仅是一个聊天机器人,更是一个能够协助我们日常工作、学习和创造的智能伙伴。随着ChatGPT 3.5和4.0版本的推出,其功能和应用范围…

3个免费好用的网站,可以转换PDF,提取MP3

今天分享的三个网站,分别用于文件转换PDF,QMC转MP3格式和配色网站。 TOPDF 这个网站是一个在线PDF转换工具,可以快速将文本文件、演示文稿、电子表格和图片转换为PDF格式。它支持多种文件格式,如AZW3、BMP、CHM、CSV、DjVu、DOC、…

秋招突击——算法练习——8/30、9/4——技巧题练习——复习{}——新作{只出现一次的数字、多数元素、颜色分类、下一个排列、寻找重复数}

文章目录 引言复习新作136、只出现一次的数字个人实现 169、多数元素个人实现 75、颜色分类个人实现参考实现 31、下一个排列个人实现参考实现 287寻找重复数个人实现参考实现 总结 引言 手撕的代码大部分都是出自于这里,还是要继续加强,把剩下一些零碎…

10分钟学会Jmeter的用法

一提到接口测试,通常大家会有这样的疑问:前端测试不是已经覆盖到各种业务逻辑了吗?为什么还要做接口测试,接口测试和前端测试是不是重复了?对于这个问题,可以从下面几个方面来解释: 什么是接口…

Ubuntu共享文件夹的设置

ubuntu的操作路径时:/mnt/hgfs/51C_share

Mongodb 4.2.25 安装教程

一、上传部署包 1.1上传mongodb包进入/usr/local目录,将mongodb-linux-x86_64-rhel70-4.2.25.tgz包传到该目录下。 cd /usr/local 二、安装 2.1解压 tar zxvf mongodb-linux-x86_64-rhel70-4.2.25.tgz 2.2修改名称 mv mongodb-linux-x86_64-rhel70-4.2.25/ mong…

《OpenCV计算机视觉》—— 模板匹配

文章目录 一、模板匹配简单介绍二、三个主要函数的介绍1.执行模板匹配函数-cv2.matchTemplate()2.查找最佳匹配函数-cv2.minMaxLoc()3.在原图上绘制匹配区域函数-cv2.rectangle() 三、代码实现 一、模板匹配简单介绍 在Python中,模板匹配是一种在图像中查找与给定模…

记录一下blender烘焙贴图黑边的一个坑

首先是拆UV这里 margin 0.1 better share better 这个也大一点好了 这样烘焙的猴头就是正常的 这里的坑点是 降噪!!烘焙如果开启降噪 如果关闭下面那一个 会好一点,都关闭了,才是最上面的效果

2024全国大学生数学建模国赛评审细则

2024全国大学生数学建模国赛评审细则 —参考2023年全国大学生数学建模竞赛C题评阅细则 评分体系阅览 —分值结果仅供参考 80分:稳国一; 65分:达国奖门槛(70分更为稳妥); 60至50分:有望获省…

整形提升-C语言

整型提升的原则:当一个小字节数,向大字节数转换时,有符号补0或1,无符号补0; 为什么会发生测试结果呢,让我们来看一下 在64位的环境中char是1个字节8位 char a1; 1000 0001 原码 整形提升 111…

网恋照妖镜源码搭建教程

文章目录 前言创建网站1.打开网站设置 配置ssl2.要打开强制HTTPS,用宝塔免费的ssl证书即可,也可以使用其他证书,必须是与域名匹配的3.上传文件至根目录进行解压4.解压后,修改文件 sc.php 里面的内容5.其余探索 前言 前俩年很火的…

ComfyUI中IC-Light节点的Detail Transfer节点参数测试

🎆背景 ic-light是一个能重绘画面光影的节点,但是在重绘的过程中,难免会将图像本身的细节进行重绘,尤其是在电商的场景中,文字和商品的细节很多时候会被重绘的乱七八糟。 针对这种情况,Comfyui-IC-Light节…

Elasticsearch的Restful风格API

前言:本博客仅作记录学习使用,部分图片出自网络,如有侵犯您的权益,请联系删除 1、Restful及JSON格式 RESTFUL是一种网络应用程序的设计风格和开发方式,基于HTTP,可以使用 XML 格式定义或 JSON 格式定义。R…

串行总线舵机

项目需求: 直接旋转:总体旋转角度方向 微调:步进模式/闭环电机模式 需要考虑受力之类的吗 初选方案: 只改写底层,然后引入官方驱动,通过各种函数 5、舵机如何实现在机械臂夹具中使用。 仅限夹取相同物…

开发台球助教小程序前景分析

开发台球助教小程序的前景分析可从以下维度展开探讨: 市场需求的增长 台球作为一项受欢迎的休闲运动,其爱好者群体正在扩大。随着大众对这项运动兴趣的增加,寻求系统化培训的需求也愈发明显。台球助教小程序正好填补了这一市场空白&#xf…

学习大数据DAY49 考后练习题

前几天在考帆软,考完后还有周末大礼包。 Oracle 上机练习 --第一题 create table 客户交易情况 ( 客户号 varchar2(5), 交易时间 varchar2(20),交易金额 number(5) ); --表中内容手动录入 select dense_rank()over(order by ascii(客户号)) as 序号 1,客户号, den…