Unified Diagnostic Services
Unified Diagnostic Services (UDS) specifies data link independent requirements of automotive diagnostic services in road vehicles.[1] UDS is codified in ISO 14229-1:2013 and allows diagnostics to control functions on an in-vehicle Electronic Control Unit (ECU). Typical functions ECUs control are electronic fuel injection(EFI), automatic gear box, anti-lock braking system, Configurable Engine Mobilizer, Key Controls, Wiper Controls etc. all connected to a serial data link embedded in a road vehicle. The Diagnostic communication over Controller Area Network (DoCAN) is specified in ISO 15765-3[2] and ISO 14229-3 coupled with some LIN signalling.
Services
SID (Service Identifier)
Function group | Request SID | Response SID | Service | Description |
---|---|---|---|---|
Diagnostic and Communications Management | $10 | $50 | Diagnostic Session Control | UDS uses different operating sessions, which can be changed using the "Diagnostic Session Control". Depending on which session is active, different services are available. On start, the control unit is by default in the "Default Session". Other sessions are defined, but are not required to be implemented depending on the type of device:
In addition, there are reserved session identifiers that can be defined for vehicle manufacturers and vehicle suppliers specific use. |
$11 | $51 | ECU Reset | The service "ECU reset" is used to restart the control unit (ECU). Depending on the control unit hardware and implementation, different forms of reset can be used:
Again, there are reserved values that can be defined for vehicle manufacturers and vehicle suppliers specific use. | |
$27 | $67 | Security Access | Security check is available to enable the most security-critical services. For this purpose a "Seed" is generated and sent to the client by the control unit. From this "Seed" the client has to compute a "Key" and send it back to the control unit to unlock the security-critical services. | |
$28 | $68 | Communication Control | With this service, both the sending and receiving of messages can be turned off in the control unit. | |
$3E | $7E | Tester Present | If no communication is exchanged with the client for a long time, the control unit automatically exits the current session and returns to the "Default Session" back. Therefore, there is an extra service which purpose is to signal to the device that the client is still present. | |
$83 | $C3 | Access Timing Parameters | In the communication between the controllers and the client certain times must be observed. If these are exceeded, without a message is sent, it must be assumed that the connection was interrupted. These times can be called up and changed. | |
$84 | $C4 | Secured Data Transmission | ||
$85 | $C5 | Control DTC Settings | Enable or disable the detection of any or all errors. This is important when diagnostic work is performed in the car, which can cause an anomalous behavior of individual devices. | |
$86 | $C6 | Response On Event | ||
$87 | $C7 | Link Control | The Service Link Control is used to set the baud rate of the diagnostic access. It is usually implemented only at the central gateway. | |
Data Transmission | $22 | $62 | Read Data By Identifier | With this service it is possible to retrieve one or more values of a control unit. This can be information of all kinds and of different lengths such as Partnumber or the software version. Dynamic values such as the current state of the sensor can be queried. Each value is associated to a Data Identifier (DID) between 0 and 65535. |
$23 | $63 | Read Memory By Address | Read data from the physical memory at the provided address. | |
$24 | $64 | Read Scaling Data By Identifier | ||
$2A | $6A | Read Data By Identifier Periodic | With this service values are sent periodically by a control unit. The values to be sent must be defined to only using the "Dynamically Define Data Identifier". | |
$2C | $6C | Dynamically Define Data Identifier | This service offers the possibility of a fix for a device specified Data Identifier (DID) pool to configure another Data Identifier. This is usually a combination of parts of different DIDs or simply a concatenation of complete DIDs.
The requested data may be configured or grouped in the following manner:
| |
$2E | $6E | Write Data By Identifier | With the same Data Identifier (DID), values can also be changed. In addition to the identifier, the new value is sent along. | |
$3D | $7D | Write Memory By Address | ||
Stored Data Transmission | $14 | $54 | Clear Diagnostic Information | Delete all stored DTC |
$19 | $59 | Read DTC Information | DTC stands for "Diagnostic trouble codes". Each DTC handled by the control unit fault is stored with its own code in the error memory and can be read at any time. In addition to the error, additional information will be stored, which can also be read. | |
Input / Output Control | $2F | $6F | Input Output Control By Identifier | This service allows an external system intervention on internal / external signals via the diagnostic interface.
By specifying a so-called option bytes additional conditions for a request can be specified, the following values are specified: ReturnControlToECU: The device must get back controls of the mentioned signals. ResetToDefault: The tester prompts to reset signals to the system wide default value. Freeze Current State: The device shall freeze the current signal value. ShortTermAdjustment: The device shall use the provided value for the signal |
Remote Activation of Routine | $31 | $71 | Routine Control | The Control service routine services of all kinds can be performed. There are three different message types:
The start and stop message parameters can be specified. This makes it possible to implement every possible project-specific service. |
Upload / Download | $34 | $74 | Request Download | Downloading new software or other data into the control unit is introduced using the "Request Download". Here, the location and size of the data is specified. In turn, the controller specifies how large the data packets can be. |
$35 | $75 | Request Upload | The service "request upload" is almost identical to the service "Request Download". With this service, the software from the control unit is transferred to the tester. The location and size must be specified. Again, the size of the data blocks are specified by the tester. | |
$36 | $76 | Transfer Data | For the actual transmission of data, the service "Transfer Data" is used. This service is used for both uploading and downloading data. The transfer direction is notified in advance by the service "Request Download" or "Upload Request". This service should try to send packets at maximum length, as specified in previous services. If the data set is larger than the maximum, the "Transfer Data" service must be used several times in succession until all data has arrived. | |
$37 | $77 | Request Transfer Exit | A data transmission can be 'completed' when using the "Transfer Exit" service. This service is used for comparison between the control unit and the tester. When it is running, a control unit can answer negatively on this request to stop a data transfer request. This will be used when the amount of data (set in "Request Download" or "Upload Request") has not been transferred. | |
$38 | $78 | Request File Transfer | This service is used to initiate a file download from the client to the server or upload from the server to the client. Additionally information about the file system are available by this service. |