diff options
author | Christopher Peplin <chris.peplin@rhubarbtech.com> | 2014-01-06 14:54:15 -0500 |
---|---|---|
committer | Christopher Peplin <chris.peplin@rhubarbtech.com> | 2014-01-06 14:54:15 -0500 |
commit | c55d6bf59167c75439c1c40e9dcd8c05081d4685 (patch) | |
tree | c8f6cb94944ac7fd87b8655f65dab73419046820 | |
parent | 2ea50110062053ef12b1c66956ec25faf7f1cb3c (diff) |
Use new set_bitfield function to handle swapping endianness.
m--------- | deps/bitfield-c | 10 | ||||
-rw-r--r-- | src/obd2/obd2.c | 6 |
2 files changed, 7 insertions, 9 deletions
diff --git a/deps/bitfield-c b/deps/bitfield-c -Subproject 09dc97c24f9f9a9c2638405167bffe339f666e2 +Subproject 6f243098abadbde2e9b2e5b13a94029960ea2e5 diff --git a/src/obd2/obd2.c b/src/obd2/obd2.c index 402cc2f9..fa20f91a 100644 --- a/src/obd2/obd2.c +++ b/src/obd2/obd2.c @@ -37,10 +37,8 @@ DiagnosticRequestHandle diagnostic_request(DiagnosticShims* shims, uint8_t payload[MAX_DIAGNOSTIC_PAYLOAD_SIZE]; payload[MODE_BYTE_INDEX] = request->mode; if(request->pid_length > 0) { - // TODO need a set bit field that's more natural and checks endianness - // becauase we DO need to flip it - copy_bytes_right_aligned((uint8_t*)&request->pid, sizeof(request->pid), - PID_BYTE_INDEX, request->pid_length, payload, sizeof(payload)); + set_bitfield(request->pid, PID_BYTE_INDEX * CHAR_BIT, + request->pid_length * CHAR_BIT, payload, sizeof(payload)); } if(request->payload_length > 0) { memcpy(&payload[PID_BYTE_INDEX + request->pid_length], |