summaryrefslogtreecommitdiff
path: root/apps/plugins/mpegplayer
diff options
context:
space:
mode:
authorMichael Sevakis <jethead71@rockbox.org>2008-04-06 04:34:57 +0000
committerMichael Sevakis <jethead71@rockbox.org>2008-04-06 04:34:57 +0000
commit05099149f193cac0c81b0129c17feb78b1a9681a (patch)
tree3dd5494dd494bcb4490ddcedef99e9f3a895cd3f /apps/plugins/mpegplayer
parentbe698f086de4641a45dffd9289671588c2391a3c (diff)
downloadrockbox-05099149f193cac0c81b0129c17feb78b1a9681a.tar.gz
rockbox-05099149f193cac0c81b0129c17feb78b1a9681a.zip
Enable nocache sections using the linker. PP5022/4 must use SW_CORELOCK now with shared variables in DRAM (it seems swp(b) is at least partially broken on all PP or I'm doing something very wrong here :\). For core-shared data use SHAREDBSS/DATA_ATTR. NOCACHEBSS/DATA_ATTR is available whether or not single core is forced for static peripheral-DMA buffer allocation without use of the UNCACHED_ADDR macro in code and is likely useful on a non-PP target with a data cache (although not actually enabled in config.h and the .lds's in this commit).
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@16981 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'apps/plugins/mpegplayer')
-rw-r--r--apps/plugins/mpegplayer/alloc.c8
-rw-r--r--apps/plugins/mpegplayer/audio_thread.c4
-rw-r--r--apps/plugins/mpegplayer/disk_buf.c10
-rw-r--r--apps/plugins/mpegplayer/disk_buf.h2
-rw-r--r--apps/plugins/mpegplayer/mpeg_parser.c2
-rw-r--r--apps/plugins/mpegplayer/stream_mgr.c6
-rw-r--r--apps/plugins/mpegplayer/stream_mgr.h2
-rw-r--r--apps/plugins/mpegplayer/video_out_rockbox.c2
-rw-r--r--apps/plugins/mpegplayer/video_thread.c4
9 files changed, 20 insertions, 20 deletions
diff --git a/apps/plugins/mpegplayer/alloc.c b/apps/plugins/mpegplayer/alloc.c
index f6661d4632..7ad8644e59 100644
--- a/apps/plugins/mpegplayer/alloc.c
+++ b/apps/plugins/mpegplayer/alloc.c
@@ -30,10 +30,10 @@ static size_t bufsize;
30static unsigned char* mallocbuf; 30static unsigned char* mallocbuf;
31 31
32/* libmpeg2 allocator */ 32/* libmpeg2 allocator */
33static off_t mpeg2_mem_ptr NOCACHEBSS_ATTR; 33static off_t mpeg2_mem_ptr SHAREDBSS_ATTR;
34static size_t mpeg2_bufsize NOCACHEBSS_ATTR; 34static size_t mpeg2_bufsize SHAREDBSS_ATTR;
35static unsigned char *mpeg2_mallocbuf NOCACHEBSS_ATTR; 35static unsigned char *mpeg2_mallocbuf SHAREDBSS_ATTR;
36static unsigned char *mpeg2_bufallocbuf NOCACHEBSS_ATTR; 36static unsigned char *mpeg2_bufallocbuf SHAREDBSS_ATTR;
37 37
38#if defined(DEBUG) || defined(SIMULATOR) 38#if defined(DEBUG) || defined(SIMULATOR)
39const char * mpeg_get_reason_str(int reason) 39const char * mpeg_get_reason_str(int reason)
diff --git a/apps/plugins/mpegplayer/audio_thread.c b/apps/plugins/mpegplayer/audio_thread.c
index 7d2f849a44..1fcd1424ff 100644
--- a/apps/plugins/mpegplayer/audio_thread.c
+++ b/apps/plugins/mpegplayer/audio_thread.c
@@ -44,8 +44,8 @@ static size_t audio_stack_size; /* Keep gcc happy and init */
44#ifndef SIMULATOR 44#ifndef SIMULATOR
45static uint32_t codec_stack_copy[AUDIO_STACKSIZE / sizeof(uint32_t)]; 45static uint32_t codec_stack_copy[AUDIO_STACKSIZE / sizeof(uint32_t)];
46#endif 46#endif
47static struct event_queue audio_str_queue NOCACHEBSS_ATTR; 47static struct event_queue audio_str_queue SHAREDBSS_ATTR;
48static struct queue_sender_list audio_str_queue_send NOCACHEBSS_ATTR; 48static struct queue_sender_list audio_str_queue_send SHAREDBSS_ATTR;
49struct stream audio_str IBSS_ATTR; 49struct stream audio_str IBSS_ATTR;
50 50
51/* libmad related definitions */ 51/* libmad related definitions */
diff --git a/apps/plugins/mpegplayer/disk_buf.c b/apps/plugins/mpegplayer/disk_buf.c
index 289918fc63..46a060221d 100644
--- a/apps/plugins/mpegplayer/disk_buf.c
+++ b/apps/plugins/mpegplayer/disk_buf.c
@@ -21,12 +21,12 @@
21#include "plugin.h" 21#include "plugin.h"
22#include "mpegplayer.h" 22#include "mpegplayer.h"
23 23
24static struct mutex disk_buf_mtx NOCACHEBSS_ATTR; 24static struct mutex disk_buf_mtx SHAREDBSS_ATTR;
25static struct event_queue disk_buf_queue NOCACHEBSS_ATTR; 25static struct event_queue disk_buf_queue SHAREDBSS_ATTR;
26static struct queue_sender_list disk_buf_queue_send NOCACHEBSS_ATTR; 26static struct queue_sender_list disk_buf_queue_send SHAREDBSS_ATTR;
27static uint32_t disk_buf_stack[DEFAULT_STACK_SIZE*2/sizeof(uint32_t)]; 27static uint32_t disk_buf_stack[DEFAULT_STACK_SIZE*2/sizeof(uint32_t)];
28 28
29struct disk_buf disk_buf NOCACHEBSS_ATTR; 29struct disk_buf disk_buf SHAREDBSS_ATTR;
30static struct list_item nf_list; 30static struct list_item nf_list;
31 31
32static inline void disk_buf_lock(void) 32static inline void disk_buf_lock(void)
@@ -566,7 +566,7 @@ static int disk_buf_probe(off_t start, size_t length,
566 { 566 {
567 if (disk_buf.cache[page] != tag) 567 if (disk_buf.cache[page] != tag)
568 { 568 {
569 static struct dbuf_range rng NOCACHEBSS_ATTR; 569 static struct dbuf_range rng IBSS_ATTR;
570 DEBUGF("disk_buf: cache miss\n"); 570 DEBUGF("disk_buf: cache miss\n");
571 rng.tag_start = tag; 571 rng.tag_start = tag;
572 rng.tag_end = tag_end; 572 rng.tag_end = tag_end;
diff --git a/apps/plugins/mpegplayer/disk_buf.h b/apps/plugins/mpegplayer/disk_buf.h
index 79c3328535..04b4675768 100644
--- a/apps/plugins/mpegplayer/disk_buf.h
+++ b/apps/plugins/mpegplayer/disk_buf.h
@@ -84,7 +84,7 @@ struct disk_buf
84 bool need_seek; /* Need to seek because a read was not contiguous */ 84 bool need_seek; /* Need to seek because a read was not contiguous */
85}; 85};
86 86
87extern struct disk_buf disk_buf NOCACHEBSS_ATTR; 87extern struct disk_buf disk_buf SHAREDBSS_ATTR;
88 88
89static inline bool disk_buf_is_data_ready(struct stream_hdr *sh, 89static inline bool disk_buf_is_data_ready(struct stream_hdr *sh,
90 ssize_t margin) 90 ssize_t margin)
diff --git a/apps/plugins/mpegplayer/mpeg_parser.c b/apps/plugins/mpegplayer/mpeg_parser.c
index cd54e84452..617b7fe9f9 100644
--- a/apps/plugins/mpegplayer/mpeg_parser.c
+++ b/apps/plugins/mpegplayer/mpeg_parser.c
@@ -21,7 +21,7 @@
21#include "plugin.h" 21#include "plugin.h"
22#include "mpegplayer.h" 22#include "mpegplayer.h"
23 23
24struct stream_parser str_parser NOCACHEBSS_ATTR; 24struct stream_parser str_parser SHAREDBSS_ATTR;
25 25
26static void parser_init_state(void) 26static void parser_init_state(void)
27{ 27{
diff --git a/apps/plugins/mpegplayer/stream_mgr.c b/apps/plugins/mpegplayer/stream_mgr.c
index 778ed0df83..24e820b0af 100644
--- a/apps/plugins/mpegplayer/stream_mgr.c
+++ b/apps/plugins/mpegplayer/stream_mgr.c
@@ -27,11 +27,11 @@
27GREY_INFO_STRUCT_IRAM 27GREY_INFO_STRUCT_IRAM
28#endif 28#endif
29 29
30static struct event_queue stream_mgr_queue NOCACHEBSS_ATTR; 30static struct event_queue stream_mgr_queue SHAREDBSS_ATTR;
31static struct queue_sender_list stream_mgr_queue_send NOCACHEBSS_ATTR; 31static struct queue_sender_list stream_mgr_queue_send SHAREDBSS_ATTR;
32static uint32_t stream_mgr_thread_stack[DEFAULT_STACK_SIZE*2/sizeof(uint32_t)]; 32static uint32_t stream_mgr_thread_stack[DEFAULT_STACK_SIZE*2/sizeof(uint32_t)];
33 33
34struct stream_mgr stream_mgr NOCACHEBSS_ATTR; 34struct stream_mgr stream_mgr SHAREDBSS_ATTR;
35 35
36/* Forward decs */ 36/* Forward decs */
37static int stream_on_close(void); 37static int stream_on_close(void);
diff --git a/apps/plugins/mpegplayer/stream_mgr.h b/apps/plugins/mpegplayer/stream_mgr.h
index 339af17182..f577e5c2ce 100644
--- a/apps/plugins/mpegplayer/stream_mgr.h
+++ b/apps/plugins/mpegplayer/stream_mgr.h
@@ -44,7 +44,7 @@ struct stream_mgr
44 } parms; 44 } parms;
45}; 45};
46 46
47extern struct stream_mgr stream_mgr NOCACHEBSS_ATTR; 47extern struct stream_mgr stream_mgr SHAREDBSS_ATTR;
48 48
49struct stream_window 49struct stream_window
50{ 50{
diff --git a/apps/plugins/mpegplayer/video_out_rockbox.c b/apps/plugins/mpegplayer/video_out_rockbox.c
index c8245cc1bf..547768887a 100644
--- a/apps/plugins/mpegplayer/video_out_rockbox.c
+++ b/apps/plugins/mpegplayer/video_out_rockbox.c
@@ -52,7 +52,7 @@ static struct vo_data vo;
52#endif 52#endif
53 53
54#if NUM_CORES > 1 54#if NUM_CORES > 1
55static struct mutex vo_mtx NOCACHEBSS_ATTR; 55static struct mutex vo_mtx SHAREDBSS_ATTR;
56#endif 56#endif
57 57
58static inline void video_lock_init(void) 58static inline void video_lock_init(void)
diff --git a/apps/plugins/mpegplayer/video_thread.c b/apps/plugins/mpegplayer/video_thread.c
index d16eb771b0..6e7c9aea15 100644
--- a/apps/plugins/mpegplayer/video_thread.c
+++ b/apps/plugins/mpegplayer/video_thread.c
@@ -54,8 +54,8 @@ struct video_thread_data
54 so maybe we can reduce it. */ 54 so maybe we can reduce it. */
55#define VIDEO_STACKSIZE (4*1024) 55#define VIDEO_STACKSIZE (4*1024)
56static uint32_t video_stack[VIDEO_STACKSIZE / sizeof(uint32_t)] IBSS_ATTR; 56static uint32_t video_stack[VIDEO_STACKSIZE / sizeof(uint32_t)] IBSS_ATTR;
57static struct event_queue video_str_queue NOCACHEBSS_ATTR; 57static struct event_queue video_str_queue SHAREDBSS_ATTR;
58static struct queue_sender_list video_str_queue_send NOCACHEBSS_ATTR; 58static struct queue_sender_list video_str_queue_send SHAREDBSS_ATTR;
59struct stream video_str IBSS_ATTR; 59struct stream video_str IBSS_ATTR;
60 60
61static void draw_fps(struct video_thread_data *td) 61static void draw_fps(struct video_thread_data *td)