From daac8f258addd3a1177d3aa84e0bf9737000c8de Mon Sep 17 00:00:00 2001 From: Dominik Sliwa Date: Tue, 5 Feb 2019 14:44:01 +0100 Subject: Revert "Move CAN data out of fifo in a thread not IRQ" This reverts commit 46bfc66ac58289bc868d982e3b0ec46176302be0. --- drivers/src/fsl_flexcan.c | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) (limited to 'drivers') diff --git a/drivers/src/fsl_flexcan.c b/drivers/src/fsl_flexcan.c index 45db478..2a07dc5 100644 --- a/drivers/src/fsl_flexcan.c +++ b/drivers/src/fsl_flexcan.c @@ -1295,12 +1295,12 @@ void FLEXCAN_TransferHandleIRQ(CAN_Type *base, flexcan_handle_t *handle) break; case kFLEXCAN_RxFifoFrameAvlFlag: - //status = FLEXCAN_ReadRxFifo(base, handle->rxFifoFrameBuf); - //if (kStatus_Success == status) - //{ + status = FLEXCAN_ReadRxFifo(base, handle->rxFifoFrameBuf); + if (kStatus_Success == status) + { status = kStatus_FLEXCAN_RxFifoIdle; - //} - //FLEXCAN_TransferAbortReceiveFifo(base, handle); + } + FLEXCAN_TransferAbortReceiveFifo(base, handle); break; default: @@ -1354,7 +1354,10 @@ void FLEXCAN_TransferHandleIRQ(CAN_Type *base, flexcan_handle_t *handle) /* Calling Callback Function if has one. */ if (handle->callback != NULL) - reschedule = handle->callback(base, handle, status, result, handle->userData); + { + if (handle->callback(base, handle, status, result, handle->userData) == pdTRUE) + reschedule = pdTRUE; + } /* Reset return status */ status = kStatus_FLEXCAN_UnHandled; -- cgit v1.2.3