基于Tricore的Tasking链接文件解读

目录

1.链接文件有什么用?

2.文件结构和语法解析

2.1 文件结构

2.2 语法解析

3.小结


玩惯了ld文件,突然让搞lsl,被其中花里胡哨的语法搞晕了,例如:

    memory cpu0_dlmu{mau = 8;size = 64k;type = ram;map     cached (dest=bus:sri, dest_offset=0x90000000,      size=64k);map not_cached (dest=bus:sri, dest_offset=0xb0000000, size=64k,priority=8);}

虽然这个字面意思写的很清楚,但是在链接器实际运行时有什么不一样吗,mau、priority具体表示什么?因此有必要搞一搞其底层原理。

编译原理这里就不多谈了,咱们直接从链接器开始走起。

1.链接文件有什么用?

Tasking 链接器将Linker和Locator集合到一起, Linker阶段主要把 .o文件、lib文件组合成一个可重定位的对象文件,例如.out;Locator主要用于给上述.out文件重新分配绝对地址,并生成目标处理器的文件,例如elf、hex、s19等,总体流程如下图:

在连接过程中,lsl(Linker Script Language)文件起到了非常关键的作用:

  • 确定当前目标处理的内核硬件架构,例如逻辑地址和物理地址的偏移等;
  • 确定当前系统的memory位置,例如RAM、ROM首地址和长度等;
  • 确定代码数据放到memory的什么位置,这也是我们主要关心的点,控制数据代码到指定位置;

有了上述基本了解,我们来看看lsl的一些关键语法。

2.文件结构和语法解析

2.1 文件结构

lsl链接文件主要包含如下几个部分:

  • 内核架构的定义:帮助linker将目标内核的逻辑地址转换为物理地址,可能还包括中断向量表、栈的定义等,一般来说编译器会把这个定义好,例如tc1v1_6_2.lsl;
  • 派生的定义:主要是用于描述内部总线定义、memeory定义等;
  • 处理器的定义:用于定义单核还是多核,以及对应内核实例
  • 段的定义:控制自定义段的具体位置

 框架如下如下:

2.2 语法解析

首先来看几个最常见到但是没有关心过的关键字,以开头代码为例:

  • mau:Minimal Addressable Units,最小可寻址单元,对Tricore来说就是1 byte,对应数字 8;
  • type:指定memory类型,常见的如rom,ram,nvram(任意时刻都可以修改),blockram
  • map:该关键字将源地址转为目的地址,具体映射关系如下:
  • space => space
  • space => bus
  • bus => bus
  • memory => bus

上述几个关键字接下来我们就来分析几个常用的语法。

定义memory的基本格式如下:

memory mem_name
{type = xx;mau = xx;size = 64k;map map_name ( map_description );
}

以定义TC3xx CPU0 DSPR的空间为例,代码如下:

    memory dsram0 // Data Scratch Pad Ram{mau = 8;size = 240k;type = ram;map (dest=bus:tc0:fpi_bus, dest_offset=0xd0000000, size=240k, priority=8);map (dest=bus:sri, dest_offset=0x70000000, size=240k);}

mau = 8,表示最小寻址单位为1 byte;整块memory为240k,属于ram类型;比较好玩的是下面两块map,我们来看第一个:

map (dest=bus:tc0:fpi_bus, dest_offset=0xd0000000, size=240k, priority=8);

目的地是Tricore 0 的FPI 总线,偏移为0xd0000000,size为240k,优先级为8;我们回过头看TC3xx的手册,会发现CH、DH这个Segment是保留的,这就奇怪了,链接文件为什么要定义这个东西?直觉告诉我这个可能和Tricore寻址方式有关系。

 fpi_bus用于将CPU\DMU等高速外设连接至中低带宽外设,对应具体实例为SPB(系统外设额总线)、BBB(ADAS domain相关),位宽32bit;如下图:

其次,针对CH\DH的用途在map中也给出体现,如下 

 

 我们继续翻看5.3.6.1.1章节,详细描述了本地和全局寻址方式。

核内DSPR位置始终为0xD0000000,PSPR为0xC000000,可以理解这是本地地址;而在多核系统中,根据Core ID,PSPR和DSPR分别对应1-7H,这就是所谓的全局地址如下:

但是,还有但是,CPU始终是用全局进行总线传输,意味着即使CPU0从本地DSPR拿数据,仍然使用是的7000000的地址。

所以紧接着定义了关于多核globle的map,如下:

map (dest=bus:sri, dest_offset=0x70000000, size=240k);

那么在链接的时候,linker如何知道用0x7开头还是0xd开头的呢?根据后面的priority优先级来定。

在测试优先级的时候,上面关于DSPR的例子举的不好,因为不管我怎么调优先级都还是用的global地址,除了在调试时将某些指定到本地地址,如下:

 所以换个DLMU来搞,cpu0_dlmu memory定义如下:

memory cpu0_dlmu
{mau = 8;size = 64k;type = ram;map     cached (dest=bus:sri, dest_offset=0x90000000, size=64k);map not_cached (dest=bus:sri, dest_offset=0xb0000000, size=64k);
}

我们将变量放到cpu0dlmu0,在不设置优先级的情况下,编译结果如下:

将not_cached地址优先级提高,结果如下:

这里我们基本可以得出结论:数值越高,优先级越高。

我们将cached\not_cached的代码互换位置,优先级不变,结果如下:

这就很神奇了,好像不是优先级相同,先到先得,而是默认为cached,这是为什么呢?

我们就从这个变量放置的段来找答案,对于section的定义,有两种关键词:

section_setup:定义堆栈、copy、table、启动地址等等

section_setup ::my_space
{reserved address rangestack definitionheap definitioncopy table definitionstart addressspace reference restrictionsinput section modificationssection reference restrictionsMPU data table
}

section_layout:定义一个或者多个section,并赋予section一个地址空间,可以指定运行地址、加载地址,section空间大小等等;可以这样理解,我们写的代码、数据存放位置是在linker里lsl里的section指定,在车规中常常会会将标定数据、信息安全数据等放置到特定位置,因此掌握这部分内容是比较重要的。

实例如下:

仔细看,在示例中section_layout里还定义group了,它包含了一个或者多个input section,因此需要使用语法select 选择section。

在上一个试验中,我们把g_DataTest放到了section lmubss_cpu0,如下图:

该section在lsl链接文件中定义如下:

注意看,此时run_addr为cpu0_dlmu,对应memory:

编译出来是cached地址,那有没有办法让它在non-cached的地址? 

根据lsl说明,使用语法:

group (run_addr = mem:A/map_name)

 修改如下:

编译得到结果如下:

3.小结

上面两节将lsl的基本框架和常用语法进行了梳理,其中比较重要的就是memory定义和section定义,这里最后再总结下如何将数据或者代码放到指定位置:

  1. 首先定义一块memory,使用语法memory name{ },指定map地址,mau,size;
  2. 在section_layout里用group定义运行地址,如有必要定义加载地址;
  3. 代码里在待处理的数据或者代码前后添加限定符#pragma,或者__attribute__ ((section  ".name"))

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

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

相关文章

腾讯中视频计划项目玩法,号称执行就有收入

腾讯中视频掘金计划是一个创新的短视频创作与分享平台,类似于西瓜视频,允许用户发布原创视频内容,并将其同步至腾讯旗下的多个平台,用户基数大,相信视频播放量也会比较大。 操作流程: 1. 注册并登录腾讯中…

深入对比:Transformer与RNN的详细解析

在深度学习领域,特别是在自然语言处理(NLP)中,循环神经网络(RNN)和Transformer模型都扮演着举足轻重的角色。然而,随着技术的不断发展,Transformer模型逐渐崭露头角,成为…

OrangePi 安装 CANN 套件及体验 AI 应用

CANN 环境安装(桌面端跳过) CANN 环境存在于下载页面的官方工具中,点击下载即可进入下载页面。 CANN 安装包就在倒数第二项,下载后传到开发板上。 给 CANN 安装包赋予运行权限并运行即可。 chmod x Ascend-cann-toolkit_7.0.0_l…

MQTT协议使用总结

MQTT是基于TCP/IP协议栈构建的异步通信消息协议,是一种轻量级的发布/订阅信息传输协议MQTT在时间和空间上,将消息发送者与接受者分离,可以在不可靠的网络环境中进行扩展。适用于设备硬件存储空间有限或网络带宽有限的场景。 物联网平台支持设…

2.1.4 采用配置类与注解方式使用MyBatis

实战概述:采用配置类与注解方式使用MyBatis 创建MyBatis配置类 在net.huawei.mybatis.config包中创建MyBatisConfig类,用于配置MyBatis核心组件,包括数据源、事务工厂和环境设置。 配置数据源和事务 使用PooledDataSource配置MySQL数据库连接…

kafka-消费者服务搭建配置简单消费(SpringBoot整合Kafka)

文章目录 1、使用efak 创建 主题 my_topic1 并建立6个分区并给每个分区建立3个副本2、创建生产者发送消息3、application.yml配置4、创建消费者监听器5、创建SpringBoot启动类6、屏蔽 kafka debug 日志 logback.xml7、引入spring-kafka依赖 1、使用efak 创建 主题 my_topic1 并…

DP动态规划(上)

文章目录 动态规划基本概念斐波那契数列问题C 实现Python 实现Java 实现 迷你结C、Python和Java在实现动态规划时有哪些性能差异?迷你结哪种语言在动态规划中更适合大规模数据处理?迷你结C有哪些知名的库适用于动态规划和大数据处理?动态规划辅助库大数据处理库 迷…

【网络协议 | HTTP】HTTP总结与全梳理(一) —— HTTP协议超详细教程

🔥博客简介:开了几个专栏,针对 Linux 和 rtos 系统,嵌入式开发和音视频开发,结合多年工作经验,跟大家分享交流嵌入式软硬件技术、音视频技术的干货。   ✍️系列专栏:C/C、Linux、rtos、嵌入式…

二叉树练习题(2024/6/5)

1翻转二叉树 给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。 示例 1: 输入:root [4,2,7,1,3,6,9] 输出:[4,7,2,9,6,3,1]示例 2: 输入:root [2,1,3] 输出:[2,3,1]…

dirfuzz-web敏感目录文件扫描工具

dirfuzz介绍 dirfuzz是一款基于Python3的敏感目录文件扫描工具,借鉴了dirsearch的思路,扬长避短。在根据自身实战经验的基础上而编写的一款工具,经过断断续续几个月的测试、修改和完善。 项目地址:https://github.com/ssrc-c/di…

运维开发介绍

目录 1.什么是运维开发 2.作用 3.优点 4.缺点 5.应用场景 5.1.十个应用场景 5.2.网站和Web应用程序 6.案例 7.小结 1.什么是运维开发 运维开发(DevOps)是一种结合软件开发(Development)与信息技术运维(Opera…

什么是回调函数?callback()

首先要知道一个点就是 在js中&#xff0c;函数是可以作为函数的参数传递的 所以其实回调函数 就是这个传进去的参数 其实回调函数的本质样子和普通函数是一样的 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8">…

embedding层的理解

一文读懂Embedding的概念&#xff0c;以及它和深度学习的关系 - 知乎 (zhihu.com) 感觉这篇知乎真的大道至简。个人感觉embedding层和普通的线性层没有什么区别~就是为了降维和升维用的。也就是向量的维度变化&#xff01;

基于SOA海鸥优化算法的三维曲面最高点搜索matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 5.完整程序 1.程序功能描述 基于SOA海鸥优化算法的三维曲面最高点搜索matlab仿真&#xff0c;输出收敛曲线以及三维曲面最高点搜索结果。 2.测试软件版本以及运行结果展示 MATLAB2022A版本…

Wireshark抓包工具使用 项目实战

Wireshark 是一个开源的网络协议分析器&#xff0c;它可以让你捕获和分析网络数据包&#xff0c;帮助你诊断网络问题、监控网络流量、分析协议和进行安全审计。以下是一些基本的 Wireshark 用法&#xff1a; 捕获数据包&#xff1a; 打开 Wireshark&#xff0c;选择要捕获数据包…

国外创意二维码营销案例:巴西宠物食品品牌户外活动“救救宠物爪子吧”

2024年5月份&#xff0c;巴西宠物食品品牌Purina Brasil 与广告公司Publicis Brasil合作&#xff0c;推出了一次特别的户外营销活动——Salve as Patinhas(Save the Paws)&#xff08;救救宠物爪子吧&#xff09;&#xff0c;非常有意思&#xff01; 随着全球气候变暖&#xf…

C++240605

设计一个 Per类&#xff0c;类中包含**私有**成员:姓名、年龄、**指针成员**身高、体重&#xff0c; 再设计一个Stu类&#xff0c;类中包含**私有**成员:成绩、 Per类对象p1&#xff0c; 设计这 两个类 的 **构造函数、析构函数**。 #include <iostream>using namespace…

PPT文件损坏且无法读取怎样修复?文档损坏修复方法推荐

PPT文件已经成为工作汇报、商务演示、学术交流以及教学培训中最常用到的文件&#xff0c;随着文件数量的增多和存储设备的频繁使用&#xff0c;我们有时会遇到PPT文件损坏无法打开的情况&#xff0c;这无疑给工作和学习带来了极大的困扰。 PPT文件损坏的原因可能多种多样&#…

VS2022,DLL1调用lib,lib调用DLL2

DLL1调用lib&#xff0c;lib调用DLL2 问题1&#xff1a;为什么在dll1中需要引入dll2的.lib文件 当你有一个工程&#xff08;dll1&#xff09;调用静态库&#xff08;lib&#xff09;&#xff0c;而静态库&#xff08;lib&#xff09;又调用另一个DLL&#xff08;dll2&#xf…

vivado BEL

描述 通常&#xff0c;BEL或基本元素对应于设计的网表视图中的叶单元。 BEL是目标Xilinx FPGA上的设备对象&#xff0c;用于放置或映射基本网表 触发器、LUT和进位逻辑等对象。 BEL在SITE对象&#xff08;如SLICE和IO块&#xff09;中的设备上分组在一起 &#xff08;IOB&#…