From 871480933a1c28f8a9fed4c4d34d06c439a7a422 Mon Sep 17 00:00:00 2001 From: Srikant Patnaik Date: Sun, 11 Jan 2015 12:28:04 +0530 Subject: Moved, renamed, and deleted files The original directory structure was scattered and unorganized. Changes are basically to make it look like kernel structure. --- drivers/video/wmt/bootanimation/buffer.c | 85 ++++++++++++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100755 drivers/video/wmt/bootanimation/buffer.c (limited to 'drivers/video/wmt/bootanimation/buffer.c') diff --git a/drivers/video/wmt/bootanimation/buffer.c b/drivers/video/wmt/bootanimation/buffer.c new file mode 100755 index 00000000..6b6f1b89 --- /dev/null +++ b/drivers/video/wmt/bootanimation/buffer.c @@ -0,0 +1,85 @@ + +#include "buffer.h" + +#define assert(int ) + +int animation_buffer_init(animation_buffer * buf, int size, int count, ISzAlloc *alloc) +{ + buf->buffer = buf->w_pos = buf->r_pos = alloc->Alloc(alloc, size * count); + if(!buf->buffer) + return -1; + + buf->frame_count = count; + buf->frame_size = size; + buf->eof = 0; + + sema_init(&buf->sem_writable, count); + sema_init(&buf->sem_readable, 0); + + return 0; +} + +int animation_buffer_release(animation_buffer * buf, ISzAlloc *alloc) +{ + if (buf->buffer) + alloc->Free(alloc, buf->buffer); + buf->buffer = buf->w_pos = buf->r_pos = NULL; + return 0; +} + +unsigned char * animation_buffer_get_writable(animation_buffer * buf, unsigned int * pSize) +{ + down_interruptible(&buf->sem_writable); + *pSize = buf->frame_size; + return buf->w_pos; +} + +int animation_buffer_stop(animation_buffer * buf) +{ + up(&buf->sem_readable); + /* up twice for safey*/ + up(&buf->sem_writable); + up(&buf->sem_writable); + return 0; +} + +void animation_buffer_write_finish(animation_buffer * buf, unsigned char * addr) +{ + assert(addr == buf->w_pos); + + // printk(KERN_INFO "add one buffer 0x%p\n", addr); + + buf->w_pos += buf->frame_size; + if (buf->w_pos - buf->buffer == buf->frame_size * buf->frame_count) + buf->w_pos = buf->buffer; + + up(&buf->sem_readable); + // printk(KERN_INFO "write <<<<<<<======\n"); + return; + +} + + +unsigned char * animation_buffer_get_readable(animation_buffer * buf) +{ + int ret = down_trylock(&buf->sem_readable); + if (ret == 0) { + return buf->r_pos; + } + else { + return NULL; + } +} + +void animation_buffer_read_finish(animation_buffer * buf, unsigned char * addr) +{ + // Integrity check + assert(addr == buf->r_pos); + // printk(KERN_INFO "read one buffer 0x%p\n", addr); + buf->r_pos += buf->frame_size; + if (buf->r_pos - buf->buffer == buf->frame_size * buf->frame_count) + buf->r_pos = buf->buffer; + + up(&buf->sem_writable); +} + -- cgit