[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