/****************************************************************************** * * Copyright 2018-2019,2022-2023 NXP * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ******************************************************************************/ #define LOG_TAG "NxpEseHal" #include #include #include #include static phNxpEse_sCoreRecvBuff_List_t *head = NULL, *current = NULL; static uint32_t total_len = 0; static ESESTATUS phNxpEse_DeletList(phNxpEse_sCoreRecvBuff_List_t* head); static ESESTATUS phNxpEse_GetDataFromList(uint32_t* data_len, uint8_t* pbuff); /****************************************************************************** * Function phNxpEse_GetData * * Description This function update the len and provided buffer * * Returns On Success ESESTATUS_SUCCESS else proper error code * ******************************************************************************/ ESESTATUS phNxpEse_GetData(uint32_t* data_len, uint8_t** pbuffer) { uint32_t total_data_len = 0; uint8_t* pbuff = NULL; ESESTATUS status = ESESTATUS_FAILED; if (total_len > 0) { pbuff = (uint8_t*)phNxpEse_memalloc(total_len); if (NULL != pbuff) { if (ESESTATUS_SUCCESS == phNxpEse_GetDataFromList(&total_data_len, pbuff)) { if (total_data_len == total_len) { /***** Success Case *****/ *pbuffer = pbuff; *data_len = total_data_len; phNxpEse_DeletList(head); head = NULL; current = NULL; total_len = 0; status = ESESTATUS_SUCCESS; } else { NXP_LOG_ESE_D("%s Mismatch of len total_data_len %d total_len %d", __FUNCTION__, total_data_len, total_len); phNxpEse_free(pbuff); } } else { NXP_LOG_ESE_E("%s phNxpEse_GetDataFromList failed", __FUNCTION__); phNxpEse_free(pbuff); } } else { NXP_LOG_ESE_E("%s Error in malloc ", __FUNCTION__); status = ESESTATUS_NOT_ENOUGH_MEMORY; } } else { NXP_LOG_ESE_D("%s total_len = %d", __FUNCTION__, total_len); } if (ESESTATUS_SUCCESS != status) { *pbuffer = NULL; *data_len = 0; } NXP_LOG_ESE_D("%s exit status = %d", __FUNCTION__, status); return status; } /****************************************************************************** * Function phNxpEse_StoreDatainList * * Description This function stores the received data in linked list * * Returns On Success ESESTATUS_SUCCESS else proper error code * ******************************************************************************/ ESESTATUS phNxpEse_StoreDatainList(uint32_t data_len, uint8_t* pbuff) { if (data_len > MAX_DATA_LEN) { ALOGE("%s Data length causes oob write error", __FUNCTION__); return ESESTATUS_INVALID_RECEIVE_LENGTH; } phNxpEse_sCoreRecvBuff_List_t* newNode = NULL; newNode = (phNxpEse_sCoreRecvBuff_List_t*)phNxpEse_memalloc( sizeof(phNxpEse_sCoreRecvBuff_List_t)); if (newNode == NULL) { NXP_LOG_ESE_E("%s Error in malloc ", __FUNCTION__); phNxpEse_FlushData(); return ESESTATUS_NOT_ENOUGH_MEMORY; } newNode->pNext = NULL; newNode->tData.wLen = data_len; phNxpEse_memcpy(newNode->tData.sbuffer, pbuff, data_len); total_len += data_len; if (head == NULL) { head = newNode; current = newNode; } else { current->pNext = newNode; current = newNode; } return ESESTATUS_SUCCESS; } /****************************************************************************** * Function phNxpEse_GetDataFromList * * Description This function copies all linked list data in provided buffer * * Returns On Success ESESTATUS_SUCCESS else proper error code * ******************************************************************************/ static ESESTATUS phNxpEse_GetDataFromList(uint32_t* data_len, uint8_t* pbuff) { phNxpEse_sCoreRecvBuff_List_t* new_node; uint32_t offset = 0; NXP_LOG_ESE_D("%s Enter ", __FUNCTION__); if (head == NULL || pbuff == NULL) { return ESESTATUS_FAILED; } new_node = head; while (new_node != NULL) { phNxpEse_memcpy((pbuff + offset), new_node->tData.sbuffer, new_node->tData.wLen); offset += new_node->tData.wLen; new_node = new_node->pNext; } *data_len = offset; NXP_LOG_ESE_D("%s Exit ", __FUNCTION__); return ESESTATUS_SUCCESS; } /****************************************************************************** * Function phNxpEse_DeletList * * Description This function deletes all nodes from linked list * * Returns On Success ESESTATUS_SUCCESS else proper error code * ******************************************************************************/ static ESESTATUS phNxpEse_DeletList(phNxpEse_sCoreRecvBuff_List_t* head) { ESESTATUS status = ESESTATUS_SUCCESS; phNxpEse_sCoreRecvBuff_List_t *current, *next; current = head; if (head == NULL) { return ESESTATUS_FAILED; } while (current != NULL) { next = current->pNext; phNxpEse_free(current); current = NULL; current = next; } head = NULL; return status; } /****************************************************************************** * Function phNxpEse_FlushData * * Description This function flushes the data from the data list * * Returns void * ******************************************************************************/ void phNxpEse_FlushData() { phNxpEse_data pRes; phNxpEse_memset(&pRes, 0x00, sizeof(phNxpEse_data)); /* read if any residual data is there */ if ((total_len > 0) && (ESESTATUS_SUCCESS == phNxpEse_GetData(&pRes.len, &pRes.p_data))) { NXP_LOG_ESE_D("%s Flushed data DataLen = %d", __FUNCTION__, pRes.len); } if (pRes.p_data != NULL) { phNxpEse_free(pRes.p_data); pRes.p_data = NULL; } }