From 82f9056988331572e01231d70fadc64b7ab76c6f Mon Sep 17 00:00:00 2001 From: Daniel Ankers Date: Sun, 4 Mar 2007 20:06:41 +0000 Subject: Dual core support for PP502x players (iPod G4 and later, iriver h10, Sansa - iPod G3 will be coming soon.) This allows threads to be run on either core provided that all communications between the cores is done using uncached memory. There should be no significant change in battery life from doing this. Documentation (on the RockboxKernel wiki page) will follow shortly. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@12601 a1c6a512-1295-4272-9138-f99709370657 --- firmware/drivers/ata.c | 3 ++- firmware/drivers/ata_mmc.c | 3 ++- firmware/drivers/lcd-16bit.c | 3 ++- firmware/drivers/lcd-1bit-vert.c | 3 ++- firmware/drivers/lcd-2bit-horz.c | 3 ++- firmware/drivers/lcd-2bit-vert.c | 3 ++- firmware/drivers/lcd-player.c | 3 ++- firmware/drivers/lcd-remote-1bit-v.c | 3 ++- firmware/drivers/lcd-remote-2bit-vi.c | 3 ++- 9 files changed, 18 insertions(+), 9 deletions(-) (limited to 'firmware/drivers') diff --git a/firmware/drivers/ata.c b/firmware/drivers/ata.c index 21376ab9a7..76c0090a12 100644 --- a/firmware/drivers/ata.c +++ b/firmware/drivers/ata.c @@ -991,7 +991,8 @@ int ata_init(void) last_disk_activity = current_tick; create_thread(ata_thread, ata_stack, sizeof(ata_stack), ata_thread_name - IF_PRIO(, PRIORITY_SYSTEM)); + IF_PRIO(, PRIORITY_SYSTEM) + IF_COP(, CPU, false)); initialized = true; } diff --git a/firmware/drivers/ata_mmc.c b/firmware/drivers/ata_mmc.c index a549624b2c..377d2444bf 100644 --- a/firmware/drivers/ata_mmc.c +++ b/firmware/drivers/ata_mmc.c @@ -1173,7 +1173,8 @@ int ata_init(void) queue_init(&mmc_queue, true); create_thread(mmc_thread, mmc_stack, - sizeof(mmc_stack), mmc_thread_name IF_PRIO(, PRIORITY_SYSTEM)); + sizeof(mmc_stack), mmc_thread_name IF_PRIO(, PRIORITY_SYSTEM) + IF_COP(, CPU, false)); tick_add_task(mmc_tick); initialized = true; } diff --git a/firmware/drivers/lcd-16bit.c b/firmware/drivers/lcd-16bit.c index d545bf3fe4..7269e54dcd 100644 --- a/firmware/drivers/lcd-16bit.c +++ b/firmware/drivers/lcd-16bit.c @@ -89,7 +89,8 @@ void lcd_init(void) create_thread(scroll_thread, scroll_stack, sizeof(scroll_stack), scroll_name - IF_PRIO(, PRIORITY_USER_INTERFACE)); + IF_PRIO(, PRIORITY_USER_INTERFACE) + IF_COP(, CPU, false)); } /*** parameter handling ***/ diff --git a/firmware/drivers/lcd-1bit-vert.c b/firmware/drivers/lcd-1bit-vert.c index 62dfab0180..64c1ace292 100644 --- a/firmware/drivers/lcd-1bit-vert.c +++ b/firmware/drivers/lcd-1bit-vert.c @@ -68,7 +68,8 @@ void lcd_init(void) /* Call device specific init */ lcd_init_device(); create_thread(scroll_thread, scroll_stack, - sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE)); + sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE) + IF_COP(, CPU, false)); } /*** parameter handling ***/ diff --git a/firmware/drivers/lcd-2bit-horz.c b/firmware/drivers/lcd-2bit-horz.c index 9ba52e1ba9..475e466c42 100644 --- a/firmware/drivers/lcd-2bit-horz.c +++ b/firmware/drivers/lcd-2bit-horz.c @@ -79,7 +79,8 @@ void lcd_init(void) /* Call device specific init */ lcd_init_device(); create_thread(scroll_thread, scroll_stack, - sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE)); + sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE) + IF_COP(, CPU, false)); } /*** parameter handling ***/ diff --git a/firmware/drivers/lcd-2bit-vert.c b/firmware/drivers/lcd-2bit-vert.c index 7b3352b9d6..7a49f35312 100644 --- a/firmware/drivers/lcd-2bit-vert.c +++ b/firmware/drivers/lcd-2bit-vert.c @@ -82,7 +82,8 @@ void lcd_init(void) /* Call device specific init */ lcd_init_device(); create_thread(scroll_thread, scroll_stack, - sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE)); + sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE) + IF_COP(, CPU, false)); } /*** parameter handling ***/ diff --git a/firmware/drivers/lcd-player.c b/firmware/drivers/lcd-player.c index 8ca81473fc..c863c9f188 100644 --- a/firmware/drivers/lcd-player.c +++ b/firmware/drivers/lcd-player.c @@ -610,7 +610,8 @@ void lcd_init (void) lcd_set_contrast(lcd_default_contrast()); create_thread(scroll_thread, scroll_stack, - sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE)); + sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE) + IF_COP(, CPU, false)); } void lcd_jump_scroll (int mode) /* 0=off, 1=once, ..., JUMP_SCROLL_ALWAYS */ diff --git a/firmware/drivers/lcd-remote-1bit-v.c b/firmware/drivers/lcd-remote-1bit-v.c index c81ccc83c9..0aa3d890f7 100644 --- a/firmware/drivers/lcd-remote-1bit-v.c +++ b/firmware/drivers/lcd-remote-1bit-v.c @@ -903,5 +903,6 @@ void lcd_remote_init(void) queue_init(&remote_scroll_queue, false); #endif create_thread(scroll_thread, scroll_stack, - sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE)); + sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE) + IF_COP(, CPU, false)); } diff --git a/firmware/drivers/lcd-remote-2bit-vi.c b/firmware/drivers/lcd-remote-2bit-vi.c index 281cbc2189..e0f6b35004 100644 --- a/firmware/drivers/lcd-remote-2bit-vi.c +++ b/firmware/drivers/lcd-remote-2bit-vi.c @@ -1241,5 +1241,6 @@ void lcd_remote_init(void) queue_init(&remote_scroll_queue, false); #endif create_thread(scroll_thread, scroll_stack, - sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE)); + sizeof(scroll_stack), scroll_name IF_PRIO(, PRIORITY_USER_INTERFACE) + IF_COP(, CPU, false)); } -- cgit v1.2.3