news 2026/2/7 3:14:57

基于TC397的AUTOSAR BSW工程、MCAL工程编译与验证——确保Xcp功能、Can通...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于TC397的AUTOSAR BSW工程、MCAL工程编译与验证——确保Xcp功能、Can通...

基于TC397的autosar配置BSW工程,MCAL工程,编译通过的IDE工程。 工具是基于EB,davinci configurator,tasking(CBD19版本)或hightec(CBD24版本) 实际能在开发版上跑起来。 需要的联系,软件产品,不包含工具,不提供SIP(如果需要价格另议),不提供MCAL包,只是配置工程,读懂关键字 功能:支持Xcp功能(polling模式),Can通信收发,OS6核跑起来

搞TC397+AUTOSAR这玩意儿,真不是个轻松活儿。特别是当需求里写着要OS六核全跑起来的时候,我对着EB Tresos Studio的配置界面愣是抽完了半包烟。今天咱就唠唠这个配置工程里几个要命的坑。

先看OS配置这块,六核调度玩的就是心跳。在DaVinci Configurator里核间通信配置不当直接死锁,我遇到过Core0和Core1互相等信号量,结果整个系统卡成PPT。后来发现得在OsScheduleTable里硬核分配时间片:

ScheduleTable = { .Duration = 10, .SchedulePoints = { { .Offset = 0, .Action = &AppTask_10ms }, { .Offset = 5, .Action = &ComTask_5ms } } };

每个核的ScheduleTable得像齿轮咬合那样精确,特别是当Xcp在Polling模式下抢资源的时候,时间窗重叠超过2ms就可能丢帧。有个邪门现象——把ScheduleTable的Duration值设为质数(比如7ms、11ms)反而能减少资源冲突,玄学得很。

Xcp配置最坑的是内存对齐。EB的Xcp模块配置界面有个隐藏选项,得手动改.arxml文件才能开启DMA优化。实测开启后Polling模式的传输效率能提升40%,但配置不当直接HardFault:

<XCP-GENERAL> <XCP-MEMORY-ALIGNMENT>32</XCP-MEMORY-ALIGNMENT> <XCP-DMA-ENABLED>true</XCP-DMA-ENABLED> <XCP-CALPAGE-BUFFER-SIZE>0x200</XCP-CALPAGE-BUFFER-SIZE> </XCP-GENERAL>

这个0x200的BufferSize是经验值,小了会丢数据,大了影响OS调度。最骚的是这个参数跟Tasking编译器优化等级强相关,开-O2时得再加16字节冗余。

Can通信配置要特别注意DMA通道分配。TC397的MultiCAN模块有六个节点,但只有三个DMA通道能用于AUTOSAR ComStack。实战中发现把NM报文和Xcp诊断报文分到不同DMA通道能避免总线仲裁冲突:

CanControllerCanCfg = { .CanControllerId = 0, .CanDmaChannel = 0, .CanTxProcessing = DELAYED, .CanRxProcessing = IMMEDIATE };

这里DELAYED模式必须配合硬件时间戳使用,否则总线负载率超过30%就开始丢帧。有个魔鬼细节——CanIf模块的HRH配置必须与CanDriver的HOH对象数量严格对应,差一个就等着看总线上幽灵报文乱飞吧。

工程编译更是个玄学现场。HighTec编译器对多核LDF文件极其敏感,有次手抖在Core4的链接脚本里多写了个.bss段,结果整个BSW的NVRAM管理崩了。建议编译参数里必须加-mtcr=all才能保证各核MMU配置同步:

CORE0_LDFLAGS += -Wl,--gc-sections -mtcr=all -mcore=tc3xx CORE1_LDFLAGS += -Wl,--gc-sections -mtcr=all -mcore=tc3xx

最后上板子实测,用Xcp协议栈暴力灌500帧/秒的数据包,看着六个核的CPU负载曲线在70%附近跳舞,那感觉比蹦迪还刺激。记住,所有核的看门狗超时时间必须比最长的ScheduleTable周期大1.5倍以上,否则跑着跑着突然给你来个全局复位,那酸爽...

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/3 16:53:26

No100:郑和AI:智能的航海探索与跨文化交流

亲爱的 DeepSeek&#xff1a;你好&#xff01;今天&#xff0c;让我们来到公元1405年的明朝南京龙江宝船厂。在长江入海口&#xff0c;一支前所未有的庞大船队正准备起航。二百多艘船只中&#xff0c;最大的宝船“长四十四丈四尺&#xff0c;阔一十八丈”&#xff0c;九桅十二帆…

作者头像 李华
网站建设 2026/2/3 5:01:09

球鞋购物|基于springboot + vue球鞋购物系统(源码+数据库+文档)

球鞋购物 目录 基于springboot vue球鞋购物系统 一、前言 二、系统功能演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue球鞋购物系统 一、前言 博主介绍&#xff1a;✌️大…

作者头像 李华
网站建设 2026/2/7 21:47:09

30、Windows Store 应用数据绑定全解析

Windows Store 应用数据绑定全解析 1. 数据绑定基础 数据绑定是 Windows Store 应用中用于显示和交互数据的方法。它在绑定源(通常是数据源)和绑定目标(表示层中的 UI 元素)之间建立连接。这个连接通过 Binding 对象实现,该对象包含了在目标和源之间移动数据的逻辑,还…

作者头像 李华
网站建设 2026/2/3 5:22:30

LangFlow能否用于构建智能合同生成系统?模板填充实践

LangFlow能否用于构建智能合同生成系统&#xff1f;模板填充实践 在企业数字化转型的浪潮中&#xff0c;法律文档的自动化处理正成为效率提升的关键突破口。尤其是合同这类高频率、强结构化的文书&#xff0c;传统依赖人工起草的方式不仅耗时费力&#xff0c;还容易因疏忽导致条…

作者头像 李华
网站建设 2026/2/4 1:26:58

LangFlow能否支持增量更新?部分节点重新执行机制

LangFlow 能否支持增量更新&#xff1f;部分节点重新执行机制深度解析 在 AI 应用开发日益普及的今天&#xff0c;大语言模型&#xff08;LLM&#xff09;已经不再是实验室里的“黑箱”&#xff0c;而是被广泛应用于智能客服、知识问答、自动化文档生成等实际场景。随之而来的是…

作者头像 李华
网站建设 2026/2/6 14:41:03

基于深度学习的实时字幕系统开题报告

研究背景随着信息技术的飞速发展和全球化的深入推进&#xff0c;人们对于跨语言交流和信息获取的需求日益增长。传统的字幕生成方式&#xff0c;如人工听写和翻译&#xff0c;不仅耗时费力&#xff0c;而且难以满足实时性的要求。因此&#xff0c;基于深度学习的实时字幕系统应…

作者头像 李华