XCP

目标

本集成手册用于指导客户进行XCP集成,文档主要包括的内容为:协议栈集成指导、基于普通应用的集成示例讲解、项目集成特殊说明。

由于各项目的需求不同,集成示例不会针对于特定的商业项目做详细讲解。

缩写词和术语

表 缩写词和术语

缩写词/术语

描述

CanIf

Can Interface Can通信的接口模块

XCP

Universal Calibration Protocol 标定协议栈模块

参考文档

[1] 参考手册_XCP.pdf

[2] 集成手册_CAN通信.pdf

协议栈集成

项目交付的内容为:XCP标定协议栈源码和ORIENTAIS Studio配置工具。协议栈细分为协议栈的各模块及其对应的配置工具模块。

XCP标定协议栈各配置模块的功能介绍。

使用协议栈源码和配置工具,进行协议栈的集成的步骤,参见表 XCP标定协议栈集成的步骤。

表 XCP标定协议栈各配置模块介绍

模块名

功能

Can

CAN驱动配置。

CanIf

CanIf模块主要处理上层模块与底层驱动的之间PDU的传递,为上层模块提供统一的接口来管理不同的CAN硬件模块

EcuC

用于辅助配置工具完成配置的模块。主要提供Pdu的定义,其它模块通过关联EcuC中Pdu,相互关联起来。

Xcp

Xcp模块是标定协议栈

表 XCP标定协议栈集成的步骤

步骤

操作

说明

1

ORIENTAIS Stuido配置工具工程搭建和协议栈模块加载

若配置工具已经搭建,则仅需进行协议栈模块的加载操作。

2

模块配置及配置文件生成

NA

3

代码集成

现有工程、协议栈源代码和配置生成文件的集成。

4

验证测试

NA

Note

协议栈集成之前,用户须确保已经有基础工程,且本协议栈相关的其他协议栈能正常工作。

新建ORIENTAIS Studio配置工程及模块加载

  1. 安装ORIENTAIS Studio软件后,双击软件图标打开软件。

    image1

    图 新建工程-1

  2. 菜单栏File🡪New🡪Project,新建工程。

    image2

    图 新建工程-2

  3. 在弹出的新建窗口中选择Autosar下的 [BSW Project],选择Next。

    image3

    图 新建工程-3

  4. 在弹出的窗口中输入工程名,选择Finish。

    image4

    图 新建工程-4

  5. 在弹出的窗口中选择Yes。

    image5

    图 新建工程-5

  6. 选择[Bsw_Builder],右键单击,选择New ECU Configuration。

    image6

    图 新建工程-6

  7. 在弹出的窗口中输入ECU名,然后选择Next。

    image7

    此处以TC397为例,

    用户根据项目芯片进行选择。

    图 新建工程-7

  8. 在弹出的窗口中勾选需添加的模块,点击Finish。

    image8

    图 新建工程-8

  9. 新建工程如下所示,上一步添加的模块已经被加入到工程中。

    image9

    图 新建工程-9

模块配置及生产代码

模块配置

模块的具体配置,取决于具体的项目需求。该协议栈各模块配置项的详细介绍,参见错误!未找到引用源。

表 协议栈各模块配置参考文档

模块

参考文档

说明

Can

MCAL对应的Can配置手册

CanIf

参考手册_Can通信.pdf

EcuC

参考手册_Can通信.pdf

XCP

参考手册_XCP.pdf

配置代码生成

  1. 在ORIENTAIS Stuido主界面左方,选择对应的协议栈,单击右键弹出Validate All和Generate All菜单。

    image10

    图 配置代码的生成-1

  2. 选择Validate All对本协议栈各配置选项进行校验,没有错误提示信息即校验通过。若有错误信息,请按照错误提示修改。

  3. 选择Generate All,生成配置文件。右下角的Console窗口输出生成的配置文件信息。

    image11

    图 配置代码的生成-2

  4. 将ORIENTAIS Studio切换到Resource模式,即可查看生成的配置文件。

    image12

    图 配置代码的生成-3

功能集成

代码集成

协议栈代码包括两部分:项目提供的协议栈源码和ORIENTAIS Studio配置生成代码。

用户须将协议栈源码和章节(配置代码生成)生成的源代码添加到集成开发工具的对应文件夹。协议栈集成的文件结构,见章节(源代码集成)。

Note

协议栈集成之前,用户须确保已经有基础工程,且本协议栈相关的其他协议栈能正常工作。

集成注意事项

对于集成过程中,协议栈特殊要求和用户经常出现的问题,归类总结形成 表 协议栈集成约束清单。用户需逐一排查表中的约束项,以避免集成问题出现。

表 XCP标定协议栈集成约束清单

编号

类别

约束限制

1

堆栈

用户需确保为任务堆栈和中断堆栈分配足够的堆栈空间。尤其是需要使用RAM来实现页切换功能

2

头文件

  • 添加协议栈代码之后,用户需更新集成开发工具中的头文件路径。

  • 调用协议栈API的源文件,需要包含协议栈的头文件。

3

初始化

Xcp_Init,这个初始化没有实际上的顺序,只需要保证在周期函数调用前被调用即可。

4

周期函数

Xcp_MainFunction需要保证是在10ms或者更短周期任务内被调用,Xcp_EventIndication这个API需要被所配置的DAQ的时间周期的周期性任务调用。

5

系统文件(.ld)

需要在系统文件内,将标定协议栈所使用的RAM和FLASH独立出来,并且将FLASH的地址重载到RAM。

6

A2L文件

合成CANape能使用的A2L文件

集成示例

本章节通过XCP标定协议栈为例,向用户展示XCP标定协议栈的集成过程。用户可以据此熟悉XCP标定协议栈配置工具的配置过程,以及如何应用配置工具生成的配置文件。

为让用户更清晰的了解工具的使用,所用的配置均逐一手动完成。关于Can驱动的配置,请参考Can配置手册。CanIf配置的具体操作请参照《参考手册_XCP.pdf》。

Note

本示例不代表用户的实际配置情况,用户需要根据自己的实际需求,决定各个参数的配置。

集成目标

客户能通过第三方标定工具(CANape或INCA)对汽车电子电控单元进行参数标定,为其提供数据标定、数据上传及相关通信服务的软件模块。同时,还可以为用户提供基于XCP协议的Flash刷写功能。软件模块运行在汽车电子电控单元系统中,实现标定工具与电控单元的主-从通讯,执行标定工具发出的各项命令,完成基于CAN通信协议的数据上传和数据标定。

XCP模块必须实现参数在线标定、数据同步上传、数据同步(STIM)下载三大功能组;支持DAQ列表动态配置、数据时间戳传输、数据块传输模式、Bypassing、Seed&Key解锁和Resume等功能。同时支持Flash刷写命令组。根据AUTOSAR标准及开发目的XCP协议栈需要实现的命令如下表所示。其中命令名后有*的是可选命令。标定协议栈主要包含三个部分

表 XCP标定协议栈命令实现清单

命令组

命令名

是否实现

标准命令组

CONNECT

DISCONNECT

GET_STATUS

SYNCH

GET_COMM_MODE_INFO*

GET_ID*

SET_REQUEST*

GET_SEED*

UNLOCK*

SET_MTA*

UPLOAD*

SHORT_UPLOAD*

BUILD_CHECKSUM*

TRANSPORT_LAYER_CMD*

GET_SLAVE_ID*

GET_DAQ_ID*

SET_DAQ_ID*

USER_CMD*

标定命令组

DOWNLOAD

DOWNLOAD_NEXT*

DOWNLOAD_MAX*

SHORT_DOWNLOAD*

MODIFY_BITS*

页切换命令组

SET_CAL_PAGE*

GET_CAL_PAGE*

GET_PAG_PROCESSOR_INFO*

GET_SEGMENT_INFO*

GET_PAGE_INFO*

SET_SEGMENT_MODE*

GET_SEGMENT_MODE*

COPY_CAL_PAGE*

DAQ/STIM基本命令组

SET_DAQ_PTR

WRITE_DAQ

SET_DAQ_LIST_MODE

START_STOP_DAQ_LIST

START_STOP_SYNCH

WRITE_DAQ_MULTIPLE*

READ_DAQ*

GET_DAQ_CLOCK*

GET_DAQ_PROCESSOR_INFO*

GET_DAQ_RESOLUTION_INFO*

GET_DAQ_LIST_MODE*

GET_DAQ_EVENT_INFO*

静态DAQ配置命令组

CLEAR_DAQ_LIST

GET_DAQ_LIST_INFO*

动态DAQ配置命令组

FREE_DAQ

ALLOC_DAQ

ALLOC_ODT

ALLOC_ODT_ENTRY

Flash刷写命令组

PROGRAM_START

PROGRAM_CLEAR

PROGRAM

PROGRAM_RESET

GET_PGM_PROCESSOR_INFO*

GET_SECTOR_INFO*

PROGRAM_PREPARE*

PROGRAM_FORMAT*

PROGRAM_NEXT*

PROGRAM_MAX*

PROGRAM_VERIFY*

备注:PROGRAM这部分的命令适用于基于XCP的Bootloader。

模块的配置

新建配置工程及模块加载操作,请参考本文档章节(模块配置及代码生成)。

XCP模块配置

  1. 双击XCP模块,打开XCP模块的配置界面。

    image13

    图 XcpGeneral配置界面

  2. 在XcpGeneral下,有Bus Interface Select、Optional API、DAQ Format和General Settings四个配置项。

    如果总线类型为ETH,则XcpSupportType则需要选择XcpOnEthernetEnabl ed,且XcpMaxCto和XcpMaxDto也需要同步适配为ETH报文长度。

    在DAQ Format和General Settings中,按照图示配置DAQ为动态,保存 的buffer为1024。DAQ的overload不需要Indication。XCP的配置生成的 a2l文件是供CANape使用。不需要timestamp。

    若需要使用polling模式,则需要打开XcpMeasurementPollingSupport开关, 同时需要在XcpSegmentInfo页中配置观测地址。

    image14

    图 XcpCommand配置界面

  3. XcpCommand配置,该配置是根据情况勾选所需要的实现的XCP的命令。一般为了安全起见,PGM的功能都是不需要的。该功能是供XCP的Bootloader使用的。

    image15

    图 XcpConfig配置界面-1

  4. XcpComfig中XcpPdus配置:

    XcpRxPdu中的XcpRxPduRef选择Xcp_Cmd(配置在EcuC中)

    XcpTxPdu中的XcpTxPduRef选择Xcp_Rsp(配置在EcuC中)

  5. XcpComfig中XcpDaqList配置:

    将XcpDaqList->XcpDtos->XcpDto中的XcpDto2PduMapping选择XcpTxPdu。

    image16

    图 XcpConfig配置界面-2

    image17

    图 XcpSegmentInfo配置界面-1

    image18

    图 XcpSegmentInfo配置界面-2

  6. XcpMeasuremenAddr的地址是当前芯片RAM的所有观测量有效地址。默认是整个RAM如图5-5,在有观测区间或者打开polling模式时,需要根据实际情况填写,如5-6。

    XcpSegmentInfo标签页下有一个顶层的容器[XcpSegmentInfos],容器 [X cpSegmentInfos]有一个子容器[XcpSegmentInfo]。在子容器[XcpSegm en tInfo]右边的配置项根据客户需要进行填写。

    image19

    图 XcpSegmentInfo配置界面-3

    在容器[XcpSegmentInfo]下有子容器[XcpPageInfo],右边的配置项根据客户 需求进行填写。右边填写的是,标定变量在FLASH和RAM中的地址以及 大小。

    image20

    图 XcpSectorInfo配置界面

  7. XcpSectorInfo标签页下有一个顶层的容器[XcpSectorInfos],点右边可以新建子容器[XcpSectorInfo]。

    image21

    图 XcpSectorInfo配置界面

  8. 点击容器[XcpSectorInfo],右边的配置项根据客户需要进行配置。Sector的界面主要是配置FLASH的擦写的地址信息。由于Flash擦除的时候需要整个sector擦除,因此有可能存在擦除的地址长度跟标定的使用的地址长度不一致的情况。

源代码集成

项目交付给用户的工程结构如下:

image22

图 工程结构目录

  • Bsw_Config目录,这个目录用来存放配置工具生成的配置文件,Xcp有关的配置文件放在Bsw_Config文件夹下。

  • BSW目录,存放BSW相关模块的源代码.

XCP标定协议栈源代码集成步骤如下:

  1. 将章节中MCAL生成的CAN模块配置文件和ORIENTAIS Studio生成 的配置文件复制到Config\Mcal_Config文件夹中;

  2. 将MCAL提供的CAN模块源码和项目提供的协议栈源代码文件复制到BS W\Mcal文件夹中。

协议栈调度集成

XCP标定协议栈调度集成步骤如下:

  1. 协议栈调度集成,需要逐一排查并实现表 协议栈集成约束清单 所罗列的问题,以避免集成出现差错。

  2. 编译链接代码,将生成的elf文件烧写进芯片。

XCP标定协议栈有关的代码,在下方的main.c文件中给出重点标注。

Note

本示例中, XCP标定协议栈初始化的代码和启动通信的代码置于main.c文件,并不代表其他项目同样适用于将其置于main.c文件中。

 1#include <machine/wdtcon.h>
 2#include "Mcu.h"
 3#include "Port.h"
 4
 5// XCP标定协议栈相关模块头文件
 6#include "Can_17_MCanP.h"   // CAN硬件驱动
 7#include "CanIf.h"          // CAN接口适配
 8#include "Xcp.h"            // XCP核心模块
 9#include "Xcp_Test.h"       // XCP测试模块
10
11int main(void)
12{
13    /* 初始化ECUM模块 */
14    EcuM_Init(&EcuM_ConfigAlternative[0]);
15
16    /* 初始化FlsLoader */
17    FlsLoader_Init(NULL_PTR);
18
19    // 初始化Can、CanIf、Xcp模块
20    Can_17_MCanP_Init(&Can_17_MCanP_ConfigRoot[0]);  // CAN硬件初始化
21    CanIf_Init(&CanIf_InitCfgSet);                   // CAN接口初始化
22    Xcp_Init(&XcpConfig);                            // XCP模块初始化
23
24    // 打开通信(启动CAN控制器)
25    CanIf_SetControllerMode(0, CANIF_CS_STARTED);
26
27    // 配置1ms定时器
28    Gpt_EnableNotification(GptConf_GptChannel_Gpt_1ms);
29    Gpt_StartTimer(GptConf_GptChannel_Gpt_1ms, 100000);
30
31    /* 无限循环 */
32    while (1)
33    {
34        if (Gpt_1msFlag == TRUE)
35        {
36            Gpt_1msFlag = FALSE;
37        }
38
39        if (Gpt_10msFlag == TRUE)
40        {
41            // XCP模块周期处理函数
42            Xcp_MainFunction();  // 处理XCP协议栈周期任务
43
44            // 测试代码:根据标定数据计算观测数据大小
45            DaqChangeTest();
46
47            // DAQ10ms的周期处理函数
48            Xcp_EventIndication(0);
49
50            Gpt_10msFlag = FALSE;
51        }
52    }
53    return 1;
54}

代码集成过程中会涉及到标定变量ROM和RAM的区域划分,标定变量需要设置ROM和RAM两个区域,观测量只涉及RAM区域,将划分好地址区域放到工程的链接文件Lcf_Gnuc_Tricore_Tc.ld中。以下是地址划分时需要注意的项(配置工具ORIENTAIS Studio V4.2,编译器HighTec Development Platform Version 2.3.1)。

  1. Memory中根据标定所需的大小划分RAM和ROM起始地址及地址长度。

    image23

    图 标定量和观测量RAM和ROM划分参考图

V在链接文件中标定对象地址要定义为禁止软件优化且不可更改的地址,

观测对象要配置为禁止软件优化的变量,为了防止代码被工具优化,可 以使用volatile定义标定和观察量;

image24

图 标定量和观测量定义参考图

  1. 在链接文件中创建clear和copy表,分别告诉启动代码要清除和复制的

地址区域。

image25

图 clear和copy表创建参考图

image26

图 相关地址名称定义参考图

Note

本章节属于不同的编译器或者同一种编译不同版本都会不一样,在此仅供参考

验证结果

根据集成目标,能够跟CANape正常通信,以下是验证结果:

image27

图 时间同步模块验证结果