-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathELM327.h
266 lines (215 loc) · 9.22 KB
/
ELM327.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
/* Copyright 2011 David Irvine
This program 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 program 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/>.
*/
#ifndef ELM327_h
#define ELM327_h
#include "Arduino.h"
#define ELM_TIMEOUT 1000
#define ELM_BAUD_RATE 9600
#define ELM_PORT Serial3
#define ELM_SUCCESS 0
#define ELM_NO_RESPONSE 1
#define ELM_BUFFER_OVERFLOW 2
#define ELM_GARBAGE 3
#define ELM_UNABLE_TO_CONNECT 4
#define ELM_NO_DATA 5
class Elm327
{
public:
byte begin();
byte getVersion(String &rev);
byte getIgnMon(bool &powered);
byte getVoltage(float &voltage);
byte engineLoad(byte &load);
void echoOff();
/**
Gets the Coolant Temperature. Reads PID 05 from the OBD interface and sets
temp to the value returned after conversion.
@param[out] temp Signed integer value is set to the coolant temperature.
- Minimum: -40
- Maximum Value: 215
- Units: °C
*/
byte coolantTemperature(int &temp);
/**
Gets the fuel trim for bank 1 in the short term. Reads PID 06 from the OBD
interface and sets percent to the value returned after conversion.
@param[out] percent - Signed integer is set to the percent fuel trim.
- Minimum Value: -100
- Maximum Value: 99.2
- Units: %
*/
byte fuelTrimBank1ShortTerm(int &percent);
/**
Gets the fuel trim for bank 2 in the short term. Reads PID 07 from the OBD
interface and sets percent to the value returned after conversion.
@param[out] percent - Signed integer is set to the percent fuel trim.
- Minimum Value: -100
- Maximum Value: 99.2
- Units: %
*/
byte fuelTrimBank2ShortTerm(int &percent);
/**
Gets the fuel trim for bank 1 in the long term. Reads PID 08 from the OBD
interface and sets percent to the value returned after conversion.
@param[out] percent - Signed integer is set to the percent fuel trim.
- Minimum Value: -100
- Maximum Value: 99.2
- Units: %
*/
byte fuelTrimBank1LongTerm(int &percent);
/**
Gets the fuel trim for bank 2 in the long term. Reads PID 09 from the OBD
interface and sets percent to the value returned after conversion.
@param[out] percent - Signed integer is set to the percent fuel trim.
- Minimum Value: -100
- Maximum Value: 99.2
- Units: %
*/
byte fuelTrimBank2LongTerm(int &percent);
/**
Gets the fuel pressure. Reads PID 0A from the OBD interface and sets pressure
to the value returned after conversion.
@param[out] pressure - Signed integer is set to the fuel pressure.
- Minimum Value: 0
- Maximum Value: 765
- Units: kPa (Absolute)
*/
byte fuelPressure(int &pressure);
/**
Gets the Intake Manifold Absolute Pressure. Reads PID 0B from the OBD
inteface and sets pressure to the value returned after conversion.
@param[out] pressure Byte set to the manifold pressure
- Minimum Value: 0
- Maximum Value: 255
- Units: kPa (Absolute)
*/
byte intakeManifoldAbsolutePressure(byte &pressure);
/**
Gets the current engine RPM. Reads PID 0C from the OBD Interface and
sets rpm to the value returned after conversion.
@param[out] rpm Unsigned integer is set to the current engine rpm.
- Minimum Value: 0
- Maximum Value: 16,383
- Units: RPM
*/
byte engineRPM(int &rpm);
/**
Gets the current speed of the vehicle in km/h. Reads PID 0D form the OBD
interface and sets speed to the value returned after conversion.
@param[out] speed Byte is set to the current speed of the vehicle.
- Minimum Value: 0
- Maximum Value: 255
- Units: km/h
*/
byte vehicleSpeed(byte &speed);
/**
Gets the timing advance of the vehicle relative to TDC on the number one cylinder.
Reads PID 0E from the OBD interface and sets advance to the value returned after
conversion.
@param[out] advance Integer set to the timing advance value.
- Minimum Value: -64
- Maximum Value: 63.5
- Units: ° from TDC
*/
byte timingAdvance(int &advance);
/**
Gets the intake air temperature. Reads PID 0F from the OBD interface and sets
temperature to the value returned after conversion.
@param[out] temperature Integer set to the intake air temperature
- Minimum Value: -40
- Maximum Value: 215
- °C
*/
byte intakeAirTemperature(int &temperature);
/**
Gets the Manifold Absolute Flow (MAF) rate. Reads PID 10 from the OBD interface
and sets rate to the value returned after conversion.
@param[out] rate Integer value set to the flow rate.
- Minimum Value: -40
- Maximum Value: 215
- °C
*/
byte MAFAirFlowRate(unsigned int &rate);
/**
Gets the current throttle position. Reads PID 11 from the OBD interface
and sets position to the value returned after conversion.
@param[out] position Byte containing throttle position.
- Minimum Value: 0
- Maximum Value: 100
- %
*/
byte throttlePosition(byte &position);
byte o2SensorBank1Sensor1(byte &voltage, byte &trim);
byte o2SensorBank1Sensor2(byte &voltage, byte &trim);
byte o2SensorBank1Sensor3(byte &voltage, byte &trim);
byte o2SensorBank1Sensor4(byte &voltage, byte &trim);
byte o2SensorBank2Sensor1(byte &voltage, byte &trim);
byte o2SensorBank2Sensor2(byte &voltage, byte &trim);
byte o2SensorBank2Sensor3(byte &voltage, byte &trim);
byte o2SensorBank2Sensor4(byte &voltage, byte &trim);
byte o2sensorRead(const char *bank, byte &voltage, byte &trim);
byte auxiliaryInputStatus(bool &auxStatus);
byte engineRunTime(unsigned int &runTime);
byte distanceMIL(unsigned int &distance);
byte relativeFuelRailPressure(unsigned int &pressure);
byte absoluteFuelRailPressure(unsigned int &pressure);
byte o2S1WRVoltage(unsigned int &equivRatio, unsigned int &voltage);
byte o2S2WRVoltage(unsigned int &equivRatio, unsigned int &voltage);
byte o2S3WRVoltage(unsigned int &equivRatio, unsigned int &voltage);
byte o2S4WRVoltage(unsigned int &equivRatio, unsigned int &voltage);
byte o2S5WRVoltage(unsigned int &equivRatio, unsigned int &voltage);
byte o2S6WRVoltage(unsigned int &equivRatio, unsigned int &voltage);
byte o2S7WRVoltage(unsigned int &equivRatio, unsigned int &voltage);
byte o2S8WRVoltage(unsigned int &equivRatio, unsigned int &voltage);
byte commandedEGR(byte &egr);
byte EGRError(int &error);
byte commandedEvaporativePurge(byte &purge);
byte fuelLevel(byte &level);
byte warmUpsSinceLastCleared(byte &warmUps);
byte distanceSinceLastCleared(unsigned int &distance);
byte evapPressure(int &pressure);
byte barometricPressure(byte &pressure);
byte o2S1WRCurrent(unsigned int &equivRatio, int ¤t);
byte o2S2WRCurrent(unsigned int &equivRatio, int ¤t);
byte o2S3WRCurrent(unsigned int &equivRatio, int ¤t);
byte o2S4WRCurrent(unsigned int &equivRatio, int ¤t);
byte o2S5WRCurrent(unsigned int &equivRatio, int ¤t);
byte o2S6WRCurrent(unsigned int &equivRatio, int ¤t);
byte o2S7WRCurrent(unsigned int &equivRatio, int ¤t);
byte o2S8WRCurrent(unsigned int &equivRatio, int ¤t);
byte catalystTemperatureBank1Sensor1( int &temperature);
byte catalystTemperatureBank2Sensor1( int &temperature);
byte catalystTemperatureBank1Sensor2( int &temperature);
byte catalystTemperatureBank2Sensor2( int &temperature);
byte controlModuleVoltage(unsigned int &voltage);
byte absoluteLoadValue(unsigned int &load);
byte commandEquivalenceRatio(float &ratio);
byte relativeThrottlePosition(byte &position);
byte ambientAirTemperature(int &temperature);
byte absoluteThrottlePositionB(byte &position);
byte absoluteThrottlePositionC(byte &position);
byte acceleratorPedalPositionD(byte &position);
byte acceleratorPedalPositionE(byte &position);
byte acceleratorPedalPositionF(byte &position);
byte commandedThrottleActuator(byte &position);
private:
byte o2WRVoltage(const char *sensor, unsigned int &equivRatio, unsigned int &voltage);
byte o2WRCurrent(const char *sensor, unsigned int &equivRatio, int ¤t);
byte catTemperature(const char *sensor, int &temperature);
byte getBytes( const char *mode, const char *chkMode, const char *pid, byte *values, unsigned int numValues);
byte runCommand(const char *cmd, char *data, unsigned int dataLength);
bool getBit(byte b, byte p);
byte getFuelTrim(const char *pid, int &percent);
void flush();
};
#endif