summaryrefslogtreecommitdiff
path: root/firmware/include/lru.h
diff options
context:
space:
mode:
authorMarcoen Hirschberg <marcoen@gmail.com>2005-12-06 13:27:15 +0000
committerMarcoen Hirschberg <marcoen@gmail.com>2005-12-06 13:27:15 +0000
commitb0fee17d6e1a463dcd84568e5997663b69488998 (patch)
treefffce775c4d1636a8bbc9e97669aa99b9378fc15 /firmware/include/lru.h
parent01917ec9809f1abff87cb372b700fc09476d343e (diff)
downloadrockbox-b0fee17d6e1a463dcd84568e5997663b69488998.tar.gz
rockbox-b0fee17d6e1a463dcd84568e5997663b69488998.zip
waiting is over: initial unicode commit
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@8169 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/include/lru.h')
-rw-r--r--firmware/include/lru.h46
1 files changed, 46 insertions, 0 deletions
diff --git a/firmware/include/lru.h b/firmware/include/lru.h
new file mode 100644
index 0000000000..8c74aa64ef
--- /dev/null
+++ b/firmware/include/lru.h
@@ -0,0 +1,46 @@
1/***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 *
9 * Copyright (C) 2003 Tat Tang
10 *
11 * All files in this archive are subject to the GNU General Public License.
12 * See the file COPYING in the source tree root for full license agreement.
13 *
14 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
15 * KIND, either express or implied.
16 *
17 ****************************************************************************/
18
19#ifndef LRU_H
20#define LRU_H
21
22/*******************************************************************************
23 * LRU manager
24 ******************************************************************************/
25struct lru
26{
27 short _head;
28 short _tail;
29 short _size;
30 short _slot_size;
31 void *_base;
32};
33
34#define LRU_SLOT_OVERHEAD (2 * sizeof(short))
35
36/* Create LRU list with specified size from buf. */
37void lru_create(struct lru* pl, void *buf, short size, short data_size);
38/* Touch an entry. Moves handle to back of LRU list */
39void lru_touch(struct lru* pl, short handle);
40/* Data */
41void *lru_data(struct lru* pl, short handle);
42/* Traverse lru-wise */
43void lru_traverse(struct lru* pl, void (*callback)(void* data));
44
45#endif /* LRU_H */
46