| /* Copyright (c) 2011, The Linux Foundation. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions are |
| * met: |
| * * Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * * Redistributions in binary form must reproduce the above |
| * copyright notice, this list of conditions and the following |
| * disclaimer in the documentation and/or other materials provided |
| * with the distribution. |
| * * Neither the name of The Linux Foundation nor the names of its |
| * contributors may be used to endorse or promote products derived |
| * from this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED |
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
| * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT |
| * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS |
| * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR |
| * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, |
| * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE |
| * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN |
| * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| #ifndef __LINKED_LIST_H__ |
| #define __LINKED_LIST_H__ |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif /* __cplusplus */ |
| |
| #include <stdbool.h> |
| #include <stdlib.h> |
| |
| /** Linked List Return Codes */ |
| typedef enum |
| { |
| eLINKED_LIST_SUCCESS = 0, |
| /**< Request was successful. */ |
| eLINKED_LIST_FAILURE_GENERAL = -1, |
| /**< Failed because of a general failure. */ |
| eLINKED_LIST_INVALID_PARAMETER = -2, |
| /**< Failed because the request contained invalid parameters. */ |
| eLINKED_LIST_INVALID_HANDLE = -3, |
| /**< Failed because an invalid handle was specified. */ |
| eLINKED_LIST_UNAVAILABLE_RESOURCE = -4, |
| /**< Failed because an there were not enough resources. */ |
| eLINKED_LIST_INSUFFICIENT_BUFFER = -5, |
| /**< Failed because an the supplied buffer was too small. */ |
| }linked_list_err_type; |
| |
| /*=========================================================================== |
| FUNCTION linked_list_init |
| |
| DESCRIPTION |
| Initializes internal structures for linked list. |
| |
| list_data: State of list to be initialized. |
| |
| DEPENDENCIES |
| N/A |
| |
| RETURN VALUE |
| Look at error codes above. |
| |
| SIDE EFFECTS |
| N/A |
| |
| ===========================================================================*/ |
| linked_list_err_type linked_list_init(void** list_data); |
| |
| /*=========================================================================== |
| FUNCTION linked_list_destroy |
| |
| DESCRIPTION |
| Destroys internal structures for linked list. |
| |
| p_list_data: State of list to be destroyed. |
| |
| DEPENDENCIES |
| N/A |
| |
| RETURN VALUE |
| Look at error codes above. |
| |
| SIDE EFFECTS |
| N/A |
| |
| ===========================================================================*/ |
| linked_list_err_type linked_list_destroy(void** list_data); |
| |
| /*=========================================================================== |
| FUNCTION linked_list_add |
| |
| DESCRIPTION |
| Adds an element to the head of the linked list. The passed in data pointer |
| is not modified or freed. Passed in data_obj is expected to live throughout |
| the use of the linked_list (i.e. data is not allocated internally) |
| |
| p_list_data: List to add data to the head of. |
| data_obj: Pointer to data to add into list |
| dealloc: Function used to deallocate memory for this element. Pass NULL |
| if you do not want data deallocated during a flush operation |
| |
| DEPENDENCIES |
| N/A |
| |
| RETURN VALUE |
| Look at error codes above. |
| |
| SIDE EFFECTS |
| N/A |
| |
| ===========================================================================*/ |
| linked_list_err_type linked_list_add(void* list_data, void *data_obj, void (*dealloc)(void*)); |
| |
| /*=========================================================================== |
| FUNCTION linked_list_remove |
| |
| DESCRIPTION |
| Retrieves data from the list tail. data_obj is the tail element from the list |
| passed in by linked_list_add. |
| |
| p_list_data: List to remove the tail from. |
| data_obj: Pointer to data removed from list |
| |
| DEPENDENCIES |
| N/A |
| |
| RETURN VALUE |
| Look at error codes above. |
| |
| SIDE EFFECTS |
| N/A |
| |
| ===========================================================================*/ |
| linked_list_err_type linked_list_remove(void* list_data, void **data_obj); |
| |
| /*=========================================================================== |
| FUNCTION linked_list_empty |
| |
| DESCRIPTION |
| Tells whether the list currently contains any elements |
| |
| p_list_data: List to check if empty. |
| |
| DEPENDENCIES |
| N/A |
| |
| RETURN VALUE |
| 0/FALSE : List contains elements |
| 1/TRUE : List is Empty |
| Otherwise look at error codes above. |
| |
| SIDE EFFECTS |
| N/A |
| |
| ===========================================================================*/ |
| int linked_list_empty(void* list_data); |
| |
| /*=========================================================================== |
| FUNCTION linked_list_flush |
| |
| DESCRIPTION |
| Removes all elements from the list and deallocates them using the provided |
| dealloc function while adding elements. |
| |
| p_list_data: List to remove all elements from. |
| |
| DEPENDENCIES |
| N/A |
| |
| RETURN VALUE |
| Look at error codes above. |
| |
| SIDE EFFECTS |
| N/A |
| |
| ===========================================================================*/ |
| linked_list_err_type linked_list_flush(void* list_data); |
| |
| /*=========================================================================== |
| FUNCTION linked_list_search |
| |
| DESCRIPTION |
| Searches for an element in the linked list. |
| |
| p_list_data: List handle. |
| data_p: to be stored with the data found; NUll if no match. |
| if data_p passed in as NULL, then no write to it. |
| equal: Function ptr takes in a list element, and returns |
| indication if this the one looking for. |
| data_0: The data being compared against. |
| rm_if_found: Should data be removed if found? |
| |
| DEPENDENCIES |
| N/A |
| |
| RETURN VALUE |
| Look at error codes above. |
| |
| SIDE EFFECTS |
| N/A |
| |
| ===========================================================================*/ |
| linked_list_err_type linked_list_search(void* list_data, void **data_p, |
| bool (*equal)(void* data_0, void* data), |
| void* data_0, bool rm_if_found); |
| |
| #ifdef __cplusplus |
| } |
| #endif /* __cplusplus */ |
| |
| #endif /* __LINKED_LIST_H__ */ |