Versal 自适应 SoC SelectMAP 启动检查表

news2024/10/6 20:25:12

Versal 自适应 SoC SelectMAP 启动检查表

本文档提供了有关 SelectMAP 启动设置的技巧和指南。在提交个案服务请求之前,应认真查看以下检查表。

SelectMAP 启动模式的常规检查表:
 

  1. 是否已查看 SelectMAP 文档,了解连接和电源轨的用法?
    • 请参阅相应的 Versal DC AC 数据手册,了解电源轨和 SelectMAP 接口规格,并确保满足这些规格
    • 请参阅 Xilinx Power Estimator (XPE) 或电源设计管理器 (PDM) 电源轨排序(Xilinx Power Estimator (XPE) 电源设计管理器 (PDM))指南,并确保遵循这些指南
    • 请参阅《Versal PCB 用户指南》(UG863) 的电源轨、专用管脚和 SelectMAP 章节,了解有关开发板初始化的信号连接指南 (https://docs.xilinx.com/r/zh_CN/ug863-versal-pcb-design)
    • 请查看 XTP546 Versal 板级原理图检查表,了解 SelectMAP 和电源轨
      • amd - Sign In
    • 请查看 AM011 SelectMAP 接口信息和 MIO 信号的使用方式 简介 • Versal 自适应 SoC 技术参考手册 (AM011) • 阅读器 • 文档门户 (xilinx.com)
    • 请查看 UG1304 https://docs.xilinx.com/r/zh_CN/ug1304-versal-acap-ssdg 以获取常规启动流程参考资料
    • 请查看《MIO 封装用户指南》,了解特定封装管脚的使用方式 https://docs.xilinx.com/r/zh_CN/am013-versal-pkg-pinout
  2. 通过上电释放 POR_B 之前,REF_CLK 是否稳定且正在运行?
    • 注:对于 SSIT 器件,需要连接 2 REF_CLK 专用管脚。
  3. Versal 自适应 SoC 启动模式管脚是否设置为 SelectMAP MODE[3:0] = 1010
  4. JTAG 的启动模式选项设置是否也可用于开发板初始化/调试?



注:建议在所有开发板上使用 JTAG 启动模式选项。选择 JTAG 启动模式选项可防止在调试期间出现长时间超时(即,如果 SelectMAP 数据接口无法正常工作,则可能需要等待 30 分钟的超时周期,然后才能在不更改模式管脚的情况下尝试加载 JTAG PDI。)
如果无法物理更改启动模式管脚,并且想要在 SelectMAP 启动失败后加载 PDI,请按以下顺序执行操作:
- SelectMAP 启动模式启动
- 等待 30 分钟超时周期
- 运行此 XSCT 脚本,以强制使用 JTAG 启动模式并发出 SRST

versal_change_boot_mode.tcl ==============================

    tar -set -filter {name =~ "Versal *"}

    # Enable ISO

    mwr -force 0xf1120000 0xffbff

    # Switch boot mode

    mwr 0xf1260200 0x0100

    mrd 0xf1260200

    # Set MULTIBOOT address to 0

    mwr -force 0xF1110004 0x0

    # Perform reset

    tar -set -filter {name =~ "PMC"}

    rst

=================================================

- 通过 JTAG 加载 PDI


软件流程 SelectMAP 检查表:

SelectMAP 启动模式生成 PDI 时,请确保已按以下步骤进行核对:

  1. 确认已选择适当的 CIPS 设置以确保 SelectMAP MIO 功能正常
    • “CIPS boot mode”CIPS 启动模式)选项卡中,是否已选中 SelectMAP 启动模式?
    • “CIPS Peripheral IO”CIPS 外设 IO)选项卡中,是否已选中适当的总线宽度(即,SelectMAP x32x8 x16 位总线宽度)?
  2. 确认正确设置了 BIF 文件属性,以确保 SelectMAP PDI 头文件设置正确且功能正常
    • 是否为目标总线宽度正确设置了 BIF 属性?
      • 在运行 Bootgen 以生成 PDI 之前,确认这些设置都正确无误
      • 对于 SelectMAPx32 为默认设置,不需要更改 BIF 文件。
      • 对于 2022.1 或更低版本,使用 SelectMAP x8 x16 时,用户必须在运行 Bootgen 之前手动包含 BIF 属性,如下所示。
      • 注:对于 SSIT 器件,请参阅下一个检查表项目以了解差异
  • 确保该属性包含在 id 之后和 image 的 pmc_subsys 之前。

对于 SelectMAP x8

new_bif:

{

id_code = 0x04d80093

extended_id_code = 0x01

id = 0x2

boot_config{smap_width=8}

image

{

name = pmc_subsys

id = 0x1c000001

Or for Select x16

new_bif:

{

id_code = 0x04d80093

extended_id_code = 0x01

id = 0x2

boot_config{smap_width=16}

image

{

name = pmc_subsys

id = 0x1c000001


注: 2022.2 版中,当用户在“CIPS Peripheral IO”选项卡中选择 SelectMAP x8 x16 时,上述属性将自动写入 BIF 文件中。

  • 是否为 Versal SSIT 器件正确设置了 BIF 属性?
    • 在 Versal SSIT 器件的 BIF 文件中,用户将在 bitstream_master 节中看到目标 smap_width,在从 SLR 节中看到 smap_width=0。
    • smap_width=0 用于表明从 SLR 设置模式,不得修改。如欲了解详细信息,请参阅相应软件版本的 UG1283。
  • 以下是一个 SSIT BIF 文件片段示例,其中 SSIT 器件的从 SLR 已包含 smap_width=0,以表明它们是下游设置。



BIF 文件中有关 SSIT 器件的设置示例

// For generating SLR1 – boot PDI

bitstream_boot_1

{

id_code = 0x04d10093

extended_id_code = 0x01

id = 0xb

// Do NOT change setting shown on SSIT Slave SLRs

boot_config {smap_width=0}

image

{

name = pmc_subsys, id = 0x1c000001

partition { id = 0xb01, type = bootloader, file = gen_files/plm.elf }

partition { id = 0xb0A, type = pmcdata, load = 0xf2000000, file = gen_files/pmc_data_slr_1.cdo }

// For generating final PDI – by combining above generated PDIs.

bitstream_master:

{

id_code = 0x04d10093

extended_id_code = 0x01

id = 0x2

// Add attribute for SelectMAP 8-bit (smap_width=8) and 16-bit (smap_width=16) under the "bitstream_master" section of BIF file

boot_config{smap_width=8)

image

{

name = pmc_subsys, id = 0x1c000001

SelectMAP 写入数据加载顺序示例:
 

  1. 上电(确保电源轨处于稳定状态并根据 Xilinx Power Estimator 或电源设计管理器指南进行排序)
  2. Versal REF_CLK 专用管脚处于稳定状态
  3. 启动模式专用管脚设置为 SelectMAP (MODE[3:0]=1010)
  4. SMAP_RDWR_b=0 表示写入模式
  5. POR_B 已释放
  6. SMAP_CLK 时钟设置处于稳定状态
  7. SMAP_BUSY 在准备好接受数据时将变为低电平
  8. SMAP_CS_b 已由主机设置,用于启动使能器件并在 SMAP_CLK 的上升沿计时
  9. SMAP_IO 主机开始发送 PDI 数据。SMAP_IO SMAP_CLK 的上升沿计时
  10. 在加载 PDI 数据期间,监视 SMAP_BUSY 断言情况
    • SMAP_BUSY=1 断言有效时,确保 SMAP_CS_b 24 SMAP_CLK 周期内断言无效 (SMAP_CS_b=1)
    • SMAP_BUSY=0 断言无效时,断言 SMAP_CS_b=0 有效以继续加载 PDI 数据
  11. 在最后一项 PDI 数据计时后确认以下内容:
    • SMAP_CS_b 已断言无效
    • 在最后一项 PDI 数据之后至少发出 24 SMAP_CLK 周期,以确保 DONE 变为高电平 


Versal SelectMAP 32 位数据加载波形图:

  1. SelectMAP 数据加载波形图显示了初始数据周期内的 PDI 启动头文件 - 16 字节总线检测模式。
  2. Versal 自适应 SoC 在写入模式下发现 RDWR_B=0 后,将断言 BUSY=0 无效。大多数应用只需加载(写入)SelectMAP 数据,并且可以保留 RDWR_B=0
  3. 发出最后一项 PDI 数据后,设置 CS_B=1 并发送至少 24 SMAP_CLK 周期,以确保 DONE 信号变为高电平。


Versal SelectMAP PDI 16 字节总线检测模式顺序:


Versal SelectMAP 多器件接口示例:

大多数应用都在写入模式下使用 Versal SelectMAP 启动模式。对于不以读取操作为目标的应用,建议将 SMAP_RDWR_b 保持在写入模式 (SMAP_RDWR_b=0)

下面显示了两种 Versal 多器件设置示例。第一个示例显示的控制信号可在上电时或使用相同的 REF_CLK 源时连接在一起。第二个示例表明每个器件的信号都是唯一的,以保证更大的灵活性。

这两种设置都显示了唯一的 SMAP_RDWR_B,这样可防止在不太常见的读取模式用例中出现任何信号争用情况。使用读取模式 (SMAP_RDWR_b=1) 时,无论 SMAP_CS_b 设置如何,数据 I/O 都不会为三态。对于多器件设置,在读取模式下以某个器件为目标时,不属于读取操作目标的器件应保持在写入模式 (SMAP_RDWR_b=0) 下且 SMAP_CS_b=1
 
示例 1.

示例 2.

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

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

相关文章

Spring事务一网打尽

Spring事务一网打尽 什么是事务首先说一个坑Spring 中的事务两种用法三大基础设施编程性事务TransactionManager 实现编程性事务TransactionTemplate 实现编程性事务 声明式事务XML配置声明式事务注解配置声明式事务注解XML混合配置声明式事务 什么是事务 这里要额外补充一点&a…

单片机第三季-第五课:GPIO控制LED

目录 1,GPIO数据手册 1.1,端口配置寄存器 ​1.2,端口输入数据寄存器和端口输出数据寄存器 ​1.3,端口位设置/清除寄存器 1.4,端口位清除寄存器 2,原理图分析和MDK工程 3,写代码通过GP…

快速入门:教你如何使用vue-element-admin 集成框架开发项目(保姆式教学)

设置完中文界面,打开是这样的 端口号更改 嘿嘿,要把项目改成自己的,是不是要更改标题啊 题目更改 src/utils/get-page-title.js src/settings.js 如何添加菜单页面 添加菜单页面(父菜单/子菜单) 效果图 添加自己的页…

Unity--视觉组件(Raw Image,Mask)||Unity--视觉组件(Text,Image)

1.Raw Image 2.mask “”Raw Image:“” Texture:(纹理) 表示要显示的图像的纹理; Color:(颜色) 应用于图像的颜色; Material:(材质&#xff09…

FreeRTOS源码阅读笔记3--queue.c

消息队列可以应用于发送不定长消息的场合,包括任务与任务间的消息交换,队列是 FreeRTOS 主要的任务间通讯方式,可以在任务与任务间、中断和任务间传送信息,发送到 队列的消息是通过拷贝方式实现的,这意味着队列存储…

前端开发项目中使用字体库

开发中有些项目要求使用固定的字体,这就需要项目中使用字体库。 首先需要下载字体库 将下载的字体文件放进项目中 在项目代码样式文件中定义字体 font-face {font-family: "Tobias-SemiBold";src: url("./assets/font/Tobias-SemiBold.ttf"…

arcgis基础篇--实验

一、绘制带空洞的面要素 方法一:先绘制出一个面区域,然后在面上再绘制一个面区域代表面洞,两者位于同一个图层内,选中代表面洞的区域,选择【编辑器】-【裁剪】工具,将面裁剪出一个洞,随后删除代…

jupyter notebook添加markdown目录

jupyternotebook添加markdown目录 1. 安装python包2. 安装JavaScript和CSS文件3. 启用扩展4. 设置markdown选项 1. 安装python包 官方安装 使用pip pip install jupyter_contrib_nbextensions # 或者 pip install https://github.com/ipython-contrib/jupyter_contrib_nbext…

苹果M3处理器跑分曝光,单核无敌!

10月底,苹果发布了全新的M3、M3 Pro、M3 Max芯片以及搭载M3系列芯片的3款新硬件,包括:新款24英寸iMac、新款14/16英寸MacBook Pro。 根据苹果官方介绍,M3系列芯片基于台积电3纳米工艺打造,采用全新图形处理器架构&…

【操作系统内核】线程

【操作系统内核】线程 为什么需要线程 比如我要做一个视频播放器,就需要实现三个功能: ① 从磁盘读取视频数据 ② 对读取到的视频数据进行解码 ③ 对解码的数据进行播放 如果串行执行(通过一个进程来执行): 那么…

视通科技新品发布:4K30分布式编解码一体机,高性价比之选!

随着信息技术的日新月异,各领域对于音视频传输、控制和显示等方面的需求呈现出爆发式的增长。这种需求的增长源于多种因素,包括但不限于高清视频的普及,实时音视频通信的广泛应用,以及各种显示设备的升级换代。 在这样的背景下&a…

动态规划(5)---Leetcode338.比特位计数

题目 给你一个整数 n &#xff0c;对于 0 < i < n 中的每个 i &#xff0c;计算其二进制表示中 1 的个数 &#xff0c;返回一个长度为 n 1 的数组 ans 作为答案。 分析 通常动态规划的做题顺序&#xff0c;先确定dp数组dp[i],然后确定确定递推公式&#xff0c;再dp数…

Gogs安装和部署教程-centos上

0、什么是 Gogs? Gogs 是一款极易搭建的自助 Git 服务。 Gogs 的目标是打造一个最简单、最快速和最轻松的方式搭建自助 Git 服务。使用 Go 语言开发使得 Gogs 能够通过独立的二进制分发&#xff0c;并且支持 Go 语言支持的 所有平台&#xff0c;包括 Linux、Mac OS X、Windo…

华为防火墙2种局域网内远程监控其它端口的方法

防火墙必须要工作在三层&#xff0c;接口上有地址 第一种用ip-link 这种方法是如果监测的接口故障后&#xff0c;自身优先级降低2 FW3 ip-link check enable ip-link 1 destination 1.1.1.1 interface g0/0/0 mode icmp hrp track ip-link 1 active FW4 ip-link check …

Hls学习(一)

1&#xff1a;CPU、DSP、GPU都算软件可编程的硬件 2&#xff1a;dsp在递归方面有所减弱&#xff0c;在递归方面有所增强&#xff0c;比如递归啊等&#xff0c;GPU可以同时处理多个进程&#xff0c;对于大块数据&#xff0c;流处理比较适用 3&#xff1a;为了提高运算量处理更多…

7-Zip的介绍和【阿里云盘】的使用

7zip从入门到入坑 前言一、7-zip的介绍和安装1、基本介绍1&#xff09;7-Zip 主要特征2&#xff09;支持格式3&#xff09;基础功能4&#xff09;安装环境需求 2、基本操作&#xff08;1&#xff09;简便的界面&#xff08;2&#xff09;发生的问题 二、阿里云盘的使用1、“exe…

OSG练习:模仿Ventsim制作三维矿井智能通风系统

1、效果 2、计划内容 1) 三维场景的加载显示;已实现 2)矿井巷道建模及纹理;已实现 3)矿井基础数据采集及修正;已实现 4)通风网络解算算法;已实现 5)通风设备及设施模型制作;未实现 6)风流模拟效果 ;进行中 7)火灾模拟效果;未实现 8)巷道属性查看栏;未实现 9)…

k8s 裸金属集群部署metalLB软负载均衡 —— 筑梦之路

metalLB 官方网站 Repo&#xff1a;https://github.com/metallb/metallb 官网&#xff1a;https://metallb.universe.tf/installation metalLB解决什么问题&#xff1f; MetalLB 是一个用于裸机 Kubernetes 集群的负载均衡器实现&#xff0c;使用标准路由协议。 k8s 并没有为裸…

深度学习 python opencv 火焰检测识别 火灾检测 计算机竞赛

文章目录 0 前言1 基于YOLO的火焰检测与识别2 课题背景3 卷积神经网络3.1 卷积层3.2 池化层3.3 激活函数&#xff1a;3.4 全连接层3.5 使用tensorflow中keras模块实现卷积神经网络 4 YOLOV54.1 网络架构图4.2 输入端4.3 基准网络4.4 Neck网络4.5 Head输出层 5 数据集准备5.1 数…

解锁 PaddleOCR 的超能力

光学字符识别&#xff08;OCR&#xff09;是一项强大的技术&#xff0c;使机器能够从图像或扫描文档中识别和提取文本。OCR 在各个领域都有应用&#xff0c;包括文件数字化、从图像中提取文本以及基于文本的数据分析。在本文中&#xff0c;我们将探讨如何使用 PaddleOCR&#x…