ELMo is a library that simplifies communication between ELM327 devices (like your OBD-II reader) and ESP32 microprocessors. The library allows for this communication to happen synchronously, no more callback hell! This library is intended to be a barebones, yet easy-to-use middle man between your logic and the ELM327 device.
Method 1: Arduino Library manager
- Open the library manager in your IDE of choice (Arduino IDE or PlatformIO)
- Search for
ELMo
- Click install
include
ELMo in your project- Profit!
Method 2: GitHub Releases
- Go to the Releases page
- Look at the latest version, denoted by the tag
- Download the source as a
.zip
file - Extract the
.zip
file to yourlibraries
directory
Advanced instructions and function definitions can be found in the Wiki. To get started, however, all you need to do is:
- Create an ELMo instance with
ELMo ELM;
- Customize any of the settings if needed, or give the defaults a shot
- Initialize the connection to the device with
ELM.initialize();
- You should probably do this in
setup();
- You should probably do this in
- Send messages to the device using
ELM.send("command");
- Wanna know what commands to send? Read on!
The way that you communicate with an ELM device (and the way it communicates back) is by sending messages back and forth. The messages you send out are called commands.
There are two kinds of commands:
- "AT" commands
- OBD-II commands.
Most users will never have to issue an AT command.
These messages are prepended by the letters "AT" (go figure) and are used to speak to the ELM controller chip. These commands are read by the ELM and NOT forwarded to the car.
"Forget this! I want to talk to the car!"
If this is you, I recommend sticking around for this quick word on AT commands. However, you can skip to the "OBD-II Commands" section below for details on how to talk to the car. Now, back to AT Commands. Let's start with an example.
The command AT Z
will tell the ELM327 device to reset itself.
AT
means that this is a command intended for the ELM device itself, not for the car.Z
tells the ELM device to reset.
"But wait!", you say. "How am I supposed to know that Z
means "reset"?"
Great question! Everything you need to know about ELM327 commands is in the ELM327 datasheet! AT Commands and their descriptions begin on page 10.
This document might seem overwhelming at first, but it contains lots of great information that'll let you unlock all the capabilities of your ELM327 reader. I recommend reading it, it's a thrilling tale. However, you do NOT have to read the document from cover to cover in order to use ELMo.
These are commands that let you talk with your car. They're typically composed of two parts, an OBD-II mode identifier (aka. service identifier) and some Parameter ID, or PID. Let's look at an example:
01 05
This command gives you the current Engine Coolant Temperature (ECT).
- Mode 01: This mode lets you check current car data.
- PID 05: This PID asks the car for the ECT. Had you sent a PID of
01
, the car would've given you stored DTCs (codes).
"But wait!", I hear you say. "How am I supposed to know what 01 or 05 mean? How do I reset codes?"
I'm glad you asked! There are two great resources to answer all your OBD-II questions:
- The OBD-II PIDs Wikipedia page.
- The ELM327 datasheet. Modes and PID descriptions begin on page 33.
The datasheet might seem overwhelming at first, but it contains lots of great information that'll let you unlock all the capabilities of your ELM327 reader. I recommend reading it, it's a thrilling tale. You can use the Find tool of your PDF viewer to search for any particular sections you may be interested in.
Here are some of the highlights:
- Talking to the Vehicle (MUST READ!) (page 33 and 34).
- NOTE: The
ELMo.initialize()
function sends a01 00
command so you don't have to. - This section contains mode definitions.
- These pages contain instructions on how to send commands. I recommend reading this as well.
- Details on how responses are formatted are also present here.
- NOTE: The
- Interpreting Trouble Codes (page 36).
- Resetting Trouble Codes (page 37).
- Multiline Responses (page 44).
- Power Control (page 67).
This project is licensed under the MIT License.