libmeinos: +llist2
[meinos.git] / apps / include / cdi / cache.h
blob4b9effdbf8892b493fa333b4f2706b7f0fe7afd7
1 /*
2 * Copyright (c) 2008 Antoine Kaufmann
4 * This program is free software. It comes without any warranty, to
5 * the extent permitted by applicable law. You can redistribute it
6 * and/or modify it under the terms of the Do What The Fuck You Want
7 * To Public License, Version 2, as published by Sam Hocevar. See
8 * http://sam.zoy.org/projects/COPYING.WTFPL for more details.
9 */
11 #ifndef _CDI_CACHE_H_
12 #define _CDI_CACHE_H_
14 #include <stdint.h>
16 struct cdi_cache {
17 /** Groesse der Blocks, die der Cache verwaltet */
18 size_t block_size;
20 /* OS-Spezifische Daten folgen... */
23 /** Block fuer direkten, schnellen Zugriff. */
24 struct cdi_cache_block {
25 /** Blocknummer */
26 uint64_t number;
28 /** Zeiger auf die Daten */
29 void* data;
31 /** Pointer auf blkpriv_len Bytes, die vom Aufrufer benutzt werden koennen*/
32 void* private;
35 /** Typ fuer Cache-Callback zum einlesen eines Blocks. */
36 typedef int (cdi_cache_read_block_t)(struct cdi_cache* cache, uint64_t block,
37 size_t count, void* dest, void* prv);
39 /** Typ fuer Cache-Callback zum schreiben eines Blocks. */
40 typedef int (cdi_cache_write_block_t)(struct cdi_cache* cache, uint64_t block,
41 size_t count, const void* src, void* prv);
44 /**
45 * Cache erstellen
47 * @param block_size Groesse der Blocks die der Cache verwalten soll
48 * @param blkpriv_len Groesse der privaten Daten die fuer jeden Block
49 * alloziert werden und danach vom aurfrufer frei benutzt
50 * werden duerfen
51 * @param read_block Funktionspointer auf eine Funktion zum einlesen eines
52 * Blocks.
53 * @param write_block Funktionspointer auf eine Funktion zum schreiben einses
54 * Blocks.
55 * @param prv_data Wird den Callbacks als letzter Parameter uebergeben
57 * @return Pointer auf das Cache-Handle
59 struct cdi_cache* cdi_cache_create(size_t block_size, size_t blkpriv_len,
60 cdi_cache_read_block_t* read_block,
61 cdi_cache_write_block_t* write_block,
62 void* prv_data);
64 /**
65 * Cache zerstoeren
67 void cdi_cache_destroy(struct cdi_cache* cache);
69 /**
70 * Veraenderte Cache-Blocks auf die Platte schreiben
72 * @return 1 bei Erfolg, 0 im Fehlerfall
74 int cdi_cache_sync(struct cdi_cache* cache);
76 /**
77 * Cache-Block holen. Dabei wird intern ein Referenzzaehler erhoeht, sodass der
78 * Block nicht freigegeben wird, solange er benutzt wird. Das heisst aber auch,
79 * dass der Block nach der Benutzung wieder freigegeben werden muss, da sonst
80 * die freien Blocks ausgehen.
82 * @param cache Cache-Handle
83 * @param blocknum Blocknummer
84 * @param noread Wenn != 0 wird der Block nicht eingelesen falls er noch
85 * nicht im Speicher ist. Kann benutzt werden, wenn der Block
86 * vollstaendig ueberschrieben werden soll.
88 * @return Pointer auf das Block-Handle oder NULL im Fehlerfall
90 struct cdi_cache_block* cdi_cache_block_get(struct cdi_cache* cache,
91 uint64_t blocknum, int noread);
93 /**
94 * Cache-Block freigeben
96 * @param cache Cache-Handle
97 * @param block Block-Handle
99 void cdi_cache_block_release(struct cdi_cache* cache,
100 struct cdi_cache_block* block);
103 * Cache-Block als veraendert markieren
105 * @param cache Cache-Handle
106 * @param block Block-Handle
108 void cdi_cache_block_dirty(struct cdi_cache* cache,
109 struct cdi_cache_block* block);
111 #endif