- CANoe_UDS-booroader 自动化测试系列(一)创建一个CANoe测试工程(测试节点的选选择)
- CANoe_UDS-booroader 自动化测试系列(二)基本刷写流程
- CANoe_UDS-booroader 自动化测试系列(三)基本功能:CAPL实现UDS协议下的CAN报文接收#解析#发送
- CANoe_UDS-booroader 自动化测试系列(四)基本功能:CAPL实现#10服务会话控制
- CANoe_UDS-booroader 自动化测试系列(五)基本功能:CAPL实现#27服务安全解锁
- CANoe_UDS-booroader 自动化测试系列(六)基本功能:CAPL实现bin文件数据解析
- CANoe_UDS-booroader 自动化测试系列(七)基本功能:CAPL实现#34#36#37服务#数据下载
- CANoe_UDS-booroader 自动化测试系列(八)基本功能:CAPL实现#31服务#例程控制
- CANoe_UDS-booroader 自动化测试系列(九)基本功能:CAPL实现#22#2E服务#DID读写
- CANoe_UDS-booroader 自动化测试系列(十)基本功能:CAPL实现#28#85服务#预编程操作
- CANoe_UDS-booroader 自动化测试系列(十一)基本功能:CAPL实现CRC数据校验
- CANoe_UDS-booroader 自动化测试系列(十二)基本功能:CAPL实现pane面板制作
- CANoe_UDS-booroader 自动化测试系列(十三)CAPL框架下的全流程测试
一、前言
hello,大家好,我是小鸟鹏。
今天给大家介绍一下CAPL中如何一键通过#0x27安全访问,要注意的是安全解锁的算法我没有做成链接库,而是把算法直接写在CAPL脚本里面,这个可以根据自己需求自行决定,我是嫌麻烦所以没有做。
二、服务介绍
1.服务请求
服务请求的基本格式:
**
<SID> + <Sub-function> + <Parameter>
**
**
<SID> + <Parameter>
**
#请求种子
#请求密钥
2.子功能
不同安全级别的请求种子和发送密钥是一一对应的,相邻的一对奇偶数对应一种安全级别,其中奇数代表请求种子,偶数代表发送密钥。
比如:
【0x01】与【0x02】是一对组合,0x01是请求种子,0x02是请求密钥;
【0x11】与【0x12】是一对组合,0x11是请求种子,0x12是请求密钥;
3.服务响应
#肯定响应
基本格式:
**
<SID + 0x40> + <Sub-function> + <Parameter>
**
**
<SID + 0x40> + <Parameter>
**
#否定响应
基本格式:
**
<0x7F> + <SID> + <NRC>
**
看起来比较简单,格式比较固定,只要是Negative Response,第一字节就是0x7F,第二字节照抄原来的SID,第三个字节是错误响应码,具体响应码对应的错误信息如下图:
需要注意的是:0x7Fxx0x78这个特殊的响应码。
三、CAPL实现#0x27
#0x27服务
void SID27_SecurityAccess(byte responsecode,long id ,byte subfunction,struct CANTP_INFO_ST data)
{
byte i;
byte TempData[256];
byte TempLen;
TempLen = 0;
TempData[TempLen++]= 0x27;
TempData[TempLen++]= subfunction;
if(0 != data.TpSduLength)
{
for(i = 0; i < data.TpSduLength; i++)
{
TempData[TempLen++] = data.TpSduDataBuf[i];
}
}
DiagnosticServiceSend(responsecode,id,TempLen,TempData);//发送函数
}
#一键通过安全访问
void Access_Unclock(void)
{
dword AccKey;
dword Seed4Byte;
struct CANTP_INFO_ST stData;
stData.TpSduLength = 0;
Seed4Byte = 0;
SID27_SecurityAccess(0x67,PHYSICS_ID_DEFAULT,0x11,stData);
if(0x67 == g_stTpRxInfo.TpSduDataBuf[0])
{
if (0x11 == g_stTpRxInfo.TpSduDataBuf[1])
{
Seed4Byte |= (((dword)g_stTpRxInfo.TpSduDataBuf[2]) << 24) + (((dword)g_stTpRxInfo.TpSduDataBuf[3]) << 16) +
(((dword)g_stTpRxInfo.TpSduDataBuf[4]) << 8) + ((dword)g_stTpRxInfo.TpSduDataBuf[5]);
}
else
{
}
AccKey = SecM_AccessKeyGet(Seed4Byte);
stData.TpSduDataBuf[0] = (AccKey >> 24) & 0xFF;
stData.TpSduDataBuf[1] = (AccKey >> 16) & 0xFF;
stData.TpSduDataBuf[2] = (AccKey >> 8) & 0xFF;
stData.TpSduDataBuf[3] = (AccKey) & 0xFF;
stData.TpSduLength = 4;
SID27_SecurityAccess(0x67,PHYSICS_ID_DEFAULT,0x12,stData);
}
}
四、总结
这篇文章简单介绍了#0x27服务的知识,以及通过CAPL实现#0x27服务。利用这几篇文章的知识,搭建一个基本的UDS测试框架做一些基本的测试是完全没问题的。下一篇我打算介绍CAPL如何结合面板组件加载和解析.bin文件,码字不易,求个三连。
下一篇:
CANoe_UDS-booroader 自动测试系列(六)基本功能:CAPL实现bin文件数据解析
如果这篇博客对你有帮助,请 “点赞” “评论”“收藏”一键三连 哦!码字不易,大家的支持就是我坚持下去的动力。
作者:小鸟鹏
联系方式:
版权归原作者 小鸟鹏嵌入式 所有, 如有侵权,请联系我们删除。