4 (C) 2001 by Andreas Gruenbacher, <a.gruenbacher@computer.org>
7 /* Hardwire the number of additional indexes */
8 #define MB_CACHE_INDEXES_COUNT 1
10 struct mb_cache_entry {
11 struct list_head e_lru_list;
12 struct mb_cache *e_cache;
13 unsigned short e_used;
14 unsigned short e_queued;
15 struct block_device *e_bdev;
17 struct list_head e_block_list;
19 struct list_head o_list;
25 int (*free)(struct mb_cache_entry *, int);
28 /* Functions on caches */
30 struct mb_cache * mb_cache_create(const char *, struct mb_cache_op *, size_t,
32 void mb_cache_shrink(struct block_device *);
33 void mb_cache_destroy(struct mb_cache *);
35 /* Functions on cache entries */
37 struct mb_cache_entry *mb_cache_entry_alloc(struct mb_cache *);
38 int mb_cache_entry_insert(struct mb_cache_entry *, struct block_device *,
39 sector_t, unsigned int[]);
40 void mb_cache_entry_release(struct mb_cache_entry *);
41 void mb_cache_entry_free(struct mb_cache_entry *);
42 struct mb_cache_entry *mb_cache_entry_get(struct mb_cache *,
43 struct block_device *,
45 #if !defined(MB_CACHE_INDEXES_COUNT) || (MB_CACHE_INDEXES_COUNT > 0)
46 struct mb_cache_entry *mb_cache_entry_find_first(struct mb_cache *cache, int,
47 struct block_device *,
49 struct mb_cache_entry *mb_cache_entry_find_next(struct mb_cache_entry *, int,
50 struct block_device *,