mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-22 00:28:30 -04:00
1243 lines
50 KiB
C
1243 lines
50 KiB
C
// ECUPackets.h was generated by ProtoGen version 3.2.a
|
|
|
|
/*
|
|
* This file is free software: you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the
|
|
* Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This file is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
* See the GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* Author: Oliver Walters / Currawong Engineering Pty Ltd
|
|
*/
|
|
|
|
|
|
#ifndef _ECUPACKETS_H
|
|
#define _ECUPACKETS_H
|
|
|
|
// Language target is C, C++ compilers: don't mangle us
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*!
|
|
* \file
|
|
*/
|
|
|
|
#include <stdbool.h>
|
|
#include "ECUProtocol.h"
|
|
#include "ECUDefines.h"
|
|
#include "ECUSettings.h"
|
|
|
|
/*!
|
|
* The throttle command packet sets the throttle position setpoint. The ECU
|
|
* will adjust the throttle position based on this command.
|
|
*/
|
|
typedef struct
|
|
{
|
|
float throttleCommand; //!< Commanded throttle position in percent
|
|
}ECU_ThrottleCommand_t;
|
|
|
|
//! Create the ECU_ThrottleCommand packet from parameters
|
|
void encodeECU_ThrottleCommandPacket(void* pkt, float throttleCommand);
|
|
|
|
//! Decode the ECU_ThrottleCommand packet to parameters
|
|
int decodeECU_ThrottleCommandPacket(const void* pkt, float* throttleCommand);
|
|
|
|
//! return the packet ID for the ECU_ThrottleCommand packet
|
|
#define getECU_ThrottleCommandPacketID() (PKT_ECU_THROTTLE)
|
|
|
|
//! return the minimum encoded length for the ECU_ThrottleCommand packet
|
|
#define getECU_ThrottleCommandMinDataLength() (2)
|
|
|
|
//! return the maximum encoded length for the ECU_ThrottleCommand packet
|
|
#define getECU_ThrottleCommandMaxDataLength() (2)
|
|
|
|
/*!
|
|
* The RPM command is used to send a target to the RPM governor on the ECU.
|
|
* Based on this command, the ECU will use a feedback loop to maintain the
|
|
* commanded engine speed by adjusting the throttle servo accordingly. If a
|
|
* valid RPM command is received by the ECU, it will automatically enter RPM
|
|
* control mode, and adjust the throttle position to match the desired RPM.
|
|
* Sending a throttle command will cause the ECU to stop the RPM loop and enter
|
|
* open-loop throttle control mode.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint16_t rpmCmd; //!< Engine speed command in revolutions per minute
|
|
uint8_t rpmCmdHigh; //!< RPM command in units of 50 RPM
|
|
uint8_t rpmCmdLow; //!< Low part of RPM command from 0 to 49
|
|
}ECU_RPMCommand_t;
|
|
|
|
//! Create the ECU_RPMCommand packet
|
|
void encodeECU_RPMCommandPacketStructure(void* pkt, const ECU_RPMCommand_t* user);
|
|
|
|
//! Decode the ECU_RPMCommand packet
|
|
int decodeECU_RPMCommandPacketStructure(const void* pkt, ECU_RPMCommand_t* user);
|
|
|
|
//! return the packet ID for the ECU_RPMCommand packet
|
|
#define getECU_RPMCommandPacketID() (PKT_ECU_RPM_COMMAND)
|
|
|
|
//! return the minimum encoded length for the ECU_RPMCommand packet
|
|
#define getECU_RPMCommandMinDataLength() (2)
|
|
|
|
//! return the maximum encoded length for the ECU_RPMCommand packet
|
|
#define getECU_RPMCommandMaxDataLength() (2)
|
|
|
|
typedef struct
|
|
{
|
|
bool driverPin8; //!< 1 if driver 8 is on
|
|
bool driverPin7; //!< 1 if driver 7 is on
|
|
bool driverPin2; //!< 1 if driver 2 is on
|
|
bool driverPin1; //!< 1 if driver 1 is on
|
|
bool throttleCurveOn; //!< 1 if the throttle curve is on.
|
|
bool rs232mode; //!< 1 if autronic, else auxiliary.
|
|
bool errorIndicator; //!< 1 if any errors are set - refer to [error packet](#PKT_ECU_ERROR_MSG)
|
|
bool enabled; //!< Global enable based on physical input
|
|
}ECU_ecuStatusBits_t;
|
|
|
|
/*!
|
|
* Fast telemetry contains high priority telemetry data and is transmitted at a
|
|
* user configurable period between 50ms (20Hz) and 10s. By default, the fast
|
|
* telemetry message is transmitted at 10Hz (every 100ms)
|
|
*/
|
|
typedef struct
|
|
{
|
|
float throttle; //!< Throttle signal (0 to 100%)
|
|
uint16_t rpm; //!< Engine speed in revolutions per minute
|
|
uint32_t fuelUsed; //!< Fuel used in grams
|
|
ECU_ecuStatusBits_t ecuStatusBits;
|
|
}ECU_TelemetryFast_t;
|
|
|
|
//! Encode a ECU_ecuStatusBits_t into a byte array
|
|
void encodeECU_ecuStatusBits_t(uint8_t* data, int* bytecount, const ECU_ecuStatusBits_t* user);
|
|
|
|
//! Decode a ECU_ecuStatusBits_t from a byte array
|
|
int decodeECU_ecuStatusBits_t(const uint8_t* data, int* bytecount, ECU_ecuStatusBits_t* user);
|
|
|
|
//! Create the ECU_TelemetryFast packet
|
|
void encodeECU_TelemetryFastPacketStructure(void* pkt, const ECU_TelemetryFast_t* user);
|
|
|
|
//! Decode the ECU_TelemetryFast packet
|
|
int decodeECU_TelemetryFastPacketStructure(const void* pkt, ECU_TelemetryFast_t* user);
|
|
|
|
//! Create the ECU_TelemetryFast packet from parameters
|
|
void encodeECU_TelemetryFastPacket(void* pkt, float throttle, uint16_t rpm, uint32_t fuelUsed, const ECU_ecuStatusBits_t* ecuStatusBits);
|
|
|
|
//! Decode the ECU_TelemetryFast packet to parameters
|
|
int decodeECU_TelemetryFastPacket(const void* pkt, float* throttle, uint16_t* rpm, uint32_t* fuelUsed, ECU_ecuStatusBits_t* ecuStatusBits);
|
|
|
|
//! return the packet ID for the ECU_TelemetryFast packet
|
|
#define getECU_TelemetryFastPacketID() (PKT_ECU_TELEMETRY_FAST)
|
|
|
|
//! return the minimum encoded length for the ECU_TelemetryFast packet
|
|
#define getECU_TelemetryFastMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_TelemetryFast packet
|
|
#define getECU_TelemetryFastMaxDataLength() (8)
|
|
|
|
/*!
|
|
* This is the first of three slower telemetry packets which are transmitted by
|
|
* the ECU at a user customizable period (between 0.5s and 10.0s). These three
|
|
* packets contain data that is not likely to change as quickly as the data in
|
|
* the fast telemetry packet. By default, the slow telemetry messages are
|
|
* transmitted at 1Hz (period of 1.0s).
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint16_t rpmCmd; //!< The reconstructed RPM command
|
|
float map; //!< The reconstructed manifold pressure in kilo-Pascals
|
|
ECUThrottleSource throttleSrc; //!< Source of the throttle information
|
|
uint16_t throttlePulse; //!< Throttle pulse width in microseconds
|
|
float cht; //!< Cylinder head temperature in Celsius
|
|
float baro; //!< Barometric pressure in kilo-Pascals
|
|
}ECU_TelemetrySlow0_t;
|
|
|
|
//! Create the ECU_TelemetrySlow0 packet
|
|
void encodeECU_TelemetrySlow0PacketStructure(void* pkt, const ECU_TelemetrySlow0_t* user);
|
|
|
|
//! Decode the ECU_TelemetrySlow0 packet
|
|
int decodeECU_TelemetrySlow0PacketStructure(const void* pkt, ECU_TelemetrySlow0_t* user);
|
|
|
|
//! return the packet ID for the ECU_TelemetrySlow0 packet
|
|
#define getECU_TelemetrySlow0PacketID() (PKT_ECU_TELEMETRY_SLOW_0)
|
|
|
|
//! return the minimum encoded length for the ECU_TelemetrySlow0 packet
|
|
#define getECU_TelemetrySlow0MinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_TelemetrySlow0 packet
|
|
#define getECU_TelemetrySlow0MaxDataLength() (8)
|
|
|
|
/*!
|
|
* ECU RPM governor mode enumeration
|
|
*/
|
|
typedef enum
|
|
{
|
|
ECU_GOV_MODE_NONE, //!< RPM governor is off
|
|
ECU_GOV_MODE_THROTTLE,//!< RPM governer setpoint is based on throttle input
|
|
ECU_GOV_MODE_DIRECT //!< RPM governor setpoint comes from direct command
|
|
} ECUGovernorMode;
|
|
|
|
/*!
|
|
* The second of three slow telemetry packets
|
|
*/
|
|
typedef struct
|
|
{
|
|
float mat; //!< Inlet air temperature in Celsius
|
|
float fuelPressure; //!< Fuel pressure in kilo-Pascals
|
|
uint32_t hobbs; //!< Engine run time in seconds.
|
|
float voltage; //!< Input voltage in Volts
|
|
ECUGovernorMode governorMode; //!< Operational mode of the governor
|
|
}ECU_TelemetrySlow1_t;
|
|
|
|
//! Create the ECU_TelemetrySlow1 packet
|
|
void encodeECU_TelemetrySlow1PacketStructure(void* pkt, const ECU_TelemetrySlow1_t* user);
|
|
|
|
//! Decode the ECU_TelemetrySlow1 packet
|
|
int decodeECU_TelemetrySlow1PacketStructure(const void* pkt, ECU_TelemetrySlow1_t* user);
|
|
|
|
//! return the packet ID for the ECU_TelemetrySlow1 packet
|
|
#define getECU_TelemetrySlow1PacketID() (PKT_ECU_TELEMETRY_SLOW_1)
|
|
|
|
//! return the minimum encoded length for the ECU_TelemetrySlow1 packet
|
|
#define getECU_TelemetrySlow1MinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_TelemetrySlow1 packet
|
|
#define getECU_TelemetrySlow1MaxDataLength() (8)
|
|
|
|
/*!
|
|
* The third of three slow telemetry packets
|
|
*/
|
|
typedef struct
|
|
{
|
|
float cpuLoad; //!< CPU load in percent
|
|
float chargeTemp; //!< Charge temperature in Celsius
|
|
float injectorDuty; //!< Injector duty cycle in percent
|
|
float ignAngle1; //!< First ignition advance angle in degrees
|
|
float ignAngle2; //!< Second ignition advance angle in degrees
|
|
float flowRate; //!< Fuel flow rate in grams per minute
|
|
}ECU_TelemetrySlow2_t;
|
|
|
|
//! Create the ECU_TelemetrySlow2 packet
|
|
void encodeECU_TelemetrySlow2PacketStructure(void* pkt, const ECU_TelemetrySlow2_t* user);
|
|
|
|
//! Decode the ECU_TelemetrySlow2 packet
|
|
int decodeECU_TelemetrySlow2PacketStructure(const void* pkt, ECU_TelemetrySlow2_t* user);
|
|
|
|
//! return the packet ID for the ECU_TelemetrySlow2 packet
|
|
#define getECU_TelemetrySlow2PacketID() (PKT_ECU_TELEMETRY_SLOW_2)
|
|
|
|
//! return the minimum encoded length for the ECU_TelemetrySlow2 packet
|
|
#define getECU_TelemetrySlow2MinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_TelemetrySlow2 packet
|
|
#define getECU_TelemetrySlow2MaxDataLength() (8)
|
|
|
|
/*!
|
|
* Enumeration of auxiliary to autronic serial relay states. Autronic relay is
|
|
* an advanced feature used to allow simultaneous connection of the Autronic
|
|
* ECUCal software and the auxiliary processor. Autronic relay should only be
|
|
* needed for engine development.
|
|
*/
|
|
typedef enum
|
|
{
|
|
AUT_RELAY_OFF, //!< Relay is disengaged, 19200 autronic interface rate; must use calibration switch to connect to Autronic
|
|
AUT_RELAY_PENDING,//!< Relay enabled but not detected, 19200 autronic and external serial interface rate
|
|
AUT_RELAY_ON //!< Relay detected, 38400 autronic and external serial interface rate
|
|
} ECUAutronicRelayState;
|
|
|
|
/*!
|
|
* The hardware config packet contains the ECU serial number and various ECU
|
|
* configuration data. Send a zero length packet to request this data.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint16_t serialNumber; //!< ECU serial number
|
|
uint16_t fuelDivisor; //!< Fuel used divisior. If the divisor is greater than 100 then it is interpreted as units of 0.01 (for a higher resolution fuel calibration)
|
|
ECUAutronicRelayState relayState; //!< Autronic relay state. This is a volatile status which will reset to AUT_RELAY_OFF on ECU power cycle.
|
|
bool resetFuelUsedOnStart; //!< Set if the fuel used value is reset each on each ECU power cycle
|
|
}ECU_HardwareConfig_t;
|
|
|
|
//! Create the ECU_HardwareConfig packet
|
|
void encodeECU_HardwareConfigPacketStructure(void* pkt, const ECU_HardwareConfig_t* user);
|
|
|
|
//! Decode the ECU_HardwareConfig packet
|
|
int decodeECU_HardwareConfigPacketStructure(const void* pkt, ECU_HardwareConfig_t* user);
|
|
|
|
//! return the packet ID for the ECU_HardwareConfig packet
|
|
#define getECU_HardwareConfigPacketID() (PKT_ECU_HARDWARE_CONFIG)
|
|
|
|
//! return the minimum encoded length for the ECU_HardwareConfig packet
|
|
#define getECU_HardwareConfigMinDataLength() (5)
|
|
|
|
//! return the maximum encoded length for the ECU_HardwareConfig packet
|
|
#define getECU_HardwareConfigMaxDataLength() (5)
|
|
|
|
/*!
|
|
* The software version packet contains the auxiliary processor firmware
|
|
* version information. Send a zero length packet to request this data.
|
|
*/
|
|
typedef struct
|
|
{
|
|
bool release; //!< 1 = Release version, 0 = Testing version
|
|
unsigned versionMajor : 6; //!< Major version number
|
|
uint8_t versionMinor; //!< Minor version number
|
|
uint8_t versionRev; //!< Revision number
|
|
uint8_t month; //!< The release month from 1 (January) to 12 (December)
|
|
uint8_t day; //!< The release day of month from 1 to 31
|
|
uint16_t year; //!< The release year
|
|
uint16_t checksum; //!< Firmware checksum
|
|
}ECU_Version_t;
|
|
|
|
//! Create the ECU_Version packet
|
|
void encodeECU_VersionPacketStructure(void* pkt, const ECU_Version_t* user);
|
|
|
|
//! Decode the ECU_Version packet
|
|
int decodeECU_VersionPacketStructure(const void* pkt, ECU_Version_t* user);
|
|
|
|
//! return the packet ID for the ECU_Version packet
|
|
#define getECU_VersionPacketID() (PKT_ECU_SOFTWARE_VERSION)
|
|
|
|
//! return the minimum encoded length for the ECU_Version packet
|
|
#define getECU_VersionMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_Version packet
|
|
#define getECU_VersionMaxDataLength() (8)
|
|
|
|
/*!
|
|
* The errors packet contains error status information for the ECU. If any
|
|
* error bits are set, then the global error bit in the [fast
|
|
* telemetry](#PKT_ECU_TELEMETRY_FAST) packet will also be set. Send a zero
|
|
* length packet to request this data.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECU_AutronicErrorBits_t autronicErrors; //!< Error bits for the Autronic processor
|
|
ECU_AuxiliaryErrorBits_t auxiliaryErrors; //!< Error bits for the auxiliary processor
|
|
}ECU_Errors_t;
|
|
|
|
//! Create the ECU_Errors packet
|
|
void encodeECU_ErrorsPacketStructure(void* pkt, const ECU_Errors_t* user);
|
|
|
|
//! Decode the ECU_Errors packet
|
|
int decodeECU_ErrorsPacketStructure(const void* pkt, ECU_Errors_t* user);
|
|
|
|
//! return the packet ID for the ECU_Errors packet
|
|
#define getECU_ErrorsPacketID() (PKT_ECU_ERROR_MSG)
|
|
|
|
//! return the minimum encoded length for the ECU_Errors packet
|
|
#define getECU_ErrorsMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_Errors packet
|
|
#define getECU_ErrorsMaxDataLength() (8)
|
|
|
|
/*!
|
|
* The power cycles packet contains information on the reset condition of the
|
|
* ECU. Send a zero length packet to request this data.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint16_t powerCycles; //!< Number of power cycles
|
|
uint8_t reserved;
|
|
uint8_t resetCode; //!< Auxiliary processor reset code
|
|
uint32_t systemTime; //!< Milliseconds since system reset
|
|
}ECU_PowerCycles_t;
|
|
|
|
//! Create the ECU_PowerCycles packet
|
|
void encodeECU_PowerCyclesPacketStructure(void* pkt, const ECU_PowerCycles_t* user);
|
|
|
|
//! Decode the ECU_PowerCycles packet
|
|
int decodeECU_PowerCyclesPacketStructure(const void* pkt, ECU_PowerCycles_t* user);
|
|
|
|
//! return the packet ID for the ECU_PowerCycles packet
|
|
#define getECU_PowerCyclesPacketID() (PKT_ECU_POWER_CYCLES)
|
|
|
|
//! return the minimum encoded length for the ECU_PowerCycles packet
|
|
#define getECU_PowerCyclesMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_PowerCycles packet
|
|
#define getECU_PowerCyclesMaxDataLength() (8)
|
|
|
|
/*!
|
|
* The fuel pump debug packet contains information on the pump control system.
|
|
* Send a zero length packet to request this data.
|
|
*/
|
|
typedef struct
|
|
{
|
|
float pTerm; //!< Proportional term of the pump feedback control in percent
|
|
float iTerm; //!< Integral term of the pump feedback control in percent
|
|
float dutyCycle; //!< Pump duty cycle in percent
|
|
float fuelPressure; //!< Fuel pressure in kilo-Pascals
|
|
}ECU_PumpDebug_t;
|
|
|
|
//! Create the ECU_PumpDebug packet
|
|
void encodeECU_PumpDebugPacketStructure(void* pkt, const ECU_PumpDebug_t* user);
|
|
|
|
//! Decode the ECU_PumpDebug packet
|
|
int decodeECU_PumpDebugPacketStructure(const void* pkt, ECU_PumpDebug_t* user);
|
|
|
|
//! return the packet ID for the ECU_PumpDebug packet
|
|
#define getECU_PumpDebugPacketID() (PKT_ECU_PUMP_DEBUG)
|
|
|
|
//! return the minimum encoded length for the ECU_PumpDebug packet
|
|
#define getECU_PumpDebugMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_PumpDebug packet
|
|
#define getECU_PumpDebugMaxDataLength() (8)
|
|
|
|
/*!
|
|
* While the engine time contained in the ECU telemetry packet can be reset by
|
|
* the user, the ECU also stores the total engine time, which cannot be reset
|
|
* by the user. Send a zero length packet to request this data.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint32_t hobbs; //!< Total engine run time in seconds
|
|
}ECU_TotalEngineTime_t;
|
|
|
|
//! Create the ECU_TotalEngineTime packet from parameters
|
|
void encodeECU_TotalEngineTimePacket(void* pkt, uint32_t hobbs);
|
|
|
|
//! Decode the ECU_TotalEngineTime packet to parameters
|
|
int decodeECU_TotalEngineTimePacket(const void* pkt, uint32_t* hobbs);
|
|
|
|
//! return the packet ID for the ECU_TotalEngineTime packet
|
|
#define getECU_TotalEngineTimePacketID() (PKT_ECU_TOTAL_ENGINE_TIME)
|
|
|
|
//! return the minimum encoded length for the ECU_TotalEngineTime packet
|
|
#define getECU_TotalEngineTimeMinDataLength() (3)
|
|
|
|
//! return the maximum encoded length for the ECU_TotalEngineTime packet
|
|
#define getECU_TotalEngineTimeMaxDataLength() (3)
|
|
|
|
/*!
|
|
* The eeprom settings packet contains information on the non-volatile ECU
|
|
* settings stored in eeprom. In particular, it provides a checksum of the
|
|
* settings data for easy comparison of settings between different ECUs. Send a
|
|
* zero length packet to request this data.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t eepromVersion; //!< Version of the EEPROM data
|
|
uint16_t eepromSize; //!< Number of bytes of the EEPROM data
|
|
uint16_t eepromChecksum; //!< Fletcher's checksum of the EEPROM data
|
|
ECU_CompileOptions_t compileOptions; //!< ECU compilation options
|
|
}ECU_eepromSettings_t;
|
|
|
|
//! Create the ECU_eepromSettings packet
|
|
void encodeECU_eepromSettingsPacketStructure(void* pkt, const ECU_eepromSettings_t* user);
|
|
|
|
//! Decode the ECU_eepromSettings packet
|
|
int decodeECU_eepromSettingsPacketStructure(const void* pkt, ECU_eepromSettings_t* user);
|
|
|
|
//! Create the ECU_eepromSettings packet from parameters
|
|
void encodeECU_eepromSettingsPacket(void* pkt, uint8_t eepromVersion, uint16_t eepromSize, uint16_t eepromChecksum, const ECU_CompileOptions_t* compileOptions);
|
|
|
|
//! Decode the ECU_eepromSettings packet to parameters
|
|
int decodeECU_eepromSettingsPacket(const void* pkt, uint8_t* eepromVersion, uint16_t* eepromSize, uint16_t* eepromChecksum, ECU_CompileOptions_t* compileOptions);
|
|
|
|
//! return the packet ID for the ECU_eepromSettings packet
|
|
#define getECU_eepromSettingsPacketID() (PKT_ECU_SETTINGS_DATA)
|
|
|
|
//! return the minimum encoded length for the ECU_eepromSettings packet
|
|
#define getECU_eepromSettingsMinDataLength() (7)
|
|
|
|
//! return the maximum encoded length for the ECU_eepromSettings packet
|
|
#define getECU_eepromSettingsMaxDataLength() (7)
|
|
|
|
/*!
|
|
* Control loop settings for the CHT control loop
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t dTermFilter; //!< Filter value for derivative term
|
|
bool enabled; //!< CHT control loop enabled
|
|
uint8_t targetTemp; //!< Target CHT temperature
|
|
float Kp; //!< Proportaional gain Kp
|
|
float Ki; //!< Proportaional gain Ki
|
|
float Kd; //!< Proportaional gain Kd
|
|
}ECU_CHTLoopSettings_t;
|
|
|
|
//! Create the ECU_CHTLoopSettings packet
|
|
void encodeECU_CHTLoopSettingsPacketStructure(void* pkt, const ECU_CHTLoopSettings_t* user);
|
|
|
|
//! Decode the ECU_CHTLoopSettings packet
|
|
int decodeECU_CHTLoopSettingsPacketStructure(const void* pkt, ECU_CHTLoopSettings_t* user);
|
|
|
|
//! Create the ECU_CHTLoopSettings packet from parameters
|
|
void encodeECU_CHTLoopSettingsPacket(void* pkt, uint8_t dTermFilter, bool enabled, uint8_t targetTemp, float Kp, float Ki, float Kd);
|
|
|
|
//! Decode the ECU_CHTLoopSettings packet to parameters
|
|
int decodeECU_CHTLoopSettingsPacket(const void* pkt, uint8_t* dTermFilter, bool* enabled, uint8_t* targetTemp, float* Kp, float* Ki, float* Kd);
|
|
|
|
//! return the packet ID for the ECU_CHTLoopSettings packet
|
|
#define getECU_CHTLoopSettingsPacketID() (PKT_ECU_CHT_LOOP)
|
|
|
|
//! return the minimum encoded length for the ECU_CHTLoopSettings packet
|
|
#define getECU_CHTLoopSettingsMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_CHTLoopSettings packet
|
|
#define getECU_CHTLoopSettingsMaxDataLength() (8)
|
|
|
|
/*!
|
|
* Dual pump control telemetry. Send a zero-length packet with this identifier
|
|
* to the ECU to poll (request) this packet.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t mode; //!< Current pump mode (which pump is running). Refer to the DualFuelPumpMode enumeration.
|
|
uint8_t state; //!< Current pump state machine state. Refer to the DualFuelPumpState enumeration.
|
|
uint16_t stateTimer; //!< Time spent in current state
|
|
}ECU_DualPumpControlTelemetry_t;
|
|
|
|
//! Create the ECU_DualPumpControlTelemetry packet
|
|
void encodeECU_DualPumpControlTelemetryPacketStructure(void* pkt, const ECU_DualPumpControlTelemetry_t* user);
|
|
|
|
//! Decode the ECU_DualPumpControlTelemetry packet
|
|
int decodeECU_DualPumpControlTelemetryPacketStructure(const void* pkt, ECU_DualPumpControlTelemetry_t* user);
|
|
|
|
//! return the packet ID for the ECU_DualPumpControlTelemetry packet
|
|
#define getECU_DualPumpControlTelemetryPacketID() (0x08)
|
|
|
|
//! return the minimum encoded length for the ECU_DualPumpControlTelemetry packet
|
|
#define getECU_DualPumpControlTelemetryMinDataLength() (4)
|
|
|
|
//! return the maximum encoded length for the ECU_DualPumpControlTelemetry packet
|
|
#define getECU_DualPumpControlTelemetryMaxDataLength() (4)
|
|
|
|
/*!
|
|
* Set the telemetry period for dual-pump messages
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t period; //!< Telemetry period (0 = Off)
|
|
}ECU_DualPump_SetTelemetryPeriod_t;
|
|
|
|
//! Create the ECU_DualPump_SetTelemetryPeriod packet from parameters
|
|
void encodeECU_DualPump_SetTelemetryPeriodPacket(void* pkt, uint8_t period);
|
|
|
|
//! Decode the ECU_DualPump_SetTelemetryPeriod packet to parameters
|
|
int decodeECU_DualPump_SetTelemetryPeriodPacket(const void* pkt, uint8_t* period);
|
|
|
|
//! return the packet ID for the ECU_DualPump_SetTelemetryPeriod packet
|
|
#define getECU_DualPump_SetTelemetryPeriodPacketID() (0x08)
|
|
|
|
//! return the minimum encoded length for the ECU_DualPump_SetTelemetryPeriod packet
|
|
#define getECU_DualPump_SetTelemetryPeriodMinDataLength() (2)
|
|
|
|
//! return the maximum encoded length for the ECU_DualPump_SetTelemetryPeriod packet
|
|
#define getECU_DualPump_SetTelemetryPeriodMaxDataLength() (2)
|
|
|
|
/*!
|
|
* Command to manually select a given pump mode.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t pump; //!< Pump selection (see DualFuelPumpMode enumeration)
|
|
}ECU_DualPump_SelectPump_t;
|
|
|
|
//! Create the ECU_DualPump_SelectPump packet from parameters
|
|
void encodeECU_DualPump_SelectPumpPacket(void* pkt, uint8_t pump);
|
|
|
|
//! Decode the ECU_DualPump_SelectPump packet to parameters
|
|
int decodeECU_DualPump_SelectPumpPacket(const void* pkt, uint8_t* pump);
|
|
|
|
//! return the packet ID for the ECU_DualPump_SelectPump packet
|
|
#define getECU_DualPump_SelectPumpPacketID() (0x08)
|
|
|
|
//! return the minimum encoded length for the ECU_DualPump_SelectPump packet
|
|
#define getECU_DualPump_SelectPumpMinDataLength() (3)
|
|
|
|
//! return the maximum encoded length for the ECU_DualPump_SelectPump packet
|
|
#define getECU_DualPump_SelectPumpMaxDataLength() (3)
|
|
|
|
/*!
|
|
* Command to temporarily run a particular pump in test mode. ECU will revert
|
|
* to OTHER pump when test expires
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t pump; //!< Pump selection (see DualFuelPumpMode enumeration)
|
|
uint8_t timeout; //!< Test timeout
|
|
}ECU_DualPump_TestPump_t;
|
|
|
|
//! Create the ECU_DualPump_TestPump packet
|
|
void encodeECU_DualPump_TestPumpPacketStructure(void* pkt, const ECU_DualPump_TestPump_t* user);
|
|
|
|
//! Decode the ECU_DualPump_TestPump packet
|
|
int decodeECU_DualPump_TestPumpPacketStructure(const void* pkt, ECU_DualPump_TestPump_t* user);
|
|
|
|
//! return the packet ID for the ECU_DualPump_TestPump packet
|
|
#define getECU_DualPump_TestPumpPacketID() (0x08)
|
|
|
|
//! return the minimum encoded length for the ECU_DualPump_TestPump packet
|
|
#define getECU_DualPump_TestPumpMinDataLength() (3)
|
|
|
|
//! return the maximum encoded length for the ECU_DualPump_TestPump packet
|
|
#define getECU_DualPump_TestPumpMaxDataLength() (4)
|
|
|
|
//! Create the ECU_ThrottleCalibration packet
|
|
void encodeECU_ThrottleCalibrationPacketStructure(void* pkt, const ECU_ThrottleSettings_t* user);
|
|
|
|
//! Decode the ECU_ThrottleCalibration packet
|
|
int decodeECU_ThrottleCalibrationPacketStructure(const void* pkt, ECU_ThrottleSettings_t* user);
|
|
|
|
//! Create the ECU_ThrottleCalibration packet from parameters
|
|
void encodeECU_ThrottleCalibrationPacket(void* pkt, uint16_t pulseClosed, uint16_t pulseOpen, const ECU_ThrottleConfigBits_t* config, uint16_t pulseInputClosed, uint16_t pulseInputOpen);
|
|
|
|
//! Decode the ECU_ThrottleCalibration packet to parameters
|
|
int decodeECU_ThrottleCalibrationPacket(const void* pkt, uint16_t* pulseClosed, uint16_t* pulseOpen, ECU_ThrottleConfigBits_t* config, uint16_t* pulseInputClosed, uint16_t* pulseInputOpen);
|
|
|
|
//! return the packet ID for the ECU_ThrottleCalibration packet
|
|
#define getECU_ThrottleCalibrationPacketID() (PKT_ECU_THROTTLE_CALIBRATION)
|
|
|
|
//! return the minimum encoded length for the ECU_ThrottleCalibration packet
|
|
#define getECU_ThrottleCalibrationMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_ThrottleCalibration packet
|
|
#define getECU_ThrottleCalibrationMaxDataLength() (8)
|
|
|
|
//! Create the ECU_RPMLoopCalibration packet
|
|
void encodeECU_RPMLoopCalibrationPacketStructure(void* pkt, const ECU_GovernorSettings_t* user);
|
|
|
|
//! Decode the ECU_RPMLoopCalibration packet
|
|
int decodeECU_RPMLoopCalibrationPacketStructure(const void* pkt, ECU_GovernorSettings_t* user);
|
|
|
|
//! return the packet ID for the ECU_RPMLoopCalibration packet
|
|
#define getECU_RPMLoopCalibrationPacketID() (PKT_ECU_RPM_CALIBRATION)
|
|
|
|
//! return the minimum encoded length for the ECU_RPMLoopCalibration packet
|
|
#define getECU_RPMLoopCalibrationMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_RPMLoopCalibration packet
|
|
#define getECU_RPMLoopCalibrationMaxDataLength() (8)
|
|
|
|
//! Create the ECU_TPSDelayCalibration packet
|
|
void encodeECU_TPSDelayCalibrationPacketStructure(void* pkt, const ECU_ThrottleSettings_t* user);
|
|
|
|
//! Decode the ECU_TPSDelayCalibration packet
|
|
int decodeECU_TPSDelayCalibrationPacketStructure(const void* pkt, ECU_ThrottleSettings_t* user);
|
|
|
|
//! Create the ECU_TPSDelayCalibration packet from parameters
|
|
void encodeECU_TPSDelayCalibrationPacket(void* pkt, uint8_t delay, const ECU_ThrottleDelayConfigBits_t* delayConfig, uint8_t maxDelay, uint8_t minDelay, uint8_t softLimit, uint8_t falloffRate, uint8_t throttleTarget, uint8_t hardLimit);
|
|
|
|
//! Decode the ECU_TPSDelayCalibration packet to parameters
|
|
int decodeECU_TPSDelayCalibrationPacket(const void* pkt, uint8_t* delay, ECU_ThrottleDelayConfigBits_t* delayConfig, uint8_t* maxDelay, uint8_t* minDelay, uint8_t* softLimit, uint8_t* falloffRate, uint8_t* throttleTarget, uint8_t* hardLimit);
|
|
|
|
//! return the packet ID for the ECU_TPSDelayCalibration packet
|
|
#define getECU_TPSDelayCalibrationPacketID() (PKT_ECU_TPS_DELAY_CONFIG)
|
|
|
|
//! return the minimum encoded length for the ECU_TPSDelayCalibration packet
|
|
#define getECU_TPSDelayCalibrationMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_TPSDelayCalibration packet
|
|
#define getECU_TPSDelayCalibrationMaxDataLength() (8)
|
|
|
|
/*!
|
|
* The telmetry settings packet is used to configure the telemetry data rates
|
|
* for the ECU. The ECU will echo the packet as confirmation of its receipt.
|
|
* Send a zero length packet to request the current settings.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t fastTelemetryPeriod; //!< Time between fast telemetry packets in 50ms increments
|
|
uint8_t slowTelemetryPeriod; //!< Time between slow telemetry packets in 500ms increments
|
|
uint8_t silencePeriod; //!< Seconds of time the ECU waits after bootup before sending telemetry.
|
|
}ECU_TelemetrySettings_t;
|
|
|
|
//! Create the ECU_TelemetrySettings packet
|
|
void encodeECU_TelemetrySettingsPacketStructure(void* pkt, const ECU_TelemetrySettings_t* user);
|
|
|
|
//! Decode the ECU_TelemetrySettings packet
|
|
int decodeECU_TelemetrySettingsPacketStructure(const void* pkt, ECU_TelemetrySettings_t* user);
|
|
|
|
//! return the packet ID for the ECU_TelemetrySettings packet
|
|
#define getECU_TelemetrySettingsPacketID() (PKT_ECU_TELEMETRY_SETTINGS)
|
|
|
|
//! return the minimum encoded length for the ECU_TelemetrySettings packet
|
|
#define getECU_TelemetrySettingsMinDataLength() (3)
|
|
|
|
//! return the maximum encoded length for the ECU_TelemetrySettings packet
|
|
#define getECU_TelemetrySettingsMaxDataLength() (3)
|
|
|
|
//! Create the ECU_PumpConfig packet
|
|
void encodeECU_PumpConfigPacketStructure(void* pkt, const ECU_PumpSettings_t* user);
|
|
|
|
//! Decode the ECU_PumpConfig packet
|
|
int decodeECU_PumpConfigPacketStructure(const void* pkt, ECU_PumpSettings_t* user);
|
|
|
|
//! return the packet ID for the ECU_PumpConfig packet
|
|
#define getECU_PumpConfigPacketID() (PKT_ECU_PUMP_CONFIG)
|
|
|
|
//! return the minimum encoded length for the ECU_PumpConfig packet
|
|
#define getECU_PumpConfigMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_PumpConfig packet
|
|
#define getECU_PumpConfigMaxDataLength() (8)
|
|
|
|
//! Create the ECU_Pump2Config packet
|
|
void encodeECU_Pump2ConfigPacketStructure(void* pkt, const ECU_PumpSettings_t* user);
|
|
|
|
//! Decode the ECU_Pump2Config packet
|
|
int decodeECU_Pump2ConfigPacketStructure(const void* pkt, ECU_PumpSettings_t* user);
|
|
|
|
//! return the packet ID for the ECU_Pump2Config packet
|
|
#define getECU_Pump2ConfigPacketID() (PKT_ECU_PUMP_2_CONFIG)
|
|
|
|
//! return the minimum encoded length for the ECU_Pump2Config packet
|
|
#define getECU_Pump2ConfigMinDataLength() (7)
|
|
|
|
//! return the maximum encoded length for the ECU_Pump2Config packet
|
|
#define getECU_Pump2ConfigMaxDataLength() (7)
|
|
|
|
/*!
|
|
* The user data packet provides the user with 8 (eight) bytes of data for
|
|
* storing custom parameters or settings in ECU EEPROM (non-volatile) memory.
|
|
* The ECU does not make use of these values; they are simply for storing user
|
|
* data. Send a zero length packet to request the current settings. To set
|
|
* these values send the system command SET_USER_DATA. Data values must be set
|
|
* individually.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t userData[8]; //!< 8 bytes of user data
|
|
}ECU_UserData_t;
|
|
|
|
//! Create the ECU_UserData packet from parameters
|
|
void encodeECU_UserDataPacket(void* pkt, const uint8_t userData[8]);
|
|
|
|
//! Decode the ECU_UserData packet to parameters
|
|
int decodeECU_UserDataPacket(const void* pkt, uint8_t userData[8]);
|
|
|
|
//! return the packet ID for the ECU_UserData packet
|
|
#define getECU_UserDataPacketID() (PKT_ECU_USER_DATA)
|
|
|
|
//! return the minimum encoded length for the ECU_UserData packet
|
|
#define getECU_UserDataMinDataLength() (8)
|
|
|
|
//! return the maximum encoded length for the ECU_UserData packet
|
|
#define getECU_UserDataMaxDataLength() (8)
|
|
|
|
/*!
|
|
* First throttle curve packet, which contains the lower 6 term of the throttle
|
|
* linearization table. To request the throttle curve data (both packets), send
|
|
* the system command REQUEST_THROTTLE_CURVE_DATA. To change the throttle curve
|
|
* data send the system command SET_THROTTLE_CURVE_ELEMENT.
|
|
*/
|
|
typedef struct
|
|
{
|
|
float throttleCurve[6]; //!< Throttle output values for the lower 6 cells in the throttle lookup table
|
|
}ECU_ThrottleCurve_t;
|
|
|
|
//! Create the ECU_ThrottleCurve packet from parameters
|
|
void encodeECU_ThrottleCurvePacket(void* pkt, const float throttleCurve[6]);
|
|
|
|
//! Decode the ECU_ThrottleCurve packet to parameters
|
|
int decodeECU_ThrottleCurvePacket(const void* pkt, float throttleCurve[6]);
|
|
|
|
//! return the packet ID for the ECU_ThrottleCurve packet
|
|
#define getECU_ThrottleCurvePacketID() (PKT_ECU_THROTTLE_CURVE_0)
|
|
|
|
//! return the minimum encoded length for the ECU_ThrottleCurve packet
|
|
#define getECU_ThrottleCurveMinDataLength() (6)
|
|
|
|
//! return the maximum encoded length for the ECU_ThrottleCurve packet
|
|
#define getECU_ThrottleCurveMaxDataLength() (6)
|
|
|
|
//! Create the ECU_ThrottleCurve1 packet from parameters
|
|
void encodeECU_ThrottleCurve1Packet(void* pkt, const float throttleCurve[5]);
|
|
|
|
//! Decode the ECU_ThrottleCurve1 packet to parameters
|
|
int decodeECU_ThrottleCurve1Packet(const void* pkt, float throttleCurve[5]);
|
|
|
|
//! return the packet ID for the ECU_ThrottleCurve1 packet
|
|
#define getECU_ThrottleCurve1PacketID() (PKT_ECU_THROTTLE_CURVE_1)
|
|
|
|
//! return the minimum encoded length for the ECU_ThrottleCurve1 packet
|
|
#define getECU_ThrottleCurve1MinDataLength() (5)
|
|
|
|
//! return the maximum encoded length for the ECU_ThrottleCurve1 packet
|
|
#define getECU_ThrottleCurve1MaxDataLength() (5)
|
|
|
|
/*!
|
|
* The system command packets follow the format provided below. Refer further
|
|
* in the document for complete documentation on each system command packet.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration
|
|
uint8_t parambytes[3]; //!< Up to 3 parameter bytes for a system command
|
|
}ECU_SystemCommand_t;
|
|
|
|
//! Create the ECU_SystemCommand packet
|
|
void encodeECU_SystemCommandPacketStructure(void* pkt, const ECU_SystemCommand_t* user);
|
|
|
|
//! Decode the ECU_SystemCommand packet
|
|
int decodeECU_SystemCommandPacketStructure(const void* pkt, ECU_SystemCommand_t* user);
|
|
|
|
//! return the packet ID for the ECU_SystemCommand packet
|
|
#define getECU_SystemCommandPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SystemCommand packet
|
|
#define getECU_SystemCommandMinDataLength() (1)
|
|
|
|
//! return the maximum encoded length for the ECU_SystemCommand packet
|
|
#define getECU_SystemCommandMaxDataLength() (4)
|
|
|
|
/*!
|
|
* Save the current value of the analog throttle position input as the 'Closed'
|
|
* position. To calibrate the closed analog input position, set the desired
|
|
* analog input level, and send this command to the ECU.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
}ECU_CalibrateAnalogClosed_t;
|
|
|
|
//! Create the ECU_CalibrateAnalogClosed packet from parameters
|
|
void encodeECU_CalibrateAnalogClosedPacket(void* pkt);
|
|
|
|
//! Decode the ECU_CalibrateAnalogClosed packet to parameters
|
|
int decodeECU_CalibrateAnalogClosedPacket(const void* pkt, ECUSystemCommands* cmd);
|
|
|
|
//! return the packet ID for the ECU_CalibrateAnalogClosed packet
|
|
#define getECU_CalibrateAnalogClosedPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_CalibrateAnalogClosed packet
|
|
#define getECU_CalibrateAnalogClosedMinDataLength() (1)
|
|
|
|
//! return the maximum encoded length for the ECU_CalibrateAnalogClosed packet
|
|
#define getECU_CalibrateAnalogClosedMaxDataLength() (1)
|
|
|
|
/*!
|
|
* Save the current value of the analog throttle position input as the 'Open'
|
|
* position. To calibrate the open analog input position, set the desired
|
|
* analog input level, and send this command to the ECU.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
}ECU_CalibrateAnalogOpen_t;
|
|
|
|
//! Create the ECU_CalibrateAnalogOpen packet from parameters
|
|
void encodeECU_CalibrateAnalogOpenPacket(void* pkt);
|
|
|
|
//! Decode the ECU_CalibrateAnalogOpen packet to parameters
|
|
int decodeECU_CalibrateAnalogOpenPacket(const void* pkt, ECUSystemCommands* cmd);
|
|
|
|
//! return the packet ID for the ECU_CalibrateAnalogOpen packet
|
|
#define getECU_CalibrateAnalogOpenPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_CalibrateAnalogOpen packet
|
|
#define getECU_CalibrateAnalogOpenMinDataLength() (1)
|
|
|
|
//! return the maximum encoded length for the ECU_CalibrateAnalogOpen packet
|
|
#define getECU_CalibrateAnalogOpenMaxDataLength() (1)
|
|
|
|
/*!
|
|
* Save the current value of the throttle output pulse width to a temporary
|
|
* variable in the ECU. When the CALIBRATE_PULSE_WRITE command is sent to the
|
|
* ECU, this value will be saved as the 'Closed' pulse width.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
}ECU_CalibratePulseClosed_t;
|
|
|
|
//! Create the ECU_CalibratePulseClosed packet from parameters
|
|
void encodeECU_CalibratePulseClosedPacket(void* pkt);
|
|
|
|
//! Decode the ECU_CalibratePulseClosed packet to parameters
|
|
int decodeECU_CalibratePulseClosedPacket(const void* pkt, ECUSystemCommands* cmd);
|
|
|
|
//! return the packet ID for the ECU_CalibratePulseClosed packet
|
|
#define getECU_CalibratePulseClosedPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_CalibratePulseClosed packet
|
|
#define getECU_CalibratePulseClosedMinDataLength() (1)
|
|
|
|
//! return the maximum encoded length for the ECU_CalibratePulseClosed packet
|
|
#define getECU_CalibratePulseClosedMaxDataLength() (1)
|
|
|
|
/*!
|
|
* Save the current value of the throttle output pulse width to a temporary
|
|
* variable in the ECU. When the CALIBRATE_PULSE_WRITE command is sent to the
|
|
* ECU, this value will be saved as the 'Open' pulse width.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
}ECU_CalibratePulseOpen_t;
|
|
|
|
//! Create the ECU_CalibratePulseOpen packet from parameters
|
|
void encodeECU_CalibratePulseOpenPacket(void* pkt);
|
|
|
|
//! Decode the ECU_CalibratePulseOpen packet to parameters
|
|
int decodeECU_CalibratePulseOpenPacket(const void* pkt, ECUSystemCommands* cmd);
|
|
|
|
//! return the packet ID for the ECU_CalibratePulseOpen packet
|
|
#define getECU_CalibratePulseOpenPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_CalibratePulseOpen packet
|
|
#define getECU_CalibratePulseOpenMinDataLength() (1)
|
|
|
|
//! return the maximum encoded length for the ECU_CalibratePulseOpen packet
|
|
#define getECU_CalibratePulseOpenMaxDataLength() (1)
|
|
|
|
/*!
|
|
* Configure the throttle output positions. The CALIBRATE_PULSE_CLOSED and
|
|
* CALIBRATE_PULSE_OPEN commands should have already been sent to the ECU. The
|
|
* ECU then saves the temporary values as the 'Closed' and 'Open' throttle
|
|
* output values, respectively.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
}ECU_CalibratePulseWrite_t;
|
|
|
|
//! Create the ECU_CalibratePulseWrite packet from parameters
|
|
void encodeECU_CalibratePulseWritePacket(void* pkt);
|
|
|
|
//! Decode the ECU_CalibratePulseWrite packet to parameters
|
|
int decodeECU_CalibratePulseWritePacket(const void* pkt, ECUSystemCommands* cmd);
|
|
|
|
//! return the packet ID for the ECU_CalibratePulseWrite packet
|
|
#define getECU_CalibratePulseWritePacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_CalibratePulseWrite packet
|
|
#define getECU_CalibratePulseWriteMinDataLength() (1)
|
|
|
|
//! return the maximum encoded length for the ECU_CalibratePulseWrite packet
|
|
#define getECU_CalibratePulseWriteMaxDataLength() (1)
|
|
|
|
/*!
|
|
* Set one of four high-current output drivers.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
uint8_t driver; //!< Select driver number (1, 2, 3 or 4)
|
|
uint8_t status; //!< Set driver status (1 = ON, 0 = OFF)
|
|
}ECU_SetOutputDriver_t;
|
|
|
|
//! Create the ECU_SetOutputDriver packet from parameters
|
|
void encodeECU_SetOutputDriverPacket(void* pkt, uint8_t driver, uint8_t status);
|
|
|
|
//! Decode the ECU_SetOutputDriver packet to parameters
|
|
int decodeECU_SetOutputDriverPacket(const void* pkt, ECUSystemCommands* cmd, uint8_t* driver, uint8_t* status);
|
|
|
|
//! return the packet ID for the ECU_SetOutputDriver packet
|
|
#define getECU_SetOutputDriverPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SetOutputDriver packet
|
|
#define getECU_SetOutputDriverMinDataLength() (3)
|
|
|
|
//! return the maximum encoded length for the ECU_SetOutputDriver packet
|
|
#define getECU_SetOutputDriverMaxDataLength() (3)
|
|
|
|
/*!
|
|
* Turn the throttle linearization curve either on or off.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
uint8_t active; //!< Curve active (1 = ON, 0 = OFF)
|
|
}ECU_SetThrottleCurveActive_t;
|
|
|
|
//! Create the ECU_SetThrottleCurveActive packet from parameters
|
|
void encodeECU_SetThrottleCurveActivePacket(void* pkt, uint8_t active);
|
|
|
|
//! Decode the ECU_SetThrottleCurveActive packet to parameters
|
|
int decodeECU_SetThrottleCurveActivePacket(const void* pkt, ECUSystemCommands* cmd, uint8_t* active);
|
|
|
|
//! return the packet ID for the ECU_SetThrottleCurveActive packet
|
|
#define getECU_SetThrottleCurveActivePacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SetThrottleCurveActive packet
|
|
#define getECU_SetThrottleCurveActiveMinDataLength() (2)
|
|
|
|
//! return the maximum encoded length for the ECU_SetThrottleCurveActive packet
|
|
#define getECU_SetThrottleCurveActiveMaxDataLength() (2)
|
|
|
|
/*!
|
|
* Set individual elements in the throttle linearization lookup table.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
uint8_t index; //!< Index into the throttle curve table from 0 to 10 (0% to 100%) throttle input
|
|
float throttleOutput; //!< Percentage throttle output for this curve element
|
|
}ECU_SetThrottleCurveElement_t;
|
|
|
|
//! Create the ECU_SetThrottleCurveElement packet from parameters
|
|
void encodeECU_SetThrottleCurveElementPacket(void* pkt, uint8_t index, float throttleOutput);
|
|
|
|
//! Decode the ECU_SetThrottleCurveElement packet to parameters
|
|
int decodeECU_SetThrottleCurveElementPacket(const void* pkt, ECUSystemCommands* cmd, uint8_t* index, float* throttleOutput);
|
|
|
|
//! return the packet ID for the ECU_SetThrottleCurveElement packet
|
|
#define getECU_SetThrottleCurveElementPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SetThrottleCurveElement packet
|
|
#define getECU_SetThrottleCurveElementMinDataLength() (3)
|
|
|
|
//! return the maximum encoded length for the ECU_SetThrottleCurveElement packet
|
|
#define getECU_SetThrottleCurveElementMaxDataLength() (3)
|
|
|
|
/*!
|
|
* Request the throttle curve lookup table data. If requested on CAN, the data
|
|
* will be returned on CAN. If requested on RS232, the data will be returned on
|
|
* RS232.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
}ECU_RequestThrottleCurveData_t;
|
|
|
|
//! Create the ECU_RequestThrottleCurveData packet from parameters
|
|
void encodeECU_RequestThrottleCurveDataPacket(void* pkt);
|
|
|
|
//! Decode the ECU_RequestThrottleCurveData packet to parameters
|
|
int decodeECU_RequestThrottleCurveDataPacket(const void* pkt, ECUSystemCommands* cmd);
|
|
|
|
//! return the packet ID for the ECU_RequestThrottleCurveData packet
|
|
#define getECU_RequestThrottleCurveDataPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_RequestThrottleCurveData packet
|
|
#define getECU_RequestThrottleCurveDataMinDataLength() (1)
|
|
|
|
//! return the maximum encoded length for the ECU_RequestThrottleCurveData packet
|
|
#define getECU_RequestThrottleCurveDataMaxDataLength() (1)
|
|
|
|
/*!
|
|
* Reset the FuelUsed value. This will set the FuelUsed data to zero.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
}ECU_ResetFuelUsed_t;
|
|
|
|
//! Create the ECU_ResetFuelUsed packet from parameters
|
|
void encodeECU_ResetFuelUsedPacket(void* pkt);
|
|
|
|
//! Decode the ECU_ResetFuelUsed packet to parameters
|
|
int decodeECU_ResetFuelUsedPacket(const void* pkt, ECUSystemCommands* cmd);
|
|
|
|
//! return the packet ID for the ECU_ResetFuelUsed packet
|
|
#define getECU_ResetFuelUsedPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_ResetFuelUsed packet
|
|
#define getECU_ResetFuelUsedMinDataLength() (1)
|
|
|
|
//! return the maximum encoded length for the ECU_ResetFuelUsed packet
|
|
#define getECU_ResetFuelUsedMaxDataLength() (1)
|
|
|
|
/*!
|
|
* Set the fuel used divisor
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
uint16_t divisor; //!< The fuel used divisor. The fuel used value is divided by this divisor before being transmitted by the auxiliary processor. Set this value to 1 to leave the fuel used data unaffected. If you use values greater than 100 the divisor is automatically interpreted as being in units of 0.01 (i.e. 100 times the resolution).
|
|
}ECU_SetFuelUsedDivisor_t;
|
|
|
|
//! Create the ECU_SetFuelUsedDivisor packet from parameters
|
|
void encodeECU_SetFuelUsedDivisorPacket(void* pkt, uint16_t divisor);
|
|
|
|
//! Decode the ECU_SetFuelUsedDivisor packet to parameters
|
|
int decodeECU_SetFuelUsedDivisorPacket(const void* pkt, ECUSystemCommands* cmd, uint16_t* divisor);
|
|
|
|
//! return the packet ID for the ECU_SetFuelUsedDivisor packet
|
|
#define getECU_SetFuelUsedDivisorPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SetFuelUsedDivisor packet
|
|
#define getECU_SetFuelUsedDivisorMinDataLength() (3)
|
|
|
|
//! return the maximum encoded length for the ECU_SetFuelUsedDivisor packet
|
|
#define getECU_SetFuelUsedDivisorMaxDataLength() (3)
|
|
|
|
/*!
|
|
* Set or clear the Fuel Used reset flag. If this flag is set, the FuelUsed
|
|
* data will reset (to zero) when the ECU is power cycled.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
uint8_t reset; //!< 1 = Reset Fuel Used data on powerup 0 = Do not reset Fuel Used data on power up
|
|
}ECU_SetFuelUsedResetFlag_t;
|
|
|
|
//! Create the ECU_SetFuelUsedResetFlag packet from parameters
|
|
void encodeECU_SetFuelUsedResetFlagPacket(void* pkt, uint8_t reset);
|
|
|
|
//! Decode the ECU_SetFuelUsedResetFlag packet to parameters
|
|
int decodeECU_SetFuelUsedResetFlagPacket(const void* pkt, ECUSystemCommands* cmd, uint8_t* reset);
|
|
|
|
//! return the packet ID for the ECU_SetFuelUsedResetFlag packet
|
|
#define getECU_SetFuelUsedResetFlagPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SetFuelUsedResetFlag packet
|
|
#define getECU_SetFuelUsedResetFlagMinDataLength() (2)
|
|
|
|
//! return the maximum encoded length for the ECU_SetFuelUsedResetFlag packet
|
|
#define getECU_SetFuelUsedResetFlagMaxDataLength() (2)
|
|
|
|
/*!
|
|
* Manually set the RPM governor mode.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
ECUGovernorMode mode; //!< MODE 0 = Governor Off (Open loop throttle control) 1 = Governor based on throttle command 2 = Governor based on RPM command
|
|
}ECU_SetGovernorMode_t;
|
|
|
|
//! Create the ECU_SetGovernorMode packet from parameters
|
|
void encodeECU_SetGovernorModePacket(void* pkt, ECUGovernorMode mode);
|
|
|
|
//! Decode the ECU_SetGovernorMode packet to parameters
|
|
int decodeECU_SetGovernorModePacket(const void* pkt, ECUSystemCommands* cmd, ECUGovernorMode* mode);
|
|
|
|
//! return the packet ID for the ECU_SetGovernorMode packet
|
|
#define getECU_SetGovernorModePacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SetGovernorMode packet
|
|
#define getECU_SetGovernorModeMinDataLength() (2)
|
|
|
|
//! return the maximum encoded length for the ECU_SetGovernorMode packet
|
|
#define getECU_SetGovernorModeMaxDataLength() (2)
|
|
|
|
/*!
|
|
* Set the serial mode used for Autronic relay. When Autronic relay is enabled
|
|
* the external serial port of the ECU is reconfigured to connect to ECUCal,
|
|
* relaying bytes to the internal autronic processor; while still allowing the
|
|
* auxiliary processor to see telemetry from Autronic. This is fundamentally
|
|
* different from using the switch to calibration mode, which bypasses the
|
|
* auxiliary processor altogether, cutting it off from autronic telemetry.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
ECUAutronicRelayState mode; //!< The serial relay mode to command
|
|
}ECU_SetSerialMode_t;
|
|
|
|
//! Create the ECU_SetSerialMode packet from parameters
|
|
void encodeECU_SetSerialModePacket(void* pkt, ECUAutronicRelayState mode);
|
|
|
|
//! Decode the ECU_SetSerialMode packet to parameters
|
|
int decodeECU_SetSerialModePacket(const void* pkt, ECUSystemCommands* cmd, ECUAutronicRelayState* mode);
|
|
|
|
//! return the packet ID for the ECU_SetSerialMode packet
|
|
#define getECU_SetSerialModePacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SetSerialMode packet
|
|
#define getECU_SetSerialModeMinDataLength() (2)
|
|
|
|
//! return the maximum encoded length for the ECU_SetSerialMode packet
|
|
#define getECU_SetSerialModeMaxDataLength() (2)
|
|
|
|
/*!
|
|
* Set a custom address value for the ECU.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
uint16_t address; //!< ECU address in the range {1, 65534}
|
|
}ECU_SetECUAddress_t;
|
|
|
|
//! Create the ECU_SetECUAddress packet from parameters
|
|
void encodeECU_SetECUAddressPacket(void* pkt, uint16_t address);
|
|
|
|
//! Decode the ECU_SetECUAddress packet to parameters
|
|
int decodeECU_SetECUAddressPacket(const void* pkt, ECUSystemCommands* cmd, uint16_t* address);
|
|
|
|
//! return the packet ID for the ECU_SetECUAddress packet
|
|
#define getECU_SetECUAddressPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SetECUAddress packet
|
|
#define getECU_SetECUAddressMinDataLength() (3)
|
|
|
|
//! return the maximum encoded length for the ECU_SetECUAddress packet
|
|
#define getECU_SetECUAddressMaxDataLength() (3)
|
|
|
|
/*!
|
|
* Save a single byte of USER_DATA in EEPROM.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
uint8_t index; //!< USER_DATA address (0 to 7)
|
|
uint8_t userdata; //!< USER_DATA variable
|
|
}ECU_SetUserData_t;
|
|
|
|
//! Create the ECU_SetUserData packet from parameters
|
|
void encodeECU_SetUserDataPacket(void* pkt, uint8_t index, uint8_t userdata);
|
|
|
|
//! Decode the ECU_SetUserData packet to parameters
|
|
int decodeECU_SetUserDataPacket(const void* pkt, ECUSystemCommands* cmd, uint8_t* index, uint8_t* userdata);
|
|
|
|
//! return the packet ID for the ECU_SetUserData packet
|
|
#define getECU_SetUserDataPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_SetUserData packet
|
|
#define getECU_SetUserDataMinDataLength() (3)
|
|
|
|
//! return the maximum encoded length for the ECU_SetUserData packet
|
|
#define getECU_SetUserDataMaxDataLength() (3)
|
|
|
|
/*!
|
|
* Reset the engine runtime.
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
uint32_t time; //!< The new value of the engine time counter in seconds
|
|
}ECU_ResetEngineTime_t;
|
|
|
|
//! Create the ECU_ResetEngineTime packet from parameters
|
|
void encodeECU_ResetEngineTimePacket(void* pkt, uint32_t time);
|
|
|
|
//! Decode the ECU_ResetEngineTime packet to parameters
|
|
int decodeECU_ResetEngineTimePacket(const void* pkt, ECUSystemCommands* cmd, uint32_t* time);
|
|
|
|
//! return the packet ID for the ECU_ResetEngineTime packet
|
|
#define getECU_ResetEngineTimePacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_ResetEngineTime packet
|
|
#define getECU_ResetEngineTimeMinDataLength() (1)
|
|
|
|
//! return the maximum encoded length for the ECU_ResetEngineTime packet
|
|
#define getECU_ResetEngineTimeMaxDataLength() (4)
|
|
|
|
/*!
|
|
* Reset the ECU
|
|
*/
|
|
typedef struct
|
|
{
|
|
ECUSystemCommands cmd; //!< The command enumeration. Field is encoded constant.
|
|
}ECU_ResetECU_t;
|
|
|
|
//! Create the ECU_ResetECU packet from parameters
|
|
void encodeECU_ResetECUPacket(void* pkt);
|
|
|
|
//! Decode the ECU_ResetECU packet to parameters
|
|
int decodeECU_ResetECUPacket(const void* pkt, ECUSystemCommands* cmd);
|
|
|
|
//! return the packet ID for the ECU_ResetECU packet
|
|
#define getECU_ResetECUPacketID() (PKT_ECU_SYS_CMD)
|
|
|
|
//! return the minimum encoded length for the ECU_ResetECU packet
|
|
#define getECU_ResetECUMinDataLength() (4)
|
|
|
|
//! return the maximum encoded length for the ECU_ResetECU packet
|
|
#define getECU_ResetECUMaxDataLength() (4)
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif // _ECUPACKETS_H
|