2020-03-19 11:01:07 -07:00
|
|
|
/**
|
|
|
|
* @file can_tx.cpp
|
|
|
|
*
|
|
|
|
* CAN transmission handling. This file handles the dispatch of various outgoing regularly scheduled CAN message types.
|
|
|
|
*
|
|
|
|
* @date Mar 19, 2020
|
|
|
|
* @author Matthew Kennedy, (c) 2020
|
|
|
|
*/
|
|
|
|
|
2021-07-25 22:05:17 -07:00
|
|
|
#include "pch.h"
|
2020-03-19 11:01:07 -07:00
|
|
|
|
2021-07-25 22:05:17 -07:00
|
|
|
#if EFI_CAN_SUPPORT
|
2020-03-19 11:01:07 -07:00
|
|
|
#include "can.h"
|
|
|
|
#include "can_hw.h"
|
|
|
|
#include "can_dash.h"
|
|
|
|
#include "obd2.h"
|
2020-08-31 01:39:27 -07:00
|
|
|
#include "can_sensor.h"
|
2021-07-13 04:32:41 -07:00
|
|
|
#include "rusefi_wideband.h"
|
2020-03-19 11:01:07 -07:00
|
|
|
|
2021-03-31 19:51:49 -07:00
|
|
|
extern CanListener* canListeners_head;
|
2020-08-31 01:39:27 -07:00
|
|
|
|
2021-04-24 14:40:48 -07:00
|
|
|
|
2020-03-19 11:01:07 -07:00
|
|
|
CanWrite::CanWrite()
|
2021-04-23 17:16:27 -07:00
|
|
|
: PeriodicController("CAN TX", PRIO_CAN_TX, CAN_CYCLE_FREQ)
|
2020-03-19 11:01:07 -07:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void CanWrite::PeriodicTask(efitime_t nowNt) {
|
|
|
|
UNUSED(nowNt);
|
2021-04-23 17:16:27 -07:00
|
|
|
static uint16_t cycleCount = 0;
|
|
|
|
CanCycle cycle(cycleCount);
|
2020-03-19 11:01:07 -07:00
|
|
|
|
2021-04-23 17:16:27 -07:00
|
|
|
//in case we have Verbose Can enabled, we should keep user configured period
|
2021-11-17 00:54:21 -08:00
|
|
|
if (engineConfiguration->enableVerboseCanTx) {
|
2021-04-23 17:16:27 -07:00
|
|
|
uint16_t cycleCountsPeriodMs = cycleCount * CAN_CYCLE_PERIOD;
|
2021-11-17 00:54:21 -08:00
|
|
|
if (0 != engineConfiguration->canSleepPeriodMs) {
|
|
|
|
if (cycleCountsPeriodMs % engineConfiguration->canSleepPeriodMs) {
|
2021-04-23 17:16:27 -07:00
|
|
|
void sendCanVerbose();
|
|
|
|
sendCanVerbose();
|
|
|
|
}
|
|
|
|
}
|
2020-03-19 14:58:46 -07:00
|
|
|
}
|
|
|
|
|
2021-03-31 19:51:49 -07:00
|
|
|
CanListener* current = canListeners_head;
|
2020-08-31 01:39:27 -07:00
|
|
|
|
|
|
|
while (current) {
|
|
|
|
current = current->request();
|
|
|
|
}
|
|
|
|
|
2021-04-23 17:16:27 -07:00
|
|
|
if (cycle.isInterval(CI::_MAX_Cycle)) {
|
|
|
|
//we now reset cycleCount since we reached max cycle count
|
|
|
|
cycleCount = 0;
|
2020-03-19 11:01:07 -07:00
|
|
|
}
|
2021-04-23 17:16:27 -07:00
|
|
|
|
2021-12-01 08:13:36 -08:00
|
|
|
#ifndef DISABLE_CAN_UPDATE_DASH
|
2021-04-23 17:16:27 -07:00
|
|
|
updateDash(cycle);
|
2021-12-01 08:13:36 -08:00
|
|
|
#endif /* DISABLE_CAN_UPDATE_DASH */
|
2021-04-23 17:16:27 -07:00
|
|
|
|
2021-11-17 00:54:21 -08:00
|
|
|
if (engineConfiguration->enableAemXSeries && cycle.isInterval(CI::_50ms)) {
|
2021-07-13 04:32:41 -07:00
|
|
|
sendWidebandInfo();
|
|
|
|
}
|
|
|
|
|
2021-04-23 17:16:27 -07:00
|
|
|
cycleCount++;
|
|
|
|
}
|
|
|
|
|
|
|
|
CanInterval CanCycle::computeFlags(uint32_t cycleCount) {
|
|
|
|
CanInterval cycleMask = CanInterval::_5ms;
|
|
|
|
|
|
|
|
if ((cycleCount % 2) == 0) {
|
|
|
|
cycleMask |= CI::_10ms;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((cycleCount % 4) == 0) {
|
|
|
|
cycleMask |= CI::_20ms;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((cycleCount % 10) == 0) {
|
|
|
|
cycleMask |= CI::_50ms;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((cycleCount % 20) == 0) {
|
|
|
|
cycleMask |= CI::_100ms;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((cycleCount % 40) == 0) {
|
|
|
|
cycleMask |= CI::_200ms;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((cycleCount % 50) == 0) {
|
|
|
|
cycleMask |= CI::_250ms;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((cycleCount % 100) == 0) {
|
|
|
|
cycleMask |= CI::_500ms;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((cycleCount % 200) == 0) {
|
|
|
|
cycleMask |= CI::_1000ms;
|
|
|
|
}
|
|
|
|
|
|
|
|
return cycleMask;
|
2020-03-19 11:01:07 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif // EFI_CAN_SUPPORT
|