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

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

3天内不再提示

自定义RISC V的bootloader-v2

XL FPGA技术交流 来源:XL FPGA技术交流 作者:XL FPGA技术交流 2024-10-31 12:37 次阅读

在生成SoC时,会生成一个预定义bootloader .bin文件,用于指定soc的工程运行的地址,这包括在flash的存储地址 ,加载到外存中的运行地址及在外存中分配的存储空间的大小 。下面我们来讲解下怎样定义自己的bootloader

在外部存储的Bootloader

1、导入软件自带的bootloader工程,在工程中选择bootloaderConfig.h文件。

1465de58-971c-11ef-a79e-92fbcf53809c.png

2、修改参数

USER_SOFTWARE_MEMORY:对应的是APP在外部存储器中的运行起始地址;USER_SOFTWARE_FLASH:对应APP在flash中的存储地址;USER_SOFTWARE_SIZE:APP对应片外存储的大小;

如下是一个设置案例,也可以根据自己的需要进行相应的修改:

把下面参数

#define USER_SOFTWARE_MEMORY 0x00001000#define USER_SOFTWARE_FLASH    0x380000#define USER_SOFTWARE_SIZE     0x01F000

修改成:

#define USER_SOFTWARE_MEMORY 0x00008000#define USER_SOFTWARE_FLASH    0x500000#define USER_SOFTWARE_SIZE     0x01F000

3、编译修改后的工程。接下来会有两种方法处理。

方法一:

4、重新生成存储器初始化文件。

(1)路径转到efinty安装路径的bin文件夹下,运行setup.bat,然后重新生成OCR初始文件。

${EFINITY_HOME}/bin/setup.bat

(2)再转到embedded_sw//tool路径下,并把bootloader.bin文件拷贝到该文件夹下,运行指令,打开浮点生成8个bin,f设置为1

python3 binGen.py -b bootloader.bin -s  -f 

1491c2e8-971c-11ef-a79e-92fbcf53809c.png

(3)生成的初始化bin文件在tool/rom文件夹下;

149b287e-971c-11ef-a79e-92fbcf53809c.png

5、将步骤4中的rom文件夹里的bin替换工程中的bin文件

14a46e70-971c-11ef-a79e-92fbcf53809c.png

----------------------------------------------------------------------

方法二:

4、勾选Cache/Memory下sapphire IP中Overwrite the default SPI flash bootloader with the user application前面的对勾。并添加上第3步生成的bootloader.hex文件.

14b2d3b6-971c-11ef-a79e-92fbcf53809c.png

5、重新生成IP并编译。

--------------------------------------------------------------------

6、重新编译工程。合成工程时注意指定的Flash地址.

14d2c414-971c-11ef-a79e-92fbcf53809c.png

这里有一个问题,修改flash的地址是多少合适呢?以Ti60F100为例 ,内部合封了一个16Mb的flash,0x38000这个地址是超出范围的,那RISCV的地址应该放上哪些呢,从上面的合并操作中可以看到soc.hex文件的Flash Length为0x00362c95,那memTest.bin的地址只要保证不重合,也就是大于0x00362c95即可。

另外值的强调的是逻辑工程生成的hex文件放在flash地址必须要从0x0开始。

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

    关注

    10

    文章

    1612

    浏览量

    147622
  • soc
    soc
    +关注

    关注

    38

    文章

    4076

    浏览量

    217647
  • bootloader
    +关注

    关注

    2

    文章

    234

    浏览量

    45484
  • RISC-V
    +关注

    关注

    44

    文章

    2193

    浏览量

    45922
收藏 人收藏

    评论

    相关推荐

    如何使用RISC-V创建自定义处理器

    采用RISC-V来替代其自定义体系结构。该体系结构吸引人的一个关键特征是,CPU开发人员可以在不牺牲为基本标准创建的工具和库的适用性的情况下,使RISC-V功能适应其需求。适应的关键在于了解R
    的头像 发表于 04-14 15:55 4087次阅读
    如何使用<b class='flag-5'>RISC-V</b>创建<b class='flag-5'>自定义</b>处理器

    请问RISC-V自定义指令如何保持软件的兼容性?

    请问RISC-V自定义指令如何保持软件的兼容性?
    发表于 06-17 07:51

    1602自定义字符

    1602液晶能够显示自定义字符,能够根据读者的具体情况显示自定义字符。
    发表于 01-20 15:43 1次下载

    EDK中PS2自定义IP

    Xilinx FPGA工程例子源码:EDK中PS2自定义IP
    发表于 06-07 11:44 4次下载

    自定义视图组件教程案例

    自定义组件 1.自定义组件-particles(粒子效果) 2.自定义组件- pulse(脉冲button效果) 3.自定义组件-progr
    发表于 04-08 10:48 14次下载

    如何看待RISC-V SoC设计中自定义扩展的指令集架构

    谈论配置基本处理器或添加自定义扩展以解决片上系统 (SoC) 中的硬件-软件设计权衡并不是什么新鲜事。这一直是 RISC-V 社区所支持的价值主张的关键部分,发布了许多信息并从中受益,例如
    发表于 07-18 15:38 2030次阅读
    如何看待<b class='flag-5'>RISC-V</b> SoC设计中<b class='flag-5'>自定义</b>扩展的指令集架构

    ArkUI如何自定义弹窗(eTS)

    自定义弹窗其实也是比较简单的,通过CustomDialogController类就可以显示自定义弹窗。
    的头像 发表于 08-31 08:24 2078次阅读

    教程 2自定义配置文件示例

    教程 2自定义配置文件示例
    发表于 03-13 19:33 0次下载
    教程 <b class='flag-5'>2</b>:<b class='flag-5'>自定义</b>配置文件示例

    教程 2:添加特征-自定义配置文件创建

    教程 2:添加特征 - 自定义配置文件创建
    发表于 03-15 19:39 0次下载
    教程 <b class='flag-5'>2</b>:添加特征-<b class='flag-5'>自定义</b>配置文件创建

    自定义算子开发

    一个完整的自定义算子应用过程包括注册算子、算子实现、含自定义算子模型转换和运行含自定义op模型四个阶段。在大多数情况下,您的模型应该可以通过使用hb_mapper工具完成转换并顺利部署到地平线芯片上……
    的头像 发表于 04-07 16:11 2679次阅读
    <b class='flag-5'>自定义</b>算子开发

    教程 2自定义配置文件示例

    教程 2自定义配置文件示例
    发表于 07-04 20:50 1次下载
    教程 <b class='flag-5'>2</b>:<b class='flag-5'>自定义</b>配置文件示例

    教程 2:添加特征-自定义配置文件创建

    教程 2:添加特征 - 自定义配置文件创建
    发表于 07-06 18:50 0次下载
    教程 <b class='flag-5'>2</b>:添加特征-<b class='flag-5'>自定义</b>配置文件创建

    Out项目之增强RISC-V处理器性能的自定义硬件模块

    电子发烧友网站提供《Out项目之增强RISC-V处理器性能的自定义硬件模块.zip》资料免费下载
    发表于 07-11 10:48 0次下载
    Out项目之增强<b class='flag-5'>RISC-V</b>处理器性能的<b class='flag-5'>自定义</b>硬件模块

    RISC-V自定义计算 – 构建您的抱负

    RISC-V自定义计算 – 构建您的抱负演讲ppt分享
    发表于 07-14 17:15 0次下载

    labview超快自定义控件制作和普通自定义控件制作

    labview超快自定义控件制作和普通自定义控件制作
    发表于 08-21 10:32 11次下载