git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'device-sys'
[lunaix-os.git]
/
lunaix-os
/
includes
/
lunaix
/
mm
/
cake.h
diff --git
a/lunaix-os/includes/lunaix/mm/cake.h
b/lunaix-os/includes/lunaix/mm/cake.h
index 0312c45d381ac7854a802cb248eb792ac496cbf6..81321f87b898c7ce1b6bd05b50f35d342dc5d8ff 100644
(file)
--- a/
lunaix-os/includes/lunaix/mm/cake.h
+++ b/
lunaix-os/includes/lunaix/mm/cake.h
@@
-7,6
+7,10
@@
#define PILE_CACHELINE 1
#define PILE_CACHELINE 1
+struct cake_pile;
+
+typedef void (*pile_cb)(struct cake_pile*, void*);
+
struct cake_pile
{
struct llist_header piles;
struct cake_pile
{
struct llist_header piles;
@@
-20,6
+24,8
@@
struct cake_pile
unsigned int pieces_per_cake;
unsigned int pg_per_cake;
char pile_name[PILE_NAME_MAXLEN];
unsigned int pieces_per_cake;
unsigned int pg_per_cake;
char pile_name[PILE_NAME_MAXLEN];
+
+ pile_cb ctor;
};
typedef unsigned int piece_index_t;
};
typedef unsigned int piece_index_t;
@@
-49,6
+55,9
@@
cake_new_pile(char* name,
unsigned int pg_per_cake,
int options);
unsigned int pg_per_cake,
int options);
+void
+cake_set_constructor(struct cake_pile* pile, pile_cb ctor);
+
/**
* @brief 拿一块儿蛋糕
*
/**
* @brief 拿一块儿蛋糕
*
@@
-70,11
+79,12
@@
cake_release(struct cake_pile* pile, void* area);
void
cake_init();
void
cake_init();
-/**
- * @brief 统计蛋糕数量 - 问问Pinkie :D
- *
- */
void
void
-cake_stats();
+cake_export();
+
+/********** some handy constructor ***********/
+
+void
+cake_ctor_zeroing(struct cake_pile* pile, void* piece);
#endif /* __LUNAIX_VALLOC_H */
#endif /* __LUNAIX_VALLOC_H */