2022-11-15 12:15:17 -08:00
|
|
|
OUT_1F9 = 0x1F9
|
|
|
|
OUT_233 = 0x233
|
|
|
|
OUT_23D = 0x23D
|
|
|
|
|
2022-07-18 14:01:44 -07:00
|
|
|
setTickRate(100)
|
|
|
|
t = Timer.new()
|
|
|
|
t : reset()
|
|
|
|
|
|
|
|
globalAcOut = 0
|
|
|
|
|
|
|
|
function onTick()
|
2022-11-15 12:15:17 -08:00
|
|
|
local rpmValue = math.floor(getSensor("RPM") + 0.5)
|
|
|
|
local RPMread = rpmValue / 3.15
|
2022-07-18 14:01:44 -07:00
|
|
|
local RPMhi = RPMread / 256
|
|
|
|
local RPMlo = RPMread
|
2022-11-01 18:32:31 -07:00
|
|
|
cltValue = getSensor("CLT")
|
2022-11-15 12:15:17 -08:00
|
|
|
cltValue = (cltValue == nil and 0 or cltValue)
|
2022-07-18 14:01:44 -07:00
|
|
|
|
|
|
|
--print('ac out = ' ..globalAcOut)
|
2022-11-15 12:15:17 -08:00
|
|
|
if globalAcOut == 1 and rpmValue > 250 then
|
2022-07-18 14:01:44 -07:00
|
|
|
fanPayloadOff = { 0x88, 0x00 }
|
|
|
|
fanPayloadLo = { 0x88, 0x00 }
|
|
|
|
fanPayloadHi = { 0x88, 0x00 }
|
|
|
|
else
|
|
|
|
--print('ac off payload')
|
|
|
|
fanPayloadOff = { 0x00, 0x00 }
|
|
|
|
fanPayloadLo = { 0x40, 0x00 }
|
|
|
|
fanPayloadHi = { 0x80, 0x00 }
|
|
|
|
end
|
|
|
|
|
|
|
|
cltGauge = 0x00
|
|
|
|
|
|
|
|
-- clt gauge stuff
|
2022-11-15 12:15:17 -08:00
|
|
|
if cltValue < 115 then
|
|
|
|
cltGauge = math.floor(cltValue * 1.5 + 0.5)
|
|
|
|
else
|
2022-07-18 14:01:44 -07:00
|
|
|
cltGauge = 0xF0
|
|
|
|
end
|
|
|
|
-- print('clt gauge = '..cltGauge)
|
|
|
|
-- rpm fun stuff
|
|
|
|
if t : getElapsedSeconds() < 2 then
|
2022-11-15 12:15:17 -08:00
|
|
|
CLTandRPM_D = { 0x00, 0x18, 0x0C, 0x01, 0x0A, 0x87, 0xFF, 0xFF }
|
2022-07-18 14:01:44 -07:00
|
|
|
else
|
2022-11-15 12:15:17 -08:00
|
|
|
CLTandRPM_D = { 0x00, 0x18, 0x0c, RPMlo, RPMhi, 0x87, 0xFF, cltGauge }
|
2022-07-18 14:01:44 -07:00
|
|
|
end
|
|
|
|
|
2022-11-15 12:15:17 -08:00
|
|
|
state_233 = rpmValue > 250 and 0x10 or 0x18
|
|
|
|
CLTandRPM_3 = { cltGauge, 0x8C, 0x20, state_233, RPMlo, 0x00, 0x00, RPMhi }
|
2022-07-18 14:01:44 -07:00
|
|
|
|
2022-11-15 12:15:17 -08:00
|
|
|
txCan(1, OUT_233, 0, CLTandRPM_3) -- transmit CLT and RPM for who knows whom
|
|
|
|
txCan(1, OUT_23D, 0, CLTandRPM_D) -- transmit CLT and RPM for gauge cluster
|
2022-07-18 14:01:44 -07:00
|
|
|
|
|
|
|
|
2022-11-15 12:15:17 -08:00
|
|
|
if rpmValue > 250 then
|
|
|
|
if cltValue <= 80 then
|
|
|
|
txCan(1, OUT_1F9, 0, fanPayloadOff)
|
|
|
|
elseif cltValue < 85 then
|
|
|
|
-- send nothing
|
|
|
|
elseif cltValue < 90 then
|
|
|
|
txCan(1, OUT_1F9, 0, fanPayloadLo)
|
|
|
|
else
|
|
|
|
txCan(1, OUT_1F9, 0, fanPayloadHi)
|
2022-07-18 14:01:44 -07:00
|
|
|
end
|
|
|
|
else
|
2022-11-15 12:15:17 -08:00
|
|
|
txCan(1, OUT_1F9, 0, fanPayloadOff)
|
2022-07-18 14:01:44 -07:00
|
|
|
end
|
2022-11-15 12:15:17 -08:00
|
|
|
-- print('CLT temp' ..cltValue)
|
2022-07-18 14:01:44 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
|
2023-03-04 18:17:42 -08:00
|
|
|
function onAcCanRx(bus, id, dlc, data)
|
2022-07-18 14:01:44 -07:00
|
|
|
--print('got CAN id=' ..id ..' dlc=' ..dlc)
|
|
|
|
--print('ac value is= '..data[1])
|
|
|
|
if data[1] == 193 then
|
|
|
|
setAcRequestState(true)
|
|
|
|
globalAcOut = 1
|
|
|
|
--print('ac is on')
|
|
|
|
else
|
|
|
|
setAcRequestState(false)
|
|
|
|
globalAcOut = 0
|
|
|
|
--print('ac is off')
|
|
|
|
end
|
|
|
|
|
2023-03-04 18:17:42 -08:00
|
|
|
end
|
|
|
|
|
|
|
|
canRxAdd(1, 0x35d, onAcCanRx)
|