summaryrefslogtreecommitdiff
path: root/apps/plugins/test_mem_jpeg.c
diff options
context:
space:
mode:
authorAndrew Mahone <andrew.mahone@gmail.com>2009-05-08 03:46:48 +0000
committerAndrew Mahone <andrew.mahone@gmail.com>2009-05-08 03:46:48 +0000
commita75c72c169f64ecb0799934f1da148bdf497b8a9 (patch)
treeb0ad37ce0f6519bb44536a0bf6fc72fc76628542 /apps/plugins/test_mem_jpeg.c
parentc91e73e922fc2a229c39a9b686d77d5cba47c95a (diff)
downloadrockbox-a75c72c169f64ecb0799934f1da148bdf497b8a9.zip
rockbox-a75c72c169f64ecb0799934f1da148bdf497b8a9.tar.gz
rockbox-a75c72c169f64ecb0799934f1da148bdf497b8a9.tar.bz2
rockbox-a75c72c169f64ecb0799934f1da148bdf497b8a9.tar.xz
Plugin JPEG decoder for data in memory, along with test_mem_jpeg.c and bench_mem_jpeg.c plugins to test and benchmark it, and a line-length clean up in jpeg_load.c.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@20871 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'apps/plugins/test_mem_jpeg.c')
-rw-r--r--apps/plugins/test_mem_jpeg.c103
1 files changed, 103 insertions, 0 deletions
diff --git a/apps/plugins/test_mem_jpeg.c b/apps/plugins/test_mem_jpeg.c
new file mode 100644
index 0000000..50969c3
--- /dev/null
+++ b/apps/plugins/test_mem_jpeg.c
@@ -0,0 +1,103 @@
+/*****************************************************************************
+ * __________ __ ___.
+ * Open \______ \ ____ ____ | | _\_ |__ _______ ___
+ * Source | _// __ \_/ ___\| |/ /| __ \ / __ \ \/ /
+ * Jukebox | | ( (__) ) \___| ( | \_\ ( (__) ) (
+ * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
+ * \/ \/ \/ \/ \/
+ * $Id$
+ *
+ * Copyright (C) 2009 Andrew Mahone
+ *
+ * In-memory JPEG decode test.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
+ * KIND, either express or implied.
+ *
+ ****************************************************************************/
+
+#include "plugin.h"
+#include "lib/grey.h"
+#include "lib/jpeg_mem.h"
+PLUGIN_HEADER
+
+/* different graphics libraries */
+#if LCD_DEPTH < 8
+#define USEGSLIB
+GREY_INFO_STRUCT
+#define MYLCD(fn) grey_ub_ ## fn
+#define MYLCD_UPDATE()
+#define MYXLCD(fn) grey_ub_ ## fn
+#define CFORMAT &format_grey
+#else
+#define MYLCD(fn) rb->lcd_ ## fn
+#define MYLCD_UPDATE() rb->lcd_update();
+#define MYXLCD(fn) xlcd_ ## fn
+#define CFORMAT &format_native
+#endif
+
+/* this is the plugin entry point */
+enum plugin_status plugin_start(const void* parameter)
+{
+ size_t plugin_buf_len;
+ unsigned char * plugin_buf =
+ (unsigned char *)rb->plugin_get_buffer(&plugin_buf_len);
+ static char filename[MAX_PATH];
+ struct bitmap bm = {
+ .width = LCD_WIDTH,
+ .height = LCD_HEIGHT,
+ };
+ int ret;
+
+ if(!parameter) return PLUGIN_ERROR;
+
+ rb->strcpy(filename, parameter);
+
+#ifdef USEGSLIB
+ long greysize;
+ if (!grey_init(plugin_buf, plugin_buf_len, GREY_ON_COP,
+ LCD_WIDTH, LCD_HEIGHT, &greysize))
+ {
+ rb->splash(HZ, "grey buf error");
+ return PLUGIN_ERROR;
+ }
+ plugin_buf += greysize;
+ plugin_buf_len -= greysize;
+#endif
+ int fd = rb->open(filename, O_RDONLY);
+ if (fd < 0)
+ return PLUGIN_ERROR;
+ unsigned long filesize = rb->filesize(fd);
+ if (filesize > plugin_buf_len)
+ return PLUGIN_ERROR;
+ plugin_buf_len -= filesize;
+ unsigned char *jpeg_buf = plugin_buf;
+ plugin_buf += filesize;
+ rb->read(fd, jpeg_buf, filesize);
+ rb->close(fd);
+ bm.data = plugin_buf;
+ ret = decode_jpeg_mem(jpeg_buf, filesize, &bm, plugin_buf_len,
+ FORMAT_NATIVE|FORMAT_RESIZE|FORMAT_KEEP_ASPECT,
+ CFORMAT);
+ if (ret < 1)
+ return PLUGIN_ERROR;
+#ifdef USEGSLIB
+ grey_show(true);
+ grey_ub_gray_bitmap((fb_data *)bm.data, (LCD_WIDTH - bm.width) >> 1,
+ (LCD_HEIGHT - bm.height) >> 1, bm.width, bm.height);
+#else
+ rb->lcd_bitmap((fb_data *)bm.data, (LCD_WIDTH - bm.width) >> 1,
+ (LCD_HEIGHT - bm.height) >> 1, bm.width, bm.height);
+#endif
+ MYLCD_UPDATE();
+ while (rb->get_action(CONTEXT_STD,1) != ACTION_STD_OK) rb->yield();
+#ifdef USEGSLIB
+ grey_release();
+#endif
+ return PLUGIN_OK;
+}