[ofw] [PATCH] etc/dlist: add simple userspace doublye-linked list abstraction
Sean Hefty
sean.hefty at intel.com
Fri Apr 17 11:18:35 PDT 2009
Add a very simple implementation for managing a doubly-linked list.
This implementation uses only a 'list entry' structure for both the
list and items on the list, versus separate structures like complib.
Signed-off-by: Sean Hefty <sean.hefty at intel.com>
---
A patch that's 95% license, 5% code...
/*
* Copyright (c) 2009 Intel Corporation. All rights reserved.
*
* This software is available to you under the OpenIB.org BSD license
* below:
*
* 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.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AWV
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#ifndef _DLIST_H_
#define _DLIST_H_
#ifdef __cplusplus
extern "C" {
#endif
typedef struct _DLIST_ENTRY
{
struct _DLIST_ENTRY *Next;
struct _DLIST_ENTRY *Prev;
} DLIST_ENTRY;
static void DListInit(DLIST_ENTRY *pHead)
{
pHead->Next = pHead;
pHead->Prev = pHead;
}
static int DListEmpty(DLIST_ENTRY *pHead)
{
return pHead->Next == pHead;
}
void DListInsertAfter(DLIST_ENTRY *pNew, DLIST_ENTRY *pHead);
static void DListInsertBefore(DLIST_ENTRY *pNew, DLIST_ENTRY *pHead)
{
DListInsertAfter(pNew, pHead->Prev);
}
#define DListInsertHead DListInsertAfter
#define DListInsertTail DListInsertBefore
void DListRemove(DLIST_ENTRY *pEntry);
#ifdef __cplusplus
}
#endif
#endif // _DLIST_H_
/*
* Copyright (c) 2009 Intel Corporation. All rights reserved.
*
* This software is available to you under the OpenIB.org BSD license
* below:
*
* 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.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AWV
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#include <dlist.h>
void DListInsertAfter(DLIST_ENTRY *pNew, DLIST_ENTRY *pHead)
{
pNew->Next = pHead->Next;
pNew->Prev = pHead;
pHead->Next->Prev = pNew;
pHead->Next = pNew;
}
void DListRemove(DLIST_ENTRY *pEntry)
{
pEntry->Prev->Next = pEntry->Next;
pEntry->Next->Prev = pEntry->Prev;
}
More information about the ofw
mailing list