- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个问题想问那些熟悉 Xilinx Zynq 和相关设计工具的人......
我正在帮助将一个介绍性嵌入式系统类(class)从 STM32F4(ARM M3 开发板)移植到 Zynq,前几周总是介绍组装。通常我们使用 arm-none-eabi 工具链从命令行手动执行所有操作,因此我会对维护该结构感兴趣,而不是立即跳入 Xilinx Vivado/SDK 环境。但是,如果没有 Xilinx 工具套件,我无法找到任何有关对器件进行编程的资源,我觉得这很奇怪。我无法想象这是不可能的,所以任何信息将不胜感激。
谢谢!
最佳答案
我没有使用 ZyBo 的直接经验,但是我多次遇到类似的情况,我学会了如何从互联网(甚至在互联网之前)收集信息并用一些逆向工程,然后是反复试验。
我收集了一些我认为有用的信息,但我从未拥有过 ZyBo,所以对此持保留态度。
另外,如果您不了解某些术语,请花时间阅读链接的文档。
看来您可以避开 Vivado SDK 和 IDE 的一部分,Zynq 7000 Software Developer guide附录 A 中描述了使用 bootgen
和 BIF
文件生成启动镜像。
在 Zybo 术语中,引导镜像包含 BootROM header 和第一阶段引导加载程序(引导过程的第一阶段,它还包含用户代码)。
请注意,BootROM 本身是不可写的,因此您无法更改阶段 0,除非您找到破解它的方法(虽然这不是一个好主意,阶段 0 只做最少的工作并使板可用)。
取自该手册的示例
// A simple BIF file example.
the_ROM_image:
{
[init]init_data.int
[bootloader]myDesign.elf
Partition1.bit
Partition1.rbt
Partition2.elf
}
手册明确指出ELF是一种受支持的文件格式(至少我希望它是 that ELF)。
因此,您可以使用 GCC 生成 ARM ELF,然后使用 bootgen
制作启动镜像(当然没有 C 运行时)。
也支持二进制文件,因此任何 ARM 汇编程序都可以。
这应该避免任何 SDK 初始化代码,只在您的代码之前执行阶段 0。
Zynq 7000 Technical Reference Manual详细描述了BootROM头格式。
它还解释了各种硬件组件和做出的架构决策,包括启动过程和各种裸机选项。
因此,您甚至可以摆脱 bootgen
并制作自己的工具。
BootROM header 似乎有一个字段用于在 XIP 模式下定义中断表,但是,如上所述,它是 BootROM 执行的第一个代码,因此您不必从 ARM 复位向量开始。
我不熟悉 SDK,但我敢肯定,如果您窥探 SDK bin 文件夹,您会发现很多用于 ARM 工具链的常用 GNU 工具(几乎就像发生在 Android NDK 上一样)。
XILINX 在其一份文件中(唉,我不记得是哪一份了)声明他们使用了标准的 GNU 工具,并进行了轻微的扩充。
至于避免使用 XILINX 库,您可以尝试阅读它们的源代码(如果有)或反汇编它们的二进制文件。
在技术引用手册的帮助下,您应该能够首先避免它们。
XILINX 在链接的两个文档(shorter one is here)上很好地描述了它的董事会,阅读这两个文档将解释很多事情。
通常供应商会重用现有工具,因此,除非 XILINX 自己开发,否则您应该会发现 IDE 使用的命令行工具很熟悉。
在深入了解 Vivado SDK 的工作原理后,您甚至可能会开始喜欢它!
关于assembly - Zynq 上的裸机组装程序,没有 Vivado/SDK,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41751536/
我正在细读 http://www.khronos.org/网站,只找到了 OpenCL 的头文件(不是我不关心的 OpenGL)。如何获取 OpenCL SDK? 最佳答案 AMD 的 ATI Str
Android 项目中最低(最低 sdk)和最高(目标 sdk)级别是否有任何影响。这些东西是否会影响项目的可靠性和效率。 最佳答案 没有影响,如果您以 SDK 级别 8 为目标,那么您的应用将以 9
“min sdk version/target sdk version”和“compile sdk version”有什么区别?我知道 min 和 target sdk 是什么意思,但是 compil
我正在尝试运行 Dji Mobile-Sdk-Android:https://github.com/dji-sdk/Mobile-SDK-Android使用 dji 网站上的说明:https://de
我目前正在向我的 iPhone 应用程序添加新的 Facebook iOS sdk 3.1.1。我看到 sdk 有重大变化。例如。我的旧 sdk 创建一个 Facebook 对象并从 FBReques
我最近刚刚下载了 Xcode 4.6 with mac 10.8.4 with iOS 6.0 SDK package,我立即注意到我无法使用我的 iPhone 3Gs with iOS 4.6 进行
我尝试下载 OpenCL SDK。但是没办法。我有一个 AMD GPU,所以我在谷歌上搜索了 AMD SDK,但是来自谷歌的所有链接和一些教程都被破坏了,不可能通过 AMD 开发者网站找到 sdk。
安装 Google Cloud SDK 后,当我运行时 gcloud 授权登录 我收到一条错误消息: Your browser has been opened to visit: https://a
我一直在 nvidia 网站上搜索 GPU 计算 SDK,因为我正在尝试构建具有 cuda 支持的点云库 (PCL)。但是,在 nvidia 网站上,我只能找到工具包的链接,而不是 SDK 的单个下载
Closed. This question needs to be more focused。它当前不接受答案。 想改善这个问题吗?更新问题,使其仅关注editing this post一个问题。 2
当我打开 Android SDK 管理器时,会出现一个屏幕“选择要安装的包”。它列出了一堆带有绿色复选标记(已经安装)的软件包,还有一些带有 x's 的软件包,它们没有安装。如果我选择“全部接受”,它
在开发过程中,我发布了 SDK 21 Lollipop,但我无法在我的 KitKat 设备上使用它。应用程序非常简单,我只将 SDK 用于动画和 Material 设计,但是当我尝试对 Play 商店
enter image description here friend 们好 在使用 Linux、jenkins 和 docker 探索 dotnet 核心时,我遇到了构建问题,该问题在标题“/usr
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
我创建了一个flutter项目,运行flutter packages get,输出如下:【二】flutter包搞定等待另一个 flutter 命令释放启动锁...第二次运行“flutter packa
这个问题在这里已经有了答案: What are the Android SDK build-tools, platform-tools and tools? And which version sh
我使用 Corona SDK 已经快一年了,并且开发了几个简单的游戏。我现在正在寻找的是在 Corona SDK 中创建 3D 幻觉的某种方法。如果有人有 Corona 3D 方面的经验,我将不胜感激
我有一个CLDC 1.1 / MIDP 2.0项目,可以使用Java ME SDK 3.2很好地进行编译。 最近,我已将Java SE升级到8,结果Java ME SDK开始在Windows启动时显示
有没有办法以编程方式控制连接到华擎主板的 RGB 照明?我知道华硕有一个 Aura SDK,但华擎是否也有一个用于他们的硬件? 如果是,我在哪里可以找到它? 最佳答案 没有用于华擎多彩的 sdk。但是
如何使用 crm 2011 sdk 和 XrmServiceContext 创建事务? 在下一个示例中,'new_brand' 是一些自定义实体。我想创建三个品牌。第三个拥有错误的 OwnerID g
我是一名优秀的程序员,十分优秀!