Rockbox
Find a file
Thomas Martitz 6d85de3419 Implement cooperative threads on hosted platforms using C code.
This replaces SDL threads with real cooperative threads, which are less cpu intensive and allow priority scheduling.
The backend for context switching is dependant on the host (sigaltstack/longjmp on Unix, Fibers on Windows).
configure has options to force or disallow SDL threads.

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@29327 a1c6a512-1295-4272-9138-f99709370657
2011-02-18 22:46:01 +00:00
android Update Android README in line with configure changes from r29286 2011-02-13 13:26:16 +00:00
apps Make sure we don't read past the end of a C-string in format_track_path. Second part of FS #11947 2011-02-18 21:56:48 +00:00
backdrops Commit part of FS#10937: CabbieV2 port for the Philips GoGear 2011-01-09 22:10:29 +00:00
bootloader M:Robe 500 bootloader: change the order of the backlight/lcd setup. 2011-02-06 21:04:51 +00:00
debian FS#11924 - Use separate targets for RaaA devices. This changes tools/configure to present the (currently four) possible RaaA targets as separate menu items instead of a single "Application" item with a follow-up question. 2011-02-11 19:51:29 +00:00
docs Some languages updates for the upcoming release: 2011-02-14 17:15:57 +00:00
firmware Implement cooperative threads on hosted platforms using C code. 2011-02-18 22:46:01 +00:00
flash Move memset6() declaration to string-extra.h, kills a warning compiling for android since it ships a memory.h. 2010-08-12 13:55:01 +00:00
fonts Fix the eogonek glyph in 14-Nimbus (the credit goes to the author of FS#11785) 2010-12-11 21:05:20 +00:00
gdb Generate C file / header for svn version string 2010-05-27 09:41:46 +00:00
icons
lib fix build 2011-01-27 11:33:33 +00:00
manual Use generic keyboard actions rather than the device-dependent 2011-02-11 18:45:04 +00:00
rbutil Replace list of languages with map. 2011-02-04 23:28:34 +00:00
tools Implement cooperative threads on hosted platforms using C code. 2011-02-18 22:46:01 +00:00
uisimulator Implement cooperative threads on hosted platforms using C code. 2011-02-18 22:46:01 +00:00
utils Revert nonsense change. 2011-02-02 22:02:56 +00:00
wps Add cabbie theme for 800x480 2011-02-08 21:13:57 +00:00

               __________               __   ___.
     Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
     Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
     Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
     Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
                       \/            \/     \/    \/            \/

Build Your Own Rockbox

1. Check out 'rockbox' from SVN (or extract a downloaded archive).

   $ svn co svn://svn.rockbox.org/rockbox/trunk rockbox

     or

   $ tar xjf rockbox.tar.bz2

2. Create a build directory, preferably in the same directory as the firmware/
   and apps/ directories. This is where all generated files will be written.

   $ cd rockbox
   $ mkdir build
   $ cd build

3. Make sure you have sh/arm/m68k-elf-gcc and siblings in the PATH. Make sure
   that you have 'perl' in your PATH too. Your gcc cross compiler needs to be
   a particular version depending on what player you are compiling for. These
   can be acquired with the rockboxdev.sh script in the /tools/ folder of the
   source, or will have been included if you've installed one of the
   toolchains or development environments provided at http://www.rockbox.org/

   $ which sh-elf-gcc
   $ which perl

4. In your build directory, run the 'tools/configure' script and enter what
   target you want to build for and if you want a debug version or not (and a
   few more questions). It'll prompt you. The debug version is for making a
   gdb version out of it. It is only useful if you run gdb towards your target
   Archos.

   $ ../tools/configure

5. *ploink*. Now you have got a Makefile generated for you.

6. Run 'make' and soon the necessary pieces from the firmware and the apps
   directories have been compiled, linked and scrambled for you.

   $ make
   $ make zip

7. unzip the rockbox.zip on your music player, reboot it and
   *smile*.

If you want to build for more than one target, just create several build
directories and create a setup for each target:

   $ mkdir build-fmrecorder
   $ cd build-fmrecorder
   $ ../tools/configure

   $ mkdir build-player
   $ cd build-player
   $ ../tools/configure

Questions anyone? Ask on the mailing list. We'll be happy to help you!