0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【ZYNQ Ultrascale+ MPSOC FPGA教程】第二十四章PS端SD卡读写

FPGA技术专栏 来源:芯驿电子科技 作者:芯驿电子科技 2021-01-28 10:00 次阅读

原创声明:

本原创教程由芯驿电子科技(上海)有限公司(ALINX)创作,版权归本公司所有,如需转载,需授权并注明出处。

适用于板卡型号:

AXU2CGA/AXU2CGB/AXU3EG/AXU4EV-E/AXU4EV-P/AXU5EV-E/AXU5EV-P /AXU9EG/AXU15EG

vivado工程目录为“ps_hello/vivado”

vitis工程目录为“ps_sd/vitis”

本章介绍使用FatFs文件系统模块读取SD卡的BMP图片,并通过DP显示。

1. FatFs简介

FatFs是一个通用的文件系统模块,用于在小型嵌入式系统中实现FAT文件系统。FatFs的编写遵循 ANSI C,因此不依赖于硬件平台。它可以嵌入到便宜的微控制器中,如 8051, PIC, AVR, SH, Z80, H8, ARM等等,不需要做任何修改。

应用程序通过API函数来调用FatFs系统模块,从而来控制SD卡这些存储设备。

o4YBAGAKMcSAXIdzAAAOugfXAJ0025.jpg

FatFs 系统提供了很多 API 函数,我们在下面列举了以下我们例程中会用的的 API 函数。

f_mount - 注册/注销一个工作区域(Work Area)

f_open - 打开/创建一个文件

f_close - 关闭一个文件

f_read - 读文件

f_write - 写文件

关于 API 函数的介绍和说明,大家可以参考以下的网站进行更深一步的了解,这个网站上

给出来了每个 API 函数的使用说明和例子。

elm-chan.org/fsw/ff/00i

2. Vitis程序开发

1)打开Vitis软件,我们已经为大家生成了一个sd_bmp的工程。这里需要配置BSP支持包的属性,在Board Support Package Settings里选择xilffs项,使能项目支持xilffs文件系统。

pIYBAGAKMcWABq3BAABIIxo0Vtk518.jpgo4YBAGAKMcWAKf-KAADiNOrtrpg950.jpg

关于xilffs库是Xilinx提供的FAT文件系统支持包,用户可以调用库里的API函数实现对

SD/eMMC等设备的操作。xilffs库里主要包含FAT的文件系统(File System Files)和驱动层文件(Glue Layer Files)。

2) 关于xilffs库的介绍和应用,大家可以参考以下Xilinx官网链接:

wiki.xilinx.com/xilffs

3) 接下来我们来看sd_bmp的工程代码。在工程代码里,我们需要把 SD 卡里存储的 bmp格式的图像数据读出来,去掉图像头后放到DP的显示缓冲区中,然后实现图像在DP显示器的显示。

4)在bmp.c 文件里,我们添加了一个 bmp_read 的函数,在这个函数里首先用f_open函数打开一个 SD 卡里的bmp的图片文件。然后读取这个文件的前面 54 个字节,因为BMP图像文件的前面54个字节为图像头文件,里面包含了图像的像素大小信息。再一行一行的读取图像数据存到DP的 frame 显示缓冲区中。

由于BMP的存储是上下颠倒的,因此在bmp_read函数中调整了顺序,存入frame缓存区。

o4YBAGAKMcaAd9B8AACm-vUDmLA874.jpg

5)同时我们也准备了BMP文件头结构体,以及一些常用分辨率的图像头设置,放在bmp.h文件中。

pIYBAGAKMcaAQeqSAADEUpvGwx4636.jpg

6) 结合之前小猫图片的显示,将小猫图片保存成bmp格式,保存到SD卡里,在bmp_write函数中,结合bmp头和bmp数据,保存到SD卡。

o4YBAGAKMceAcbpBAAGI6Vj0JGc399.jpg

7) 在main函数里,调用bmp_read函数实现一副图像从SD卡读取到DP显示缓冲的存储,这里的 BMP 图像的文件名1.bmp需要和存储在SD卡里的文件名一样。用bmp_write,将小猫图片写入SD卡。

pIYBAGAKMciAFePvAABYLpkpvfQ230.jpg

3.板上验证

1) 首先需要先存一副1920*1080像素,24bit的BMP文件到SD卡里,文件名为1.bmp(文件在工程目录下),开发板断电情况下,把SD卡插入卡座里。

o4YBAGAKMciAAz8_AAAOyDhtD-g982.jpg

2) 开发板连接DP显示器,然后上电,下载程序运行之后我们可以在DP显示器上显示SD卡里存储的1.bmp文件的图像。

3) 之后可将开发板断电,将SD卡插到电脑上,可以看到多了CAT.BMP

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1625

    文章

    21619

    浏览量

    601148
  • 嵌入式
    +关注

    关注

    5057

    文章

    18964

    浏览量

    301814
  • SD卡
    +关注

    关注

    2

    文章

    558

    浏览量

    63724
  • Zynq
    +关注

    关注

    9

    文章

    607

    浏览量

    47100
  • MPSoC
    +关注

    关注

    0

    文章

    195

    浏览量

    24230
收藏 人收藏

    评论

    相关推荐

    Zynq UltraScale + MPSoC USB 3.0 CDC器件类设计

    Linux主机测试CDC功能履行实施细节设计类型仅PSSW类型Zynq®UltraScale+MPSoC Linux操作系统CPU的ARM Cortex A53 Core 0以1.1 GHz运行
    发表于 01-03 09:59

    如何调试Zynq UltraScale+ MPSoC VCU DDR控制器

      如何调试Zynq UltraScale+ MPSoC VCU DDR控制器  Zynq UltraScale+
    发表于 01-07 16:02

    如何调试Zynq UltraScale+ MPSoC VCU DDR控制器

    如何调试 Zynq UltraScale+ MPSoC VCU DDR 控制器?
    发表于 01-22 06:29

    ZYNQ Ultrascale+ MPSOC FPGA教程

    ZYNQ Ultrascale+ MPSOC FPGA教程
    发表于 02-02 07:53

    闲话Zynq UltraScale+ MPSoC(连载1)

    Zynq-7000,这款SoC功能显得更加强劲:最显著的变化是新加入了GPU和视频编解码器,PS的高速接口更加丰富。按照Xilinx官方的说法,Zynq
    发表于 02-08 08:24 721次阅读
    闲话<b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>(连载1)

    闲话Zynq UltraScale+ MPSoC(连载5)

    作者:Hello,Panda Part3 I/O资源 和Zynq-7000相比较,Zynq UltraScale+ 增强了PS的IO性能;
    发表于 02-08 08:29 696次阅读
    闲话<b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>(连载5)

    Xilinx基于ARM的Zynq-7000和Zynq UltraScale+ MPSoC及RFSoC器件是否存在安全漏洞

    本文试图搞清楚在 Xilinx 基于 ARM 的 Zynq-7000、Zynq UltraScale+ MPSoCZynq
    发表于 06-28 15:53 2658次阅读

    Zynq UltraScale+ MPSoC的发售消息

    Zynq®UltraScale+MPSoC,现已开始发售。视频向您重点介绍了Xilinx UltraScale +产品组合的第一位成员
    的头像 发表于 11-27 06:47 3556次阅读

    米尔科技Zynq UltraScale+ MPSoC技术参考手册介绍

    Zynq UltraScale+ MPSoC是Xilinx推出的第二代多处理SoC系统,在第一代Zynq-7000的基础上做了全面升级,在单
    的头像 发表于 11-18 11:03 3094次阅读
    米尔科技<b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>技术参考手册介绍

    如何调试 Zynq UltraScale+ MPSoC VCU DDR 控制器?

    Zynq UltraScale+ MPSoC VCU DDR 控制器是一款专用 DDR 控制器,只支持在 Zynq UltraScale+
    发表于 02-23 06:00 15次下载
    如何调试 <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b> VCU DDR 控制器?

    米尔电子zynq ultrascale+ mpsoc底板外设资源清单分享

    米尔电子推出的国内首款zynq ultrascale+ mpsoc平台核心板(及开发板):MYC-CZU3EG吸引了人工智能、工业控制、嵌入式视觉、ADAS、算法加速、云计算、有线/无线通信等
    发表于 01-07 15:20 3次下载
    米尔电子<b class='flag-5'>zynq</b> <b class='flag-5'>ultrascale+</b> <b class='flag-5'>mpsoc</b>底板外设资源清单分享

    ZYNQ Ultrascale+ MPSoC系列FPGA芯片设计

    基于 Xilinx 公司ZYNQ Ultrascale+ MPSoC系列 FPGA 芯片设计,应用于工厂自动化、机器视觉、工业质检等工业领域
    发表于 11-02 14:35 1543次阅读

    Zynq UltraScale+ MPSoC中的隔离方法

    电子发烧友网站提供《Zynq UltraScale+ MPSoC中的隔离方法.pdf》资料免费下载
    发表于 09-13 17:11 1次下载
    <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>中的隔离方法

    Zynq UltraScale+ MPSoC的隔离设计示例

    电子发烧友网站提供《Zynq UltraScale+ MPSoC的隔离设计示例.pdf》资料免费下载
    发表于 09-13 11:28 3次下载
    <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>的隔离设计示例

    Zynq UltraScale+ MPSoC验证数据手册

    电子发烧友网站提供《Zynq UltraScale+ MPSoC验证数据手册.pdf》资料免费下载
    发表于 09-15 10:13 0次下载
    <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>验证数据手册