summaryrefslogtreecommitdiff
path: root/firmware
diff options
context:
space:
mode:
authorMichael Sevakis <jethead71@rockbox.org>2010-05-17 12:34:05 +0000
committerMichael Sevakis <jethead71@rockbox.org>2010-05-17 12:34:05 +0000
commitfcf36dd4f9879a82342e5606535d2dcf46d1de2a (patch)
tree21ed249c7a6f9d0bd7e2049c7a9f9e0708ba28f8 /firmware
parent9fde12676b382a31a10c58e2473edfde460e4d73 (diff)
downloadrockbox-fcf36dd4f9879a82342e5606535d2dcf46d1de2a.zip
rockbox-fcf36dd4f9879a82342e5606535d2dcf46d1de2a.tar.gz
rockbox-fcf36dd4f9879a82342e5606535d2dcf46d1de2a.tar.bz2
rockbox-fcf36dd4f9879a82342e5606535d2dcf46d1de2a.tar.xz
Simplify mpegplayer a bit and use array-based lists rather than linked lists for stream management. Move a couple useful functions to handle pointer arrays from kernel.c into general.c; mpeglayer now makes use of them.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@26101 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware')
-rw-r--r--firmware/export/general.h15
-rw-r--r--firmware/general.c37
-rw-r--r--firmware/kernel.c35
3 files changed, 53 insertions, 34 deletions
diff --git a/firmware/export/general.h b/firmware/export/general.h
index 8da4a0a..16c8240 100644
--- a/firmware/export/general.h
+++ b/firmware/export/general.h
@@ -72,4 +72,19 @@ char *create_datetime_filename(char *buffer, const char *path,
bool unique_time);
#endif /* CONFIG_RTC */
+/***
+ ** Compacted pointer lists
+ **
+ ** N-length list requires N+1 elements to ensure NULL-termination.
+ **/
+
+/* Find a pointer in a pointer array. Returns the addess of the element if
+ found or the address of the terminating NULL otherwise. This can be used
+ to bounds check and add items. */
+void ** find_array_ptr(void **arr, void *ptr);
+
+/* Remove a pointer from a pointer array if it exists. Compacts it so that
+ no gaps exist. Returns 0 on success and -1 if the element wasn't found. */
+int remove_array_ptr(void **arr, void *ptr);
+
#endif /* GENERAL_H */
diff --git a/firmware/general.c b/firmware/general.c
index fa10254..20b0277 100644
--- a/firmware/general.c
+++ b/firmware/general.c
@@ -196,3 +196,40 @@ char *create_datetime_filename(char *buffer, const char *path,
return buffer;
}
#endif /* CONFIG_RTC */
+
+/***
+ ** Compacted pointer lists
+ **
+ ** N-length list requires N+1 elements to ensure NULL-termination.
+ **/
+
+/* Find a pointer in a pointer array. Returns the addess of the element if
+ * found or the address of the terminating NULL otherwise. This can be used
+ * to bounds check and add items. */
+void ** find_array_ptr(void **arr, void *ptr)
+{
+ void *curr;
+ for (curr = *arr; curr != NULL && curr != ptr; curr = *(++arr));
+ return arr;
+}
+
+/* Remove a pointer from a pointer array if it exists. Compacts it so that
+ * no gaps exist. Returns 0 on success and -1 if the element wasn't found. */
+int remove_array_ptr(void **arr, void *ptr)
+{
+ void *curr;
+ arr = find_array_ptr(arr, ptr);
+
+ if (*arr == NULL)
+ return -1;
+
+ /* Found. Slide up following items. */
+ do
+ {
+ void **arr1 = arr + 1;
+ *arr++ = curr = *arr1;
+ }
+ while (curr != NULL);
+
+ return 0;
+}
diff --git a/firmware/kernel.c b/firmware/kernel.c
index d8c67e8..fe40c35 100644
--- a/firmware/kernel.c
+++ b/firmware/kernel.c
@@ -27,6 +27,7 @@
#include "system.h"
#include "panic.h"
#include "debug.h"
+#include "general.h"
/* Make this nonzero to enable more elaborate checks on objects */
#if defined(DEBUG) || defined(SIMULATOR)
@@ -62,40 +63,6 @@ static struct
} all_queues SHAREDBSS_ATTR;
/****************************************************************************
- * Common utilities
- ****************************************************************************/
-
-/* Find a pointer in a pointer array. Returns the addess of the element if
- * found or the address of the terminating NULL otherwise. */
-static void ** find_array_ptr(void **arr, void *ptr)
-{
- void *curr;
- for(curr = *arr; curr != NULL && curr != ptr; curr = *(++arr));
- return arr;
-}
-
-/* Remove a pointer from a pointer array if it exists. Compacts it so that
- * no gaps exist. Returns 0 on success and -1 if the element wasn't found. */
-static int remove_array_ptr(void **arr, void *ptr)
-{
- void *curr;
- arr = find_array_ptr(arr, ptr);
-
- if(*arr == NULL)
- return -1;
-
- /* Found. Slide up following items. */
- do
- {
- void **arr1 = arr + 1;
- *arr++ = curr = *arr1;
- }
- while(curr != NULL);
-
- return 0;
-}
-
-/****************************************************************************
* Standard kernel stuff
****************************************************************************/
void kernel_init(void)