new skeleton
This commit is contained in:
parent
2003b22275
commit
a72efe47f7
|
@ -4,4 +4,22 @@
|
||||||
-- endinclude
|
-- endinclude
|
||||||
|
|
||||||
-- include utils.lua
|
-- include utils.lua
|
||||||
-- endinclude
|
-- endinclude
|
||||||
|
|
||||||
|
setTickRate(100)
|
||||||
|
|
||||||
|
canRxAdd(ECU_BUS, Diagnose_1, silentlyRelayFromECU)
|
||||||
|
|
||||||
|
|
||||||
|
canRxAddMask(ECU_BUS, 0, 0, silentlyRelayFromECU)
|
||||||
|
canRxAddMask(TCU_BUS, 0, 0, silentlyRelayFromTCU)
|
||||||
|
|
||||||
|
everySecondTimer = Timer.new()
|
||||||
|
|
||||||
|
function onTick()
|
||||||
|
if everySecondTimer : getElapsedSeconds() > 1 then
|
||||||
|
everySecondTimer : reset()
|
||||||
|
print("Total from ECU " ..totalEcuMessages .. " totalTcuMessages " .. totalTcuMessages)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
|
@ -79,33 +79,8 @@ fakeTorque = 0
|
||||||
rpm = 0
|
rpm = 0
|
||||||
tps = 0
|
tps = 0
|
||||||
|
|
||||||
function xorChecksum(data, targetIndex)
|
-- include utils.lua
|
||||||
local index = 1
|
-- endinclude
|
||||||
local result = 0
|
|
||||||
while data[index] ~= nil do
|
|
||||||
if index ~= targetIndex then
|
|
||||||
result = result ~ data[index]
|
|
||||||
end
|
|
||||||
index = index + 1
|
|
||||||
end
|
|
||||||
data[targetIndex] = result
|
|
||||||
return result
|
|
||||||
end
|
|
||||||
|
|
||||||
function setBitRange(data, totalBitIndex, bitWidth, value)
|
|
||||||
local byteIndex = totalBitIndex >> 3
|
|
||||||
local bitInByteIndex = totalBitIndex - byteIndex * 8
|
|
||||||
if (bitInByteIndex + bitWidth > 8) then
|
|
||||||
bitsToHandleNow = 8 - bitInByteIndex
|
|
||||||
setBitRange(data, totalBitIndex + bitsToHandleNow, bitWidth - bitsToHandleNow, value >> bitsToHandleNow)
|
|
||||||
bitWidth = bitsToHandleNow
|
|
||||||
end
|
|
||||||
mask = (1 << bitWidth) - 1
|
|
||||||
data[1 + byteIndex] = data[1 + byteIndex] & (~(mask << bitInByteIndex))
|
|
||||||
maskedValue = value & mask
|
|
||||||
shiftedValue = maskedValue << bitInByteIndex
|
|
||||||
data[1 + byteIndex] = data[1 + byteIndex] | shiftedValue
|
|
||||||
end
|
|
||||||
|
|
||||||
function relayFromECU(bus, id, dlc, data)
|
function relayFromECU(bus, id, dlc, data)
|
||||||
onEcuTimer : reset ()
|
onEcuTimer : reset ()
|
||||||
|
|
|
@ -20,9 +20,5 @@ MOTOR_INFO = 0x580
|
||||||
MOTOR_7 = 0x588
|
MOTOR_7 = 0x588
|
||||||
|
|
||||||
|
|
||||||
|
Diagnose_1 = 2000
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ECU_BUS = 1
|
|
||||||
-- really 'not ECU'
|
|
||||||
TCU_BUS = 2
|
|
|
@ -1,3 +1,16 @@
|
||||||
|
ECU_BUS = 1
|
||||||
|
-- really 'not ECU'
|
||||||
|
TCU_BUS = 2
|
||||||
|
|
||||||
|
totalEcuMessages = 0
|
||||||
|
totalTcuMessages = 0
|
||||||
|
|
||||||
|
function relayFromTCU(bus, id, dlc, data)
|
||||||
|
totalTcuMessages = totalTcuMessages + 1
|
||||||
|
-- print("Relaying to ECU " .. id)
|
||||||
|
txCan(ECU_BUS, id, 0, data) -- relay non-ECU message to ECU
|
||||||
|
end
|
||||||
|
|
||||||
function xorChecksum(data, targetIndex)
|
function xorChecksum(data, targetIndex)
|
||||||
local index = 1
|
local index = 1
|
||||||
local result = 0
|
local result = 0
|
||||||
|
@ -78,3 +91,8 @@ function silentlyRelayFromECU(bus, id, dlc, data)
|
||||||
totalEcuMessages = totalEcuMessages + 1
|
totalEcuMessages = totalEcuMessages + 1
|
||||||
txCan(TCU_BUS, id, 0, data)
|
txCan(TCU_BUS, id, 0, data)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function silentlyRelayFromTCU(bus, id, dlc, data)
|
||||||
|
totalTcuMessages = totalTcuMessages + 1
|
||||||
|
txCan(ECU_BUS, id, 0, data) -- relay non-ECU message to ECU
|
||||||
|
end
|
Loading…
Reference in New Issue