From 6c522624b364b3d85ac7f95d55061d4677246dad Mon Sep 17 00:00:00 2001 From: Rafaël Carré Date: Thu, 10 Jun 2010 19:46:14 +0000 Subject: ppmviewer/rockpaint: do not steal the audiobuffer (and stop playback) if the plugin buffer is large enough git-svn-id: svn://svn.rockbox.org/rockbox/trunk@26750 a1c6a512-1295-4272-9138-f99709370657 --- apps/plugins/ppmviewer.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) (limited to 'apps/plugins/ppmviewer.c') diff --git a/apps/plugins/ppmviewer.c b/apps/plugins/ppmviewer.c index af66b58736..c947af10bd 100644 --- a/apps/plugins/ppmviewer.c +++ b/apps/plugins/ppmviewer.c @@ -294,11 +294,17 @@ enum plugin_status plugin_start(const void* parameter) if(!parameter) return PLUGIN_ERROR; size_t buffer_size; - char *audiobuf = rb->plugin_get_audio_buffer(&buffer_size); + char *audiobuf = rb->plugin_get_buffer(&buffer_size); if (buffer_size < PPM_MAXSIZE + LCD_WIDTH * LCD_HEIGHT + 1) { - rb->splash(HZ, "Not enough memory"); - return PLUGIN_ERROR; + /* steal from audiobuffer if plugin buffer is too small */ + audiobuf = rb->plugin_get_audio_buffer(&buffer_size); + + if (buffer_size < PPM_MAXSIZE + LCD_WIDTH * LCD_HEIGHT + 1) + { + rb->splash(HZ, "Not enough memory"); + return PLUGIN_ERROR; + } } /* align on 16 bits */ -- cgit v1.2.3