The invention relates to systems for maintaining accurate information about the attributes of a vehicle.
Increasingly, electronic components are being relied upon to facilitate the operations of a vehicle. These electronic components aid in the development of sophisticated vehicle subsystems such as collision detection systems, automated cruise control systems, global positioning navigation, and the like. In this regard, systems have been developed that allow electronic components to communicate in accordance with standard protocols. For example, an electronics control unit associated with a vehicle engine that was developed by an engine manufacturer may communicate with a cab-mounted electronic control unit that was developed by a different manufacturer. Since communication protocols have been standardized, components from different manufacturers may be used in the same vehicle.
Development of standardized communication protocols provides an opportunity to automate and/or improve certain vehicle processes. For example, an electronic control unit associated with a vehicle's engine typically manages the amount of fuel input into the engine by a fuel injector. Moreover, the electronic control unit may be configured to identify the distance traveled by a vehicle over a given unit of time. This data may be communicated over a vehicle-wide network to other components in the vehicle such as a cab-mounted electronic control unit. As a result, information about the operation of a vehicle's engine may be made available to a vehicle operator.
A deficiency with existing systems is that odometer data may not be synchronized between different electronic components in the vehicle. For example, an electronic control unit associated with a vehicle's engine may calculate odometer data using a methodology that is different than the methodology that is used by a cab-mounted electronic control unit. While any discrepancy may initially be small, over the lifetime of the vehicle the discrepancy will accumulate and become significant.
Another deficiency with existing systems is that odometer data being received from a vehicle's engine is not necessarily checked for consistency. A common problem in the vehicle industry is the “rollback” of a vehicle's odometer. Traditionally, rollback prevention systems centered on the physical protection of an odometer that used mechanical components in performing calculations. However, electronic components in a vehicle's engine that are now being used to calculate odometer data may also be subject to tampering.
Another deficiency with existing systems is the inability to manage odometer data across multiple engines. Frequently, a seller may make assertions regarding the odometer attributes of the vehicle and one or more engines installed in the vehicle. For example, a vehicle owner may claim that a vehicle has two-hundred thousand (200,000) miles, and that a new engine was installed that was only used for twenty-thousand (20,000) miles. It would be beneficial to have a way to verify the accuracy of these types of assertions.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This summary is not intended to identify key features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
Aspects of the present invention are directed at securely calculating and storing odometer data associated with a vehicle. In accordance with one embodiment, a method is provided that checks the integrity of odometer data being received from a vehicle's engine. More specifically, the method includes receiving a first and second engine odometer values for an engine. Then, these odometer values are compared to determine whether data indicative of tampering was received. In this regard, if data indicative of tampering was received, aspects of the present invention adjust the official vehicle odometer value to account for the tampering.
The foregoing aspects and many of the attendant advantages of this invention will become more readily appreciated as the same become better understood by reference to the following detailed description, when taken in conjunction with the accompanying drawings, wherein:
Although the present invention will be described primarily in the context of an application for securely calculating and storing vehicle odometer data, those skilled in the art and others will appreciate that the invention is also applicable in other contexts. In any event, the following description first provides a general overview of a system architecture of electronic components that may be used to implement aspects of the present invention. Then, an exemplary method for calculating and storing vehicle odometer data will be described. The examples provided herein are not intended to be exhaustive or to limit the invention to the precise forms disclosed. Similarly, any steps described herein may be interchangeable with any other steps or combinations of steps in order to achieve the same results. Accordingly, the embodiments of the present invention described below should be construed as illustrative in nature, and not limiting.
As further illustrated in
The system architecture for the truck 100 depicted in
In the illustrative embodiment depicted in
As further illustrated in
Aspects of the present invention may be implemented in the odometer management system 120. Those skilled in the art and others will recognize that program code embodying the odometer management system 120 may be loaded into RAM 115 and executed by the processor 118. In one embodiment, odometer data calculated by the odometer management system 120 is regularly saved to the EEPROM 116. In this regard, the EEPROM 116 is a non-volatile memory capable of storing data when a vehicle is not operating. Accordingly, odometer data calculated by the odometer management system 120 is committed for storage on the EEPROM 116 at regularly occurring intervals or when operation of the vehicle terminates. Also, at vehicle start-up, odometer data may be retrieved from the EEPROM 116 by the odometer management system 120 so that the odometer data may be updated while the vehicle is operating.
In some existing systems, the calculation of a vehicle's official odometer value relied on a total engine odometer value that was maintained in memory of the electronic control unit 102. Unfortunately, the electronic control unit 102 may implement few security measures and transmit engine odometer data on a public vehicle network. As a result, a user could “rollback” an official vehicle odometer value by leveraging the lack of security in data maintained in the electronic control unit 102. Generally described, the odometer management system 120 is responsible for calculating and maintaining odometer data in a way that is secure from tampering. In this regard, insecure data that is committed to storage on the electronic control unit 102 is not relied on when updating a vehicle's official odometer value. Instead, the vehicle's official odometer value is calculated based on incremental distance information that is periodically received while the vehicle is operating. Moreover, a check may be performed by the odometer management system 120 to verify the integrity of the data that is received from electronic control unit 102. In instances when the integrity of the data is not verified, the odometer management system 120 performs processing to account for any attempted tampering.
As will be appreciated by those skilled in the art and others,
With reference now to
When odometer data is received from the electronic control unit 102, the odometer management system 120 updates local variables to reflect movement of the truck 100. In this regard, odometer data as updated by the odometer management system 120 is periodically saved to non-volatile memory. For example, as depicted in
Now, with reference to
As illustrated in
Once an activation event occurs, a set of odometer data stored on non-volatile memory is obtained, at block 206. As described in further detail below, aspects of the present invention perform processing to securely update a vehicle's odometer. In one embodiment, a set of odometer data is regularly saved to non-volatile memory. For example, before operation of a vehicle terminates, an updated set of odometer data that reflects usage of the vehicle may saved to non-volatile memory (e.g., the EEPROM 116). In this regard, the set of odometer data obtained from non-volatile memory, at block 206, may include: (1) an official vehicle odometer value; (2) an official engine odometer value; (3) an engine offset; and (4) a negative rollback offset. In this regard, the official vehicle odometer value represents the total distance traveled in the vehicle's lifetime. Similarly, the engine odometer value represents the total distance traveled while the current engine has been installed in the vehicle. The engine offset represents the total distance traveled with one or more previously installed engines other than the current engine. As described in further detail below, the engine offset may be used when calculating the official vehicle odometer value. Finally, the negative rollback offset quantifies the extent in which a user attempted to “rollback” an engine odometer value as reported from a vehicle's engine.
At block 208, an integrity check is performed to determine whether the official vehicle odometer value and engine offset value retrieved from non-volatile memory, at block 206, are valid. In one embodiment, a “checksum” is used to determine if this data retrieved from non-volatile memory is valid. In this regard, a checksum records basic information that describes attributes of a set of odometer data when saved. For example, the basic information may be the number of bytes in the set of odometer data that is saved to non-volatile memory. When the odometer data is retrieved from memory, a check may be performed to determine whether the number of bytes saved and retrieved from memory are the same. Then, at decision block 210, a determination is made regarding whether the official odometer value and engine offset value are valid. In instances when the checksum performed at block 208 indicates that the set of odometer data retrieved from non-volatile memory is not valid, the activation method 200 proceeds to block 214, described in further detail below. Conversely, if the checksum indicates that the odometer data is valid, the activation method 200 proceeds to block 212.
At block 212, the official vehicle odometer value that was read from non-volatile memory is communicated to a run-mode component of the odometer management system 120. As described in further detail below with reference to
At block 214, the activation method 200 handles the error condition that was identified at block 210. In handling the error condition, the activation method 200 may display information to the vehicle operator indicating that an error has occurred. Moreover, a description of the error condition may be recorded in a log file for subsequent retrieval. In this regard, the information inserted into the log file may include an error code identifying the type of error that was encountered. Then, the activation method 200 proceeds to block 216, where it terminates.
Now with reference to
As illustrated in
At decision block 306, a test is performed to determine whether the odometer data received at block 304 is valid. In some instances, data may be corrupted when transmitted over a vehicle network. For example, electronic components may malfunction so that data received at the cab-mounted electronic control unit 106 is not valid. Thus, aspects of the present invention check the validity of the odometer data that is periodically received from the vehicle's engine before performing updates. For example, the test performed at decision block 306 ensures that the data received hasn't reported a vehicle velocity that is not capable of being achieved. In any event, if the test performed at decision block 306 indicates that the odometer data received from a vehicle's engine is invalid, the calculation method 300 proceeds to block 341, described in further detail below. Conversely, if the set of odometer data is identified as being valid, the calculation routine 300 proceeds to block 310.
At decision block 310, a determination is made regarding whether the official engine odometer value retrieved from non-volatile memory by the activation method 200 (
As illustrated in
At decision block 314, a determination is made regarding whether inconsistent odometer data indicative of tampering has been reported from a vehicle's engine. As mentioned previously, odometer data that originates from the electronic control unit 102 is periodically reported over a network to the cab-mounted electronic control unit 106. To determine whether attempted tampering is occurring, a comparison is performed between successive engine odometer values as reported from the electronic control unit 102. An electronic control unit 102 associated with a vehicle's engine 104 that has not been tampered with will report increasing engine odometer values. Thus, if the engine odometer value received at block 304 is less than an engine odometer value that was previously received from the same engine 104, this is indicative of tampering and the calculation method proceeds to block 318. Conversely, if the test performed at block 314 indicates that the engine odometer values as reported by the vehicle's engine are increasing, then the calculation method 300 proceeds to block 326.
At block 318, a new negative rollback offset is quantified. In accordance with one embodiment, the new rollback offset quantified at block 318 is the square of the difference between successive engine odometer values received from a vehicle's engine, summed with any previously quantified rollback offset. As described in further detail below, the negative rollback offset that is updated each time an attempted tampering occurs may be used to modify the official vehicle and engine odometer values to account for the attempted tampering of engine odometer data. Then the calculation method 300 proceeds to block 326, described in further detail below.
As further illustrated in
At block 324, the calculation method 300 increments a variable that represents the total number of engines that have been installed in the vehicle (“engine counter”). Some manufacturers or end users may have prohibitions or limitations on the number of engines that may be installed. Thus, aspects of the present invention maintain an engine counter so that this characteristic of the vehicle may be readily identified.
At block 326, the official engine odometer value maintained by the odometer management system 120 is updated. More specifically, the engine odometer value received on a previous iteration of the calculation method 300 is set to equal the new engine odometer value that was received at block 304. Before block 326 is reached, data that accounts for the possibility of tampering and/or a new engine being installed has been identified. Thus, the official engine odometer value maintained by the odometer management system 120 may be updated to equal the new engine odometer value received at block 304. As a result of performing an update in this way, the official engine odometer values maintained by the odometer management system 120 is synchronized with an engine odometer value received from a vehicle's engine.
At block 328, the calculation method 300 quantifies a new official odometer value for the vehicle. In one embodiment, the official odometer value quantified at block 328 equals the summation of (1) the official engine odometer value (updated at block 326), (2) the engine offset, (3) and the negative rollback offset. As described previously, the engine odometer value represents the total distance traveled using the current engine and the engine offset represents the total distance traveled using any previously installed engines. Summation of these values with the negative rollback offset that accounts for tampering with data received from the engine produces a total distance traveled by the vehicle.
At decision block 330, a determination is made regarding whether a triggering event occurred that will cause a set of odometer data updated by the calculation method 300 to be saved back to non-volatile memory. In one embodiment, the calculation method 300 periodically saves a set of odometer data back to non-volatile memory (e.g., the EEPROM 116) each time the vehicle travels a predetermined distance (e.g., 100 kilometers). However, this example is merely exemplary as the calculation method 300 may be configured to save the set of odometer data more or less frequently without departing from the scope of the claimed subject matter. If the vehicle has not traveled the predetermined distance and the threshold has not been satisfied, the calculation method 300 proceeds to block 336, described below. Conversely, if a triggering event was identified, the calculation method 300 proceeds to block 332.
As illustrated in
At block 336, the calculation method 300 causes the official vehicle odometer value that is currently displayed on a dashboard display to be updated. In this regard, the official vehicle odometer value currently displayed to a vehicle operator is “refreshed” based on the update to the vehicle's official odometer value. However, since refreshing the information presented on a dashboard display may be performed using techniques that are generally known in the art, these techniques will not be described here.
At decision block 338, a determination is made regarding whether active input of odometer data is being received from a vehicle's engine. Active input may not be received when operation of the vehicle stops or the vehicle remains idle for a predetermined amount of time. If active input is being received, the calculation method 300 proceeds back to block 304 and blocks 304-338 repeat until input is no longer being received. Conversely, if active input is not being received from the vehicle's engine, the calculation method 300 proceeds to block 340.
At block 340 a set of odometer data is saved to non-volatile memory since active input is no longer being received from a vehicle's engine. The set of odometer data saved to non-volatile memory, at block 332, includes the official odometer value updated at block 328, the official engine odometer value updated at block 326, and the negative rollback offset. Then, the calculation method 300 proceeds to block 342, where it terminates.
At block 341, the calculation method 300 handles an error condition. In handling the error condition, the calculation method 300 may display information to the vehicle operator indicating that an error has occurred. Moreover, a description of the error condition may be recorded in a log file for subsequent retrieval. In this regard, the information inserted into the log file may include an error code identifying the type of error that was encountered. Then, the calculation method 300 proceeds to block 342, where it terminates.
While illustrative embodiments have been illustrated and described, it will be appreciated that various changes can be made therein without departing from the spirit and scope of the invention.