core_alloc: Provide a tiny test allocation, which can be freed for debug purposes.

This allocation can be freed in the buflib debug menu (select it to free).
Doing a another allocation, e.g. by selecting another item in this debug menu
will cause compaction (all allocs move).

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@30719 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Thomas Martitz 2011-10-05 18:32:19 +00:00
parent 6efb3f0760
commit 4478b25ede
3 changed files with 33 additions and 8 deletions

View file

@ -429,14 +429,21 @@ static int bf_action_cb(int action, struct gui_synclist* list)
{ {
if (action == ACTION_STD_OK) if (action == ACTION_STD_OK)
{ {
splash(HZ/1, "Attempting a 64k allocation"); if (gui_synclist_get_sel_pos(list) == 0 && core_test_free())
int handle = core_alloc("test", 64<<10); {
splash(HZ/2, (handle > 0) ? "Success":"Fail"); splash(HZ, "Freed test handle. New alloc should trigger compact");
/* for some reason simplelist doesn't allow adding items here if }
* info.get_name is given, so use normal list api */ else
gui_synclist_set_nb_items(list, core_get_num_blocks()); {
if (handle > 0) splash(HZ/1, "Attempting a 64k allocation");
core_free(handle); int handle = core_alloc("test", 64<<10);
splash(HZ/2, (handle > 0) ? "Success":"Fail");
/* for some reason simplelist doesn't allow adding items here if
* info.get_name is given, so use normal list api */
gui_synclist_set_nb_items(list, core_get_num_blocks());
if (handle > 0)
core_free(handle);
}
action = ACTION_REDRAW; action = ACTION_REDRAW;
} }
else if (action == ACTION_NONE) else if (action == ACTION_NONE)

View file

@ -6,6 +6,9 @@
/* not static so it can be discovered by core_get_data() */ /* not static so it can be discovered by core_get_data() */
struct buflib_context core_ctx; struct buflib_context core_ctx;
/* debug test alloc */
static int test_alloc;
void core_allocator_init(void) void core_allocator_init(void)
{ {
buffer_init(); buffer_init();
@ -13,6 +16,17 @@ void core_allocator_init(void)
void *start = buffer_get_buffer(&size); void *start = buffer_get_buffer(&size);
buflib_init(&core_ctx, start, size); buflib_init(&core_ctx, start, size);
buffer_release_buffer(size); buffer_release_buffer(size);
test_alloc = core_alloc("test", 112);
}
bool core_test_free(void)
{
bool ret = test_alloc > 0;
if (ret)
test_alloc = core_free(test_alloc);
return ret;
} }
int core_alloc(const char* name, size_t size) int core_alloc(const char* name, size_t size)

View file

@ -28,6 +28,10 @@ int core_get_num_blocks(void);
void core_print_block_at(int block_num, char* buf, size_t bufsize); void core_print_block_at(int block_num, char* buf, size_t bufsize);
#endif #endif
/* frees the debug test alloc created at initialization,
* since this is the first any further alloc should force a compaction run */
bool core_test_free(void);
static inline void* core_get_data(int handle) static inline void* core_get_data(int handle)
{ {
extern struct buflib_context core_ctx; extern struct buflib_context core_ctx;