xilinx zynq ps端移植wxworks6.9系统

news2024/11/24 10:42:50

一,创建bootrom

打开打开Workbench,目录在C:\WindRiver\workbench-3.3\wrwb\platform\x86-win32\eclipse\eclipse-x86-win32

 在菜单栏,点击 File->New->Project。The New Project Wizard opens。

在 VxWorks 6.x中,选择 VxWorks Image Project

 输入project name, 比如zynq_vxworks_bootrom

基于a board support package,选择 xlnx_zynq7k BSP,编译工具链选择diab,勾选Enable WDB Target Agent,选择next下一步,VxWorks Image Project Multipage Wizard就配置完成。

 这一步保持默认,直接选择next下一步

 从the New VxWorks Image Project中,profile选择PROFILE_DEVELOPMENT,单击finish。

 从bootrom工程中右键选择build project,开始编译Kernel image。

菜单栏,project中选择open development shell打开vxworks脚本编译窗口

 选择Wind River VxWorks 6.9,然后单击OK

进入cd vxworks-6.9\target\config\xlnx_zynq7k\ 

输入make clean make zynq_vxworks_bootrom,就会生成zynq_vxworks_bootrom.elf文件

二,根据vivado的搭建修改对bootrom的硬件配置

 1,vivado中勾选的硬件有一路PS串口,用于启动文件信息打印,现在修改vxworks串口BSP

(1)config.h文件中,修改串口打印波特率和串口的数量,如果有三路修改为3,两路修改为2,一路修改为1,这里我修改为1。修改目录宏定义在xlnx_zynq7k.h,如下截图所示。

#undef  CONSOLE_BAUD_RATE
#define CONSOLE_BAUD_RATE 115200



#undef  NUM_TTY
#define NUM_TTY             N_SIO_CHANNELS

(2)在prjParams.h文件中,此宏表示bootrom生成的BOOT.BIN启动后从哪路串口进行打印,此处我配置为1,如果需要从第1路串口打印则需要将此宏定义为1,第2路串口打印需要将宏定义配置为2。

#undef  CONSOLE_TTY
#define CONSOLE_TTY 1

(3)在hwconf.c文件中,对驱动列表中的中断输入中的串口驱动的修改。

LOCAL struct intrCtlrInputs gicInputs[] = {
    /* pin,                driver,            unit,   index */

    { INT_VEC_UART1,       "zynqSioDev",       0,       0 },

2,两路网口分别连接PS和PL,连接PL的网口使用GMII转RGMII的方式

 3,分别勾选SD卡和EMMC硬件配置

(1)如果采用SD卡启动,这里需要修改SD卡驱动,增加SD卡控制器驱动组件和文件系统组件。在config.h文件中,增加SD卡控制器驱动组件和文件系统组件。

/* SDHC */
#define DRV_STORAGE_SDHC
#define DRV_SDSTORAGE_CARD
#define INCLUDE_BOOT_FILESYSTEMS

/* dosfs */
#define INCLUDE_DOSFS
#define INCLUDE_DOSFS_MAIN
#define INCLUDE_DOSFS_CHKDSK
#define INCLUDE_DOSFS_FMT
#define INCLUDE_DOSFS_FAT
#define INCLUDE_DOSFS_SHOW
#define INCLUDE_DOSFS_DIR_VFAT
#define INCLUDE_DOSFS_DIR_FIXED
#define INCLUDE_FS_MONITOR
#define INCLUDE_FS_EVENT_UTIL
#define INCLUDE_ERF
#define INCLUDE_XBD
#define INCLUDE_XBD_TRANS
#define INCLUDE_DEVICE_MANAGER
#define INCLUDE_XBD_BLK_DEV
#define INCLUDE_XBD_PART_LIB
#define INCLUDE_DISK_UTIL

(2)如果采用EMMC启动,这里需要增加EMMC驱动配置

修改EMMC驱动,EMMC驱动和SD卡驱动是互斥的,根据硬件进行相应地配置,如果包含了SD卡驱动,就不需要EMMC驱动。如果包含了EMMC驱动,则不需要再包含SD卡驱动。此处我以一路EMMC配置为例,由于默认的BSP中有两路EMMC配置,此处我们保留EMMC0,屏蔽EMMC1。

 在文件config.h中,增加EMMC控制器驱动组件和文件系统组件

#define DRV_ZYNQ_SDHC_CTRL
#define DRV_MMCSTORAGE_CARD
#define INCLUDE_DISK_UTIL
#define INCLUDE_DOSFS
#define INCLUDE_BOOT_FILESYSTEMS
#define INCLUDE_XBD_BLK_DEV
#define INCLUDE_XBD_PART_LIB
#define INCLUDE_XBD_RAMDRV

 在hwconf.c文件中,保留EMMC0的配置,删除EMMC1的中断优先级配置

#ifdef DRV_ZYNQ_SDHC_CTRL
    { INT_VEC_SDIO0,       128 },
#endif /* DRV_ZYNQ_SDHC_CTRL */

保留EMMC0的中断配置,删除EMMC1的中断触发配置

#ifdef DRV_ZYNQ_SDHC_CTRL
    { INT_VEC_SDIO0,            VXB_INTR_TRIG_LEVEL },
#endif /* DRV_ZYNQ_SDHC_CTRL */

在中断输入中保留EMMC0,屏蔽EMMC1

#ifdef DRV_ZYNQ_SDHC_CTRL
    { INT_VEC_SDIO0,       "zynqSdhci",        0,       0 },
#endif /* DRV_ZYNQ_SDHC_CTRL */

保留EMMC0驱动模块,屏蔽EMMC1驱动模块

#ifdef DRV_ZYNQ_SDHC_CTRL
LOCAL struct hcfResource zynqSdhc0Resources[] = {
    { "regBase",    HCF_RES_INT,  {(void *)ZYNQ7K_SDHC0_BASE} },
    { "clkFreq",    HCF_RES_ADDR, {(void *)sysSdhcClkFreqGet} },
    { "polling",    HCF_RES_INT,  {(void *)FALSE} },
    { "flags",      HCF_RES_INT,  {(void *)(SDHC_PIO_NEED_DELAY |
                                            SDHC_MISS_CARD_INS_INT_WHEN_INIT |
                                            SDHC_FIFO_ENDIANESS_REVERSE |
                                            SDHC_HOST_VER_REVERSE) } }
};
#define zynqSdhc0Num NELEMENTS(zynqSdhc0Resources)
#endif /* DRV_ZYNQ_SDHC_CTRL */

在驱动列表中保留EMMC0,屏蔽EMMC1

#ifdef DRV_ZYNQ_SDHC_CTRL
    { "zynqSdhci",            0, VXB_BUSID_PLB, 0, zynqSdhc0Num,   zynqSdhc0Resources },
#endif /* DRV_ZYNQ_SDHC_CTRL */

在sysLib.c文件中,屏蔽的EMMC1控制器的寄存器地址映射,保留EMMC0控制器的寄存器地址映射内容。

#if defined(DRV_STORAGE_SDHC) || defined(DRV_ZYNQ_SDHC_CTRL) 
    {
    ZYNQ7K_SDHC0_BASE,   /* SDIO */
    ZYNQ7K_SDHC0_BASE,
    SZ_4K,
    MMU_ATTR_VALID_MSK | MMU_ATTR_PROT_MSK | MMU_ATTR_DEVICE_SHARED_MSK,
    MMU_ATTR_VALID     | MMU_ATTR_SUP_RWX  | MMU_ATTR_DEVICE_SHARED
    },
/*
    {
    ZYNQ7K_SDHC1_BASE,   /* SDIO */
    ZYNQ7K_SDHC1_BASE,
    SZ_4K,
    MMU_ATTR_VALID_MSK | MMU_ATTR_PROT_MSK | MMU_ATTR_DEVICE_SHARED_MSK,
    MMU_ATTR_VALID     | MMU_ATTR_SUP_RWX  | MMU_ATTR_DEVICE_SHARED
    }, 
*/

#endif /* DRV_STORAGE_SDHC || DRV_ZYNQ_SDHC_CTRL */

4,勾选flash硬件配置,为后续flash启动固化做准备

(1)添加TFFS文件系统组件。

#define  INCLUDE_TFFS

(2)在config.h文件中,修改spi总线类型,默认为4BIT,由于我此处硬件设计为两片flash,所以修改为8BIT,如果只有一片flash可以不用修改 

#   define SPI_BUS_TYPE             SPI_SINGLE_8BIT

(3) 由于硬件上有两片16M大小的flash,所以将16M修改为32M。

#   define SPI_FLASH_SIZE           (SZ_32M)

5,修改默认boot启动参数
gem(0,0)表示从网口0启动vxWorks镜像,host表示主机名称,vxWorks.st表示vxWorks系统镜像名称,h表示主机ip地址,e表示板卡ip地址,g表示网关地址,u表示ftp用户名,pw表示ftp密码,f表示bootom启动时的特殊标志,tn表示板卡名称。

#define DEFAULT_BOOT_LINE \
    "gem(0,0)host:vxWorks h=192.168.1.36 e=192.168.1.50:ffffff00 \
     g=192.168.1.1 u=vxWorks pw=vxWorks f=0x0 tn=xlnx_zynq7k"

三,在SDK生成zynq_fsbl.elf文件

创建一个BOOT.BIN需要生成[bootloader]zynq_fsbl.elf和bootROM.elf来合成

 打开SDK,菜单栏中New选择Application Project

 输入fsbl文件名,点击next下一步

 选择zynq fsbl,点击完成。生成后,点击zynq_fsbl工程右键,build project生成elf文件

 四,生成wxworks系统BOOT.BIN启动文件

菜单栏Xilinx,选择Creat Boot Image创建启动文件

 生成BOOT.BIN启动文件

 启动wxworks系统打印信息

五,创建wxworks应用程序

选择File > New > Project > VxWorks Downloadable Kernel Module Project,点击next下一步。

输入一个 project name,比如hello_my_world

连续点击下一步

点击下一步

点击finish完成

右键选择New > File,新建一个应用程序

  取名hello_world.c,点击hello_my_world,然后finish完成

 加入应用程序代码

 wxworks应用程序举例

#include <sys/mman.h>
#define GPIO_BASE 0xE000A000
#define GPIO_DIRM_0 0x00000204
#define GPIO_OEN_0 0x00000208
#define GPIO_DATA_0 0x00000040
int main(void)
{
    printf("Hello World!\n");
    int val = 0xffffffff;
    sysOutLong(GPIO_BASE + GPIO_DIRM_0, 0x00000400);
    sysOutLong(GPIO_BASE + GPIO_OEN_0, 0x00000400);
    while (1) 
    {
        sysOutLong(GPIO_BASE + GPIO_DATA_0, val);
        sleep(1);
        val ^= 0xffffffff;
    }
    return 0;
}

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

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

相关文章

WDM波分复用器件的结构组成介绍

目前已知WDM波分复用技术有很多种&#xff0c;如&#xff1a;FBT (熔融拉锥&#xff0c;Fused Biconical Taper)、FBG(光纤布拉格光栅&#xff0c;Fiber Bragg Grating)、TFF (薄膜滤波&#xff0c; Thin Film Filter)、AWG (阵列波导光栅&#xff0c; Arrayed Waveguide Grati…

【GTest】C++在Linux上如何安装构建GoogleTest

&#x1f449;博__主&#x1f448;&#xff1a;米码收割机 &#x1f449;技__能&#x1f448;&#xff1a;C/Python语言 &#x1f449;公众号&#x1f448;&#xff1a;测试开发自动化 &#x1f449;专__注&#x1f448;&#xff1a;专注主流机器人、人工智能等相关领域的开发、…

chatgpt赋能python:Python内置字符串处理方法

Python内置字符串处理方法 Python是一种高级编程语言&#xff0c;拥有丰富的库和模块&#xff0c;方便开发者进行各种编程操作。同时&#xff0c;Python也提供了许多内置的字符串处理方法&#xff0c;使得字符串操作变得更加方便快捷。 字符串的定义 在Python中&#xff0c;…

AI实战营:人体姿态估计与MMPose

目录 人体姿态估计的介绍与应用 2D姿态估计 多人姿态估计&#xff1a;自顶向下方法 多人姿态估计&#xff1a;自底向上方法 多人姿态估计&#xff1a;单阶段方法 基于Transformer的方法 基于回归的自顶向下方法 DensePose(2014) 通过级联提升精度 回归方法的优势与劣…

考前必看|PMP考试通关宝典

项目进度管理 &#xff08;1&#xff09;项目进度计划 如何及何时交付项目范围中的产品、服务和成果&#xff0c;为绩效报告提供进度依据。 选择进度计划的方法&#xff0c;如关键路径法或敏捷方法。 &#xff08;2&#xff09;定义活动 活动由工作包分解而来&#xff0c;作…

【蓝桥杯选拔赛真题59】Scratch影院选座 少儿编程scratch图形化编程 蓝桥杯选拔赛真题解析

目录 scratch影院选座 一、题目要求 编程实现 二、案例分析 1、角色分析

SpringCloudAlibaba:服务容错之Sentinel学习

目录 一、高并发带来的问题 服务雪崩效应 二、常见容错方案 &#xff08;一&#xff09;隔离 &#xff08;二&#xff09;超时 &#xff08;三&#xff09;限流 &#xff08;四&#xff09;熔断 &#xff08;五&#xff09;降级 三、常见的容错组件 四、Sentinel概述 …

子集-回溯算法

1题目 给你一个整数数组 nums &#xff0c;数组中的元素 互不相同 。返回该数组所有可能的子集&#xff08;幂集&#xff09;。 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。 示例 1&#xff1a; 输入&#xff1a;nums [1,2,3] 输出&#xff1a;[[],[1],[2],[1…

SpringBoot项目整合Redis作为缓存中间件的详细步骤

SpringBoot项目整合Redis作为缓存中间件的详细步骤 1.链接2.整合步骤3.测试Demo4.遇到的问题5.待考虑问题 有更好的建议&#xff0c;欢迎评论区留言~ 有不详细或者不准确的地方&#xff0c;欢迎评论区指正~ 有技术群嘛 hahh 可以拉我么 ~ 1.链接 哔哩教程视频 Redis官方 2.整…

线程池的工作原则揭秘:如何合理管理线程数量?

大家好&#xff0c;我是小米&#xff0c;一个热爱技术分享的小伙伴。在多线程编程中&#xff0c;线程池是一种非常实用的工具&#xff0c;可以帮助我们更好地管理线程&#xff0c;提高程序的性能和稳定性。今天&#xff0c;我将详细介绍线程池的概念、使用方法以及常用参数&…

MFC 状态栏梳理

MFC状态栏梳理 MFC状态栏&#xff0c;觉得挺简单的&#xff0c;但是用的时候总是不得劲&#xff0c;梳理了一下代码。理解通透些。 先说状态栏窗口怎么来的 在MainFrame里面会有一个成员变量&#xff0c;状态栏 m_wndStatusBar protected: // 控件条嵌入成员CMFCMenuBar …

VMware ESXi 8.0U1a 发布 - 领先的裸机 Hypervisor

VMware ESXi 8.0U1a 发布 - 领先的裸机 Hypervisor 请访问原文链接&#xff1a;https://sysin.org/blog/vmware-esxi-8-u1/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&#xff1a;sysin.org 2023-06-01, VMware vSphere 8.0U1a 发布。 详见&am…

I.MX6ULL_Linux_驱动篇(36) GPIO输入驱动

在前面我们都是使用的 GPIO 输出功能&#xff0c;还没有用过 GPIO 输入功能&#xff0c;本章我们就来学习一下在 Linux 下编写 GPIO 输入驱动程序。我们使用一个 GPIO 加输入驱动程序&#xff0c;同时利用原子操作来对按键值进行保护。 按键驱动和 LED 驱动原理上来讲基本都是…

浅谈TTF字体和Fnt字体的本质和优缺点

前言 本篇在讲什么 浅浅对TTF字体和Fnt字体的本质了解一下 本篇的特色 具有全流程的图文教学 重实践&#xff0c;轻理论&#xff0c;快速上手 提供全流程的源码内容 ★提高阅读体验★ &#x1f449; ♠ 一级标题 &#x1f448; &#x1f449; ♥ 二级标题 &#x1f448…

【Java 接口】接口(Interface)的定义,implements关键字,接口实现方法案例

博主&#xff1a;_LJaXi Or 東方幻想郷 专栏&#xff1a; Java | 从入门到入坟 专属&#xff1a;六月一日 | 儿童节 Java 接口 接口简介 &#x1f383;接口的定义 &#x1f9e7;接口实现类名定义 &#x1f381;接口实现类小案例 &#x1f388;后话 &#x1f3b0; 接口简介 &…

从架构到特性:JuiceFS 企业版首次全面解析

大多数用户是通过社区版初次接触 JuiceFS&#xff0c;企业版对大家来说可能比较陌生。与其他开源项目不同的是&#xff0c;JuiceFS 企业版比社区版更早发布&#xff0c;社区版的架构设计大量参考了企业版。对 JuiceFS 用户而言&#xff0c;这意味着社区版具有更加稳定的特性。 …

onnx模型转 ncnn 模型全连接层输出shape不对问题解决

1.简述 最近在把paddleocr 中cls分类模型通过ncnn部署框架部署时&#xff0c;发现onnx -> ncnn 模型的转换过程中出现问题。因为之前的项目都是使用ncnn框架部署的&#xff0c;只能去解决模型转换问题了。 2. 问题描述与分析 模型在onnx推理代码上正常&#xff0c;当把模型…

Fabric.js 复制粘贴元素

theme: smartblue 本文简介 点赞 关注 收藏 学会了 当你要复制一个 fabric 的元素时&#xff0c;你考虑到的是什么&#xff1f;是深拷贝当前选中对象再添加到画布中&#xff1f; 其实&#xff0c;fabric.js 提供了一个克隆方法&#xff0c;在 fabric.js 官网的案例里也有这个…

自动驾驶赛道回暖?传统Tier1加速入场,真正赢家正在浮出水面

自动驾驶赛道&#xff0c;在经历过去三年的持续降温之后&#xff0c;正在迎来新一轮上升势头。整合、并购、协作&#xff0c;正在成为新一轮产业周期的关键词。 本周&#xff0c;滴滴自动驾驶与法雷奥签署战略合作及投资意向书&#xff0c;法雷奥将对滴滴自动驾驶进行战略投资…

【VMware】局域网里机器A访问机器B内部的vm虚拟机

一、机器B配置 1、打开机器B上面的VMware&#xff0c;在菜单里找到编辑&#xff0c;在编辑里找到“虚拟网络编辑器” 2、选择 net 项&#xff0c;点击NET设置 3、填写主机端口8090&#xff0c;主机端口不要和其它端口冲突就行&#xff0c;这个端口后面会在机器A上面用到 3.1、…