Geotab Firmware Product Guide
User Guide
14 mins to read
Browse resources and information about telematics devices, engine data, ignition detection, accelerometers, GPS, and more. Learn more about firmware releases and how they may affect your fleet.
Firmware Releases
Firmware versions are published from one of three branches: Stable Release, Release Candidate, and Beta. The firmware branches are considered three separate copies of the firmware code base. The Stable Release branch, the most stable branch, aims to fix critical issues. The Release Candidate branch aims to fix issues to increase stability and may accept new features, when appropriate. The Beta branch, the most unstable branch, accepts all new features but may introduce instabilities. Please refer to the Firmware Release Notes document to review the release notes.
✱ NOTE: The Release Candidate branch will eventually become the Stable Release branch, and the Beta branch will eventually become the Release Candidate branch. Geotab will create a new Beta branch when this occurs. This process occurs approximately every two months. See the Firmware Rollout Process for more details.
Telematics Device
Installation
The telematics device must be correctly installed to ensure functionality. For more information on the telematics installation, please refer to the installation documentation and blog. For specific installation requirements, please refer to the Vehicle Specific Installation Notes.
Specifications
For details about device specifications, please refer to the Hardware Support documents.
IOX
IOX Expansion Technology is integrated with the telematics device and allows the device to connect to additional hardware. For more information on IOXs, please refer to the IOX documentation and the IOX blog.
Curve Logging
In general and where appropriate, most data is saved using the curve-based algorithm.
LED
The device has three LEDs to indicate the status of the device:
- The red LED indicates that the device detected ignition and has powered ON;
- The green LED indicates that the device has connected to a cellular network; and
- The blue LED indicates that the device has latched onto a GPS signal.
Device Beeping
When the device powers on for the first time after installation, it enters the Troubleshooting Beeping Mode to assist with the installation for the first two trips. The Troubleshooting Beeping Mode has various beep indications:
- Six short beeps to indicate power detection,
- One short beep when a change in ignition state is detected,
- Two short beeps when searching for cellular connection (occurs periodically),
- Three short beeps when cellular connection is established, and
- One long beep when GPS is latched.
✱ NOTE: Device beeping can be enabled and configured through MyGeotab.
Heartbeat
When the vehicle ignition is turned off, the device powers down and enters Sleep Mode. In Sleep Mode, the device periodically pings the server — similar to a heartbeat to ensure the device remains connected and checks for any pending firmware updates. The device heartbeats every 30 minutes for the first 72 hours. After 72 hours, the device heartbeats once every 23 hours.
Firmware Updates
Firmware updates occur after an ignition off event or during heartbeats. The request for firmware update starts once the device has uploaded all of its data and the modem is about to go offline.
Disabled Device Mode
The device enters Disabled Mode by downloading a parameter while in Suspend or Terminate Mode. Upon entering the disabled state, the device resets and erases log data, accident data, and timestamp data from the flash memory. While disabled, the device does not create logs, update firmware, or detect ignition. The device does however, periodically connect to the Gateway servers in order to download new parameters. When a disabled device connects to the Gateway servers, it logs a Device Disabled fault. The connection frequency of a disabled device is 12 hours after entering the disabled state, then every 23 hours thereafter. If a device is in Terminate Mode, the cellular account is canceled and the device is permanently disabled. In Suspend mode, the cellular account remains active so that it can download new parameters, and exit Disabled Mode once an active rate plan is applied.
Engine Data
For information about the engine status data collected by the telematics device, please refer to the sheet. The Vehicle Type and Engine Data sheet represents an overview of engine data for Odometer, Driver Seat Belt, Fuel Usage, and Fuel Level supported by the telematics device.
✱ NOTE: The percentages in the engine data columns are calculated based on the total number of vehicles in the field with telematics devices.
Engine Data Priority
Vehicles often use multiple sources to report data. When powered on, the device identifies all existing source variations, then selects the one most likely to provide accurate data. For engine data displayed on the instrument cluster (i.e. odometer, cruise control etc.), the firmware prioritizes the instrument cluster computer above other computers. The instrument cluster computer is prioritized because the end user often wants to see a representation of what is visually available in the vehicle rather than what is available in the engine computer.
Listen-Only Mode
Some vehicle data types are broadcasted by the vehicle while other data types require the device to send a request to the vehicle. If a device detects a connection issue with the vehicle, the device enters Listen Only Mode. In the Listen Only Mode, the device will not request any data, and therefore no longer log any vehicle data that must be requested.
✱ NOTE: A small number of vehicles sound an alert if any On-Board Diagnostic (OBD) third-party device requests data via the OBD port while the vehicle is locked and the ignition is off. As of firmware version x.27.x, the GO9 disables this alert by default in order to provide full access to data according to the rate plan, without risk of sounding the alert. For more information, including how to verify and control the alert’s status, please consult the OBD Port Audible Alert FAQ.
Vehicle Identification Number (VIN)
The VIN is a standard request and is available on most vehicle types. Some vehicles do not reply to the VIN request or reply with an invalid VIN number. If we do not receive a valid VIN from the vehicle, we save the VIN as 0 s.
Fuel
MyGeotab uses Device Total Fuel and Device Total Idle Fuel to calculate fuel economy, and Fuel Level (percentage or volume) to calculate fill up events. The device flash memory saves the Device Total Fuel values to ensure the data is retained after a firmware update or power cycle of the telematics device. If the telematics device is moved to a new vehicle — detected by a change in VIN — the Total Fuel values are reset to 0. The Device Total Fuel is both curved logged and logged after ignition is turned OFF.
Seat Belt and Odometer
Seat Belt Detection
The telematics device goes through a comprehensive Seat Belt data detection and verification process. The process normally takes three trips for the seat belt data to validate. Each trip must last longer than one minute and include driving — at a speed greater than 10 km/hr — to consider the data as part of the validation process. For data detection, the device needs to recognize seatbelt changes. Seat belt changes occur during ignition events.
✱ NOTE: The Seat Belt data detection and verification process may take longer if there are multiple sources of seat belt data on a particular vehicle type.
Seat Belt Functionality
When the telematics device first powers on, a seat belt value of -1 indicates the value is unknown and prevents MyGeotab from creating an ongoing Seat Belt Unbuckled exception — until the seat belt is re-detected. On every ignition change event, if the seatbelt was previously in a buckled or unbuckled state, the seat belt status is set to Unknown. Setting the seat belt data to unknown ensures that the data from previous trips is not carried over to the present trip.
Odometer Detection
The Telematics Device has a three-stage odometer detection process. In the first stage, the device attempts to locate the odometer information. Once a possible source for the odometer is found, the device begins the second stage to ensure that the data values increment properly. The second stage requires at least 0.5 km of driving to complete verification. In the third stage, the device uses GPS data to verify the odometer unit over at least 5 km of driving. Stage 2 and 3 can be done over multiple trips.
Odometer Functionality
The Odometer is logged for every ignition ON, ignition OFF, and at every two (2) km or every one (1) km — if the GPS is invalid. Odometer validation occurs every time we receive an odometer value to ensure the odometer does not jump 15 km forwards or backwards between readings. If this happens twice during two trips with no recovery — i.e. the odometer does not return to its value within 15 km — an invalid odometer fault is logged and the telematics device stops reporting the odometer values.
Voltage
To record the vehicle’s crank voltage curve, 10 seconds of instantaneous voltage logs are saved using the curve algorithm at every ignition ON event. An average voltage value is saved whenever it changes by 250 mV or more. If the vehicle voltage falls below 11.6 V for five minutes, the device logs a Low voltage warning fault and forces a heartbeat to ensure the low voltage value is communicated. 11.6 V is the default value and can be changed through a parameter. Heartbeats switch to every 23 hours once this has occurred to help preserve battery power. If the vehicle voltage is consistently lower than 7 V, the telematics device remains in Low Power Mode and will not operate until the voltage rises above 8V.
Oil Pressure
Oil pressure is saved using curve logic under the following conditions:
- Engine RPM is above 450; and
- Coolant temperature is above 52 degrees C; and
- Oil pressure is less than or equal to 84 kPa.
Ignition Detection
Vehicle ignition status is detected by the device using one of the following three methods:
- Engine-Based;
- Three-Wire; or
- Trip Tracking/Two-Wire.
Engine-Based
The device first wakes up by detecting voltage spikes or accelerometer-based movement and then uses RPM or Engine Road Speed to determine ignition status.
Three-Wire
The device is connected via the special three-wire harness: power, ground, and ignition. The harness ignition connection is responsible for setting the ignition state.
Trip Tracking/Two-Wire
If the device does not receive engine data or is not connected to a three-wire harness, then the device attempts to determine ignition based on a logic called Trip Tracking. Another logic, called Two-Wire, is more voltage-focused and can be used to determine ignition — enabled through a custom parameter.
Accelerometer
The accelerometer is calibrated while the vehicle is driven. As a result, there are no orientation restrictions when installing the telematics device for the accelerometer to work. The device must be securely installed for the accelerometer data to remain consistent. Because of real-time calibration, it can take one or two trips to calibrate the accelerometer. In addition, calibration relies on GPS data and may take longer to calibrate if the device is in an area with weak GPS signals. Accelerometer data is sampled at 100 Hz and saved using the curve-based algorithm. The accelerometer ranges from −8 g to +8 g with a resolution of 4 mg/bit for GO8 and prior, and 0.244 mg/bit for GO9.
Installation
Telematics devices that are not securely installed have less reliable accelerometer behavior and may potentially not calibrate. Mounting the device to a surface with excessive vibration or contact may generate immoderate and/or incorrect accelerometer data. The telematics device can detect excessive accelerometer data and stops logging accelerometer data when excessive data collection occurs. A telematics device fault is saved at the time of the excessive logging detection.
Orientation
Once calibrated, the accelerometer is virtually oriented as follows:
- The x-axis reflects the forward/back motion of the vehicle, with a positive x-value indicating acceleration and a negative x-value indicating deceleration;
- The y-axis reflects the sides of the vehicle, with a positive y-value indicating a left turn and a negative y-value indicating a right turn; and
- The z-axis reflects the up/down motion of the vehicle, with a positive z-value indicating down (gravity).
Harsh Driving
The accelerometer constantly logs events over 300mg in the X-axis (front/back) or Y-axis (side/side) direction using the curve-based logging algorithm. The constant logging ensures that as long as you set your rules to a minimum of 300 mg, the events are always observed.
Driver Feedback
Beeping for driver feedback on harsh driving events is configured in MyGeotab. Different thresholds are available for acceleration, braking, and cornering. No feedback is provided when the vehicle is traveling under 10 km/h.
Accident Detection
A separate accident data memory buffer is used to store second-by-second data. The data is only uploaded when there is an accelerometer event with a combined X/Y magnitude over 2.5 g. Also, if the Z-axis values become negative, the device detects a possible rollover event which triggers an accident event. Only four accident data buffer uploads can occur per trip. Custom parameters can be used to change the value of 2.5 g, but please note that the value cannot be set to less than 1.9 g. Although accelerometer data may be disabled due to excessive logging, accident level accelerometer data is still logged.
Accelerometer Data Logging During Accident
Accelerometer data during an accident is logged using the curve, with no accident-specific logic. The curve logic detects that there is a change in acceleration and sends the appropriate accelerometer points. Accelerometer data logic must be enabled as part of the Rate Plan (for example, accident accelerometer data is not available on the Asset Plan but the fault will be logged).
Reverse Detection
The accelerometer can be used to detect reverse if you do not receive gear data from the vehicle’s engine computer. The device determines that the vehicle is out-of-reverse if the vehicle is stopped for five seconds or if the vehicle starts moving forward. Reverse detect is logged as follows:
- Into reverse is logged as Gear Position with a value of -1; and
- Out of reverse is logged as Gear Position with a value of 0 (neutral).
GPS
Logging
Curve-based logging is performed for both GPS position and GPS road speed to ensure the best fit on the map, as well as an accurate speed profile and idle time.
The following are default error values for the curve logging:
- Pro Plus with Active Tracking:
- Max Curve Distance Error = 7.8 m
- Max Position Estimate Error = 28.5 m
- Max Curve Speed Error = 3.6 km/hr
- Max Speed Estimate Error = 7.3 km/hr
- Pro or Pro Plus without Active Tracking:
- Max Curve Distance Error = 7.8 m
- Max Position Estimate Error = 399 m
- Max Curve Speed Error = 5.5 km/hr
- Max Speed Estimate Error = Disabled
- Base:
- Max Curve Distance Error = 7.8 m
- Max Position Estimate Error = 1026 m
- Max Curve Speed Error = 5.5 km/hr
- Max Speed Estimate Error = Disabled
✱ NOTE: An estimate error is used to predict where the value should be based on the last saved GPS record, and then compares the current point with the estimated point to determine if it should be logged.
If GPS data is invalid, the road speed curve logging is performed using engine-based road speed. Latitude and longitude are used to validate GPS-based road speed. If movement is detected by the accelerometer while ignition is off, the GPS is turned on and checks if the latitude or longitude changes by a sufficient amount (approximately 100 m). If the device detects a sufficient change in distance, the trip is tracked and the modem connects (if it’s a live unit), and remains connected until the device stops moving.
Validity and Precision
The telematics device obtains the latitude and longitude directly from the GPS module. To consider a GPS position from the GPS module valid, the following conditions must be met:
- 3D fix (a minimum of 4 satellites);
- Position Dilution of Precision (DOP) must be 6 or better;
- Time DOP must be 10 or better;
- Speed accuracy estimate must be better than 1 m/s;
- Ignore first valid;
- Ignore data that has a speed increase over 30 km/h from the previous data;
- Ignore data if the difference between the GPS speed and the calculated speed, using the latitude and longitude of the previous two seconds, is greater than 10 km/h; and
- Each bit of latitude and longitude has a precision of 0.0000256 of a degree.
Library Inclusion Notices
Please refer to this document for a list of notices for included firmware/software libraries.
Device Variation Functional Differences
The firmware contains slight functional differences for the GO RUGGED compared to the other devices type. Please see GO RUGGED Firmware Functional Differences [PUB] for the full list of differences.