mirror of https://github.com/rusefi/isotp-c.git
Hide allocations behind an interface
Should make porting to bare-metal environments easier. Signed-off-by: Anton Gerasimov <anton@advancedtelematic.com>
This commit is contained in:
parent
ee24440b7c
commit
1cae4bf63d
|
@ -0,0 +1,13 @@
|
||||||
|
#ifndef __ISOTP_ALLOCATE_H__
|
||||||
|
#define __ISOTP_ALLOCATE_H__
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
/* The implementation of the two functions is platform-specific and is left to
|
||||||
|
* the user. Implementation used for testing is based on stdlib's malloc/free
|
||||||
|
* and can be found in tests/common.c */
|
||||||
|
|
||||||
|
uint8_t* allocate (size_t size);
|
||||||
|
void free_allocated (uint8_t* data);
|
||||||
|
|
||||||
|
#endif // __ISOTP_ALLOCATE_H_
|
|
@ -6,7 +6,6 @@
|
||||||
#include <isotp/receive.h>
|
#include <isotp/receive.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
#include <isotp/receive.h>
|
#include <isotp/receive.h>
|
||||||
|
#include <isotp/allocate.h>
|
||||||
#include <isotp/send.h>
|
#include <isotp/send.h>
|
||||||
#include <bitfield/bitfield.h>
|
#include <bitfield/bitfield.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
#define ARBITRATION_ID_OFFSET 0x8
|
#define ARBITRATION_ID_OFFSET 0x8
|
||||||
|
|
||||||
|
@ -111,7 +111,7 @@ IsoTpMessage isotp_continue_receive(IsoTpShims* shims,
|
||||||
//messages. That way we don't have to allocate 4k of memory
|
//messages. That way we don't have to allocate 4k of memory
|
||||||
//for each multi-frame response.
|
//for each multi-frame response.
|
||||||
uint8_t* combined_payload = NULL;
|
uint8_t* combined_payload = NULL;
|
||||||
combined_payload = (uint8_t*)malloc(sizeof(uint8_t)*payload_length);
|
combined_payload = allocate(payload_length);
|
||||||
|
|
||||||
if(combined_payload == NULL) {
|
if(combined_payload == NULL) {
|
||||||
shims->log("Unable to allocate memory for multi-frame response.");
|
shims->log("Unable to allocate memory for multi-frame response.");
|
||||||
|
@ -142,12 +142,12 @@ IsoTpMessage isotp_continue_receive(IsoTpShims* shims,
|
||||||
handle->received_buffer_size = start_index + remaining_bytes;
|
handle->received_buffer_size = start_index + remaining_bytes;
|
||||||
|
|
||||||
if(handle->received_buffer_size != handle->incoming_message_size){
|
if(handle->received_buffer_size != handle->incoming_message_size){
|
||||||
free(handle->receive_buffer);
|
free_allocated(handle->receive_buffer);
|
||||||
handle->success = false;
|
handle->success = false;
|
||||||
shims->log("Error capturing all bytes of multi-frame. Freeing memory.");
|
shims->log("Error capturing all bytes of multi-frame. Freeing memory.");
|
||||||
} else {
|
} else {
|
||||||
memcpy(message.payload,&handle->receive_buffer[0],handle->incoming_message_size);
|
memcpy(message.payload,&handle->receive_buffer[0],handle->incoming_message_size);
|
||||||
free(handle->receive_buffer);
|
free_allocated(handle->receive_buffer);
|
||||||
message.size = handle->incoming_message_size;
|
message.size = handle->incoming_message_size;
|
||||||
message.completed = true;
|
message.completed = true;
|
||||||
shims->log("Successfully captured all of multi-frame. Freeing memory.");
|
shims->log("Successfully captured all of multi-frame. Freeing memory.");
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
#include <isotp/isotp.h>
|
#include <isotp/isotp.h>
|
||||||
|
#include <isotp/allocate.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
@ -89,3 +90,10 @@ void setup() {
|
||||||
can_frame_was_sent = false;
|
can_frame_was_sent = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint8_t* allocate(size_t size) {
|
||||||
|
return (uint8_t*) malloc((sizeof(uint8_t))* size);
|
||||||
|
}
|
||||||
|
|
||||||
|
void free_allocated(uint8_t* data) {
|
||||||
|
free(data);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue