This commit is contained in:
sunbeam 2022-07-06 16:55:12 +08:00
parent b55d450a81
commit f8de166289
8 changed files with 155 additions and 37 deletions

View File

@ -20,5 +20,6 @@
<file name="S19Decode.aardio" path="user\S19Decode.aardio" comment="user\S19Decode.aardio"/> <file name="S19Decode.aardio" path="user\S19Decode.aardio" comment="user\S19Decode.aardio"/>
<file name="Diag37code.aardio" path="user\Diag37code.aardio" comment="user\Diag37code.aardio"/> <file name="Diag37code.aardio" path="user\Diag37code.aardio" comment="user\Diag37code.aardio"/>
<file name="Diag11code.aardio" path="user\Diag11code.aardio" comment="user\Diag11code.aardio"/> <file name="Diag11code.aardio" path="user\Diag11code.aardio" comment="user\Diag11code.aardio"/>
<file name="GeelySecurety.aardio" path="user\GeelySecurety.aardio" comment="user\GeelySecurety.aardio"/>
</folder> </folder>
</project> </project>

View File

@ -5,9 +5,9 @@ import win.timer;
CANHw = usb2canfd.USB2CANHW(); CANHw = usb2canfd.USB2CANHW();
CANHw.LoadDll(); CANHw.LoadDll();
DiagReqID = 0x18dadff1; DiagReqID = 0x741;//0x18dadff1;
DiagRespID = 0x18daf1df; DiagRespID = 0x751;//0x18daf1df;
DiagGloableID = 0x18DB33F1; DiagGloableID = 0x7DF;//0x18DB33F1;
stopflag = 0; stopflag = 0;
//注册一个消息钩子函数 //注册一个消息钩子函数
FuncLoopMsg = function(msg){ FuncLoopMsg = function(msg){

View File

@ -17,7 +17,7 @@ FuncDiag22Pro = function(data){
} }
var did = (data[1]<<8) + data[2]; var did = (data[1]<<8) + data[2];
select(did) { select(did) {
case 0xF192 { case 0xF193 {
FuncDisplay("硬件版本号"); FuncDisplay("硬件版本号");
FuncDisplay(string.pack(table.slice(data,3))); FuncDisplay(string.pack(table.slice(data,3)));
} }

View File

@ -1,52 +1,78 @@
var SecuretySeed = {0,0,0,0,}; var SecuretySeed = {0,0,0,0,};
var SecuretyKey = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; var SecuretyKey = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
var lockstate = 0;
//发送 //发送
FuncReq27 = function(num,key){ FuncReq27 = function(num,key){
if(num >= 1 && num <= 0x0C){ if(num >= 1 && num <= 0x1C){
if(key == null){ if(key == null){
var data = {0x02,0x27,num,0,0,0,0,0}; var data = {0x02,0x27,num,0,0,0,0,0};
CANHw.SendMsg(DiagReqID,data); CANHw.SendMsg(DiagReqID,data);
} }
else { else {
var data = {0x10,0X12,0x27,num,key[1],key[2],key[3],key[4]}; if(#key > 4){
CANHw.SendMsg(DiagReqID,data); var data = {0x10,0X12,0x27,num,key[1],key[2],key[3],key[4]};
CANHw.SendMsg(DiagReqID,data);
FuncPushPackage(DiagReqID,table.slice(key,5));
}
else {
var data = {0x06,0x27,num,key[1],key[2],key[3],key[4],0x00};
CANHw.SendMsg(DiagReqID,data);
}
FuncPushPackage(DiagReqID,table.slice(key,5)); }
} }
else {
FuncDisplay("27长度错误");
} }
} }
loadcodex("\user\securety.aardio"); //loadcodex("\user\securety.aardio");
loadcodex("\user\GeelySecurety.aardio");
//接收 //接收
FuncDiag27Pro = function(data){ FuncDiag27Pro = function(data){
//console.dumpJson(data); //console.dumpJson(data);
select(data[1]) { select(data[1]) {
case 1,3,5,7,9,11 { case 1,3,5,7,9,11,0x11 {
var str = "收到种子"; var str = "收到种子";
for(i=1;4;1){ for(i=1;4;1){
SecuretySeed[i] = data[i+1]; SecuretySeed[i] = data[i+1];
str += " " + tostring(SecuretySeed[i],16); str += " " + tostring(SecuretySeed[i],16);
lockstate = 1;
} }
FuncDisplay(str) FuncDisplay(str)
SecuretyKey = GenerateKeyEx(SecuretySeed,data[1]); SecuretyKey = securetyKeyCalc(SecuretySeed,data[1]);
if(#SecuretyKey >= 16){ if(#SecuretyKey >= 4){
FuncReq27(data[1]+1,SecuretyKey); FuncReq27(data[1]+1,SecuretyKey);
var str = "计算密钥-";
for(i=1;4;1){
str += " " + tostring(SecuretyKey[i],16);
}
FuncDisplay(str);
} }
else { else {
FuncDisplay("计算失败"); FuncDisplay("计算失败");
} }
} }
case 2,4,6,8,10,12 { case 2,4,6,8,10,12,0x12 {
FuncDisplay("解锁成功"); FuncDisplay("解锁成功");
lockstate = 2;
} }
else { else {
FuncDisplay("27服务未知子服务"); FuncDisplay("27服务未知子服务");
} }
} }
} }
FuncDiag27GetState = function(){
if(lockstate == 2){
return 0;
}
else {
return 1;
}
}

View File

@ -13,6 +13,10 @@ FuncReq31CheckPD = function(){//Programming Dependencies
var data = {0xFF,0x01}; var data = {0xFF,0x01};
FuncReq31(data); FuncReq31(data);
} }
FuncReq31CheckFlash = function(){
var data = {0x02,0x02};
FuncReq31(data);
}

View File

@ -9,17 +9,5 @@ FuncReq34 = function(addr,len){
//接收 //接收
FuncDiag34Pro = function(data){ FuncDiag34Pro = function(data){
//console.dumpJson(data); //console.dumpJson(data);
select(data[1]) { FuncDisplay("请求下载成功")
case 1 {
FuncDisplay("使能接收,禁能发送")
}
case 2 {
FuncDisplay("28 - TDB02")
}
case 3 {
FuncDisplay("28 - TDB03")
}
else {
}
}
} }

View File

@ -16,7 +16,7 @@ FuncWait = function(sid){
return 0xff; return 0xff;
} }
else { else {
FuncDisplay("刷写错误"); FuncDisplay("刷写错误 步骤" + bootstate);
boottimer.disable(); boottimer.disable();
thread.command.$SendEnd(false); thread.command.$SendEnd(false);
return 1; //负响应 return 1; //负响应
@ -188,7 +188,7 @@ FuncBootSeq = function(){
} }
case 2 { case 2 {
if(sendstate == 0){ if(sendstate == 0){
FuncReadDID(0xF192);//读取硬件版本 FuncReadDID(0xF193);//读取硬件版本
FuncClearState(); FuncClearState();
} }
else { else {
@ -238,7 +238,7 @@ FuncBootSeq = function(){
} }
case 7 { case 7 {
if(sendstate == 0){ if(sendstate == 0){
FuncReq27(01);//解密 FuncReq27(0x11);//解密
FuncClearState(); FuncClearState();
} }
else { else {
@ -250,16 +250,18 @@ FuncBootSeq = function(){
if(sendstate == 0){ if(sendstate == 0){
//FuncReq27(02);//发送key //FuncReq27(02);//发送key
FuncClearState(); FuncClearState();
FuncDisplay("等待解锁");
} }
else { else {
var ret = FuncWait(0x27); //var ret = FuncWait(0x27);
var ret = FuncDiag27GetState();
nextstate(ret); nextstate(ret);
} }
} }
case 9 { case 9 {
if(sendstate == 0){ if(sendstate == 0){
FuncClearState(); FuncClearState();
FuncDIDWriteStr(0xf198,"Daming_CANBootload ");//写入repair_shopcode FuncDIDWriteStr(0xf198,"Daming ");//写入repair_shopcode
} }
else { else {
@ -283,9 +285,23 @@ FuncBootSeq = function(){
nextstate(ret); nextstate(ret);
} }
} }
case 11 {
if(sendstate == 0){//请求下载
FuncReq34(0x5A01,0x2C0);//
FuncClearState();
}
else {
var ret = FuncWait(0x34);
nextstate(ret);
}
}
case 11 { case 11 {
if(sendstate == 0){//擦除flash if(sendstate == 0){//擦除flash
FuncReq31EraseFlash(0x00FE0000,0x00019FE0);// FuncReq31EraseFlash(0x00A000,0x00010000);//
FuncClearState(); FuncClearState();
} }

83
user/GeelySecurety.aardio Normal file
View File

@ -0,0 +1,83 @@
xorArray = {0xAA,0x50,0x43,0x52}
securetyKeyCalc = function(pucSeed,ucSecurityLevel){
//SeedSec_t cal,key,seed;
var seed = {0,0,0,0};
var key = {0,0,0,0};
var cal = {0,0,0,0};
seed[1]=pucSeed[4];
seed[2]=pucSeed[3];
seed[3]=pucSeed[2];
seed[4]=pucSeed[1];
select(ucSecurityLevel) {
case 0x01 {
cal[1] = seed[1]^xorArray[1];
cal[2] = seed[2]^xorArray[2];
cal[3] = seed[3]^xorArray[3];
cal[4] = seed[4]^xorArray[4];
/*
key[3] = ((cal[0]&0x0F)<<4)|( cal[0]&0xF0);
key[2] = ((cal[2]&0x0F)<<4)|((cal[3]&0xF0)>>4);
key[1] = (cal[2]&0xF0)|((cal[1]&0xF0)>>4);
key[0] = ((cal[3]&0x0F)<<4)|( cal[1]&0x0F);
*/
key[4] = ((cal[1]&0x0F)<<4)|( cal[1]&0xF0);
key[3] = ((cal[3]&0x0F)<<4)|((cal[4]&0xF0)>>4);
key[2] = (cal[3]&0xF0)|((cal[2]&0xF0)>>4);
key[1] = ((cal[4]&0x0F)<<4)|( cal[2]&0x0F);
}
case 0x03 {
/*
cal.byte[0] = ((seed.byte[0]&0xF8)>>3)^xorArray[0];
cal.byte[1] = ((seed.byte[1]&0xF8)>>3)^xorArray[1];
cal.byte[2] = ((seed.byte[2]&0xF8)>>3)^xorArray[2];
cal.byte[3] = ((seed.byte[3]&0xF8)>>3)^xorArray[3];
key.byte[0] = ((cal.byte[3]&0x07)<<5)|(( cal.byte[0]&0xF8)>>3);
key.byte[1] = ((cal.byte[0]&0x07)<<5)|(cal.byte[2]&0x1F);
key.byte[2] = (cal.byte[1]&0xF8)|((cal.byte[3]&0xE0)>>5);
key.byte[3] = (cal.byte[2]&0xF8)|( cal.byte[1]&0x07);
*/
cal[1] = ((seed[1]&0xF8)>>3)^xorArray[1];
cal[2] = ((seed[2]&0xF8)>>3)^xorArray[2];
cal[3] = ((seed[3]&0xF8)>>3)^xorArray[3];
cal[4] = ((seed[4]&0xF8)>>3)^xorArray[4];
key[1] = ((cal[4]&0x07)<<5)|(( cal[1]&0xF8)>>3);
key[2] = ((cal[0]&0x07)<<5)|(cal[3]&0x1F);
key[3] = (cal[2]&0xF8)|((cal[4]&0xE0)>>5);
key[4] = (cal[3]&0xF8)|( cal[2]&0x07);
}
case 0x11 {
/*
cal.byte[0] = seed.byte[0]^xorArray[0];
cal.byte[1] = seed.byte[1]^xorArray[1];
cal.byte[2] = seed.byte[2]^xorArray[2];
cal.byte[3] = seed.byte[3]^xorArray[3];
key.byte[3] = ((cal.byte[1]&0x03)<<6)|(( cal.byte[0]&0xFC)>>2);
key.byte[2] = ((cal.byte[0]&0x03)<<6)|(cal.byte[3]&0x3F);
key.byte[1] = (cal.byte[3]&0xFC)|((cal.byte[2]&0xC0)>>6);
key.byte[0] = (cal.byte[2]&0xFC)|(cal.byte[1]&0x03);
*/
cal[1] = seed[1]^xorArray[1];
cal[2] = seed[2]^xorArray[2];
cal[3] = seed[3]^xorArray[3];
cal[4] = seed[4]^xorArray[4];
key[4] = ((cal[2]&0x03)<<6)|(( cal[1]&0xFC)>>2);
key[3] = ((cal[1]&0x03)<<6)|(cal[4]&0x3F);
key[2] = (cal[4]&0xFC)|((cal[3]&0xC0)>>6);
key[1] = (cal[3]&0xFC)|(cal[2]&0x03);
}
else {
}
}
var pucKey = {0,0,0,0};
pucKey[1]=key[4];
pucKey[2]=key[3];
pucKey[3]=key[2];
pucKey[4]=key[1];
return pucKey;
}