diff options
author | Christopher Peplin <chris.peplin@rhubarbtech.com> | 2014-01-03 13:44:39 -0500 |
---|---|---|
committer | Christopher Peplin <chris.peplin@rhubarbtech.com> | 2014-01-03 13:44:39 -0500 |
commit | a5e910714733f309b6db18f6017c6f0864e20d38 (patch) | |
tree | 9255d43cd3545ab138595e3abb24c60660052104 /src/isotp/receive.c | |
parent | 330358c978ea3d324740a8dba884c4493fa339b8 (diff) |
Split up functions in send/receive files for clarity.
Diffstat (limited to 'src/isotp/receive.c')
-rw-r--r-- | src/isotp/receive.c | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/src/isotp/receive.c b/src/isotp/receive.c index 3eba9b53..bfbf16fd 100644 --- a/src/isotp/receive.c +++ b/src/isotp/receive.c @@ -22,3 +22,57 @@ IsoTpReceiveHandle isotp_receive(IsoTpShims* shims, return handle; } + +IsoTpMessage isotp_continue_receive(IsoTpShims* shims, + IsoTpReceiveHandle* handle, const uint16_t arbitration_id, + const uint8_t data[], const uint8_t size) { + IsoTpMessage message = { + arbitration_id: arbitration_id, + completed: false, + payload: {0}, + size: 0 + }; + + if(size < 1) { + return message; + } + + if(handle->arbitration_id != arbitration_id) { + if(shims->log != NULL) { + shims->log("The arb ID 0x%x doesn't match the expected rx ID 0x%x", + arbitration_id, handle->arbitration_id); + } + return message; + } + + IsoTpProtocolControlInformation pci = (IsoTpProtocolControlInformation) + get_nibble(data, size, 0); + + uint8_t payload_length = get_nibble(data, size, 1); + uint8_t payload[payload_length]; + if(payload_length > 0 && size > 0) { + memcpy(payload, &data[1], payload_length); + } + + // TODO this is set up to handle rx a response with a payload, but not to + // handle flow control responses for multi frame messages that we're in the + // process of sending + + switch(pci) { + case PCI_SINGLE: { + if(payload_length > 0) { + memcpy(message.payload, payload, payload_length); + } + message.size = payload_length; + message.completed = true; + handle->success = true; + handle->completed = true; + isotp_handle_single_frame(handle, &message); + break; + } + default: + shims->log("Only single frame messages are supported"); + break; + } + return message; +} |