Difference between revisions of "LXR OSX build instructions"
m (→Compile the firmware) |
|||
(10 intermediate revisions by 3 users not shown) | |||
Line 3: | Line 3: | ||
== General steps == | == General steps == | ||
− | |||
− | |||
− | |||
− | + | The LXR code is divided into two main parts | |
− | + | *the AVR Atmel code (display and front-panel control) | |
+ | *the Cortex M4 ARM code (main LXR code for DSP, sequencer, USB etc.) | ||
− | + | We need different toolkits to handle compilation of each set of code. | |
− | |||
− | |||
− | |||
− | |||
− | + | There is also a firmware utility (see <code>tools/FirmwareImageBuilder</code>); this generates the final firmware image for the LXR and requires regular <code>g++</code> to compile. It combines the AVR and the ARM code into a single image that can be uploaded from the SD-Card. | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | == | + | == AVR toolchain == |
− | * | + | * Download the Atmel AVR 8-bit toolchain for Mac from http://www.obdev.at/products/crosspack/download.html |
+ | * You will get a <code>.dmg</code> file that you should extract and install (<code>CrossPack-AVR-20131216.dmg</code> is the most recent as of 2014/05/02) | ||
+ | * The compiler and libs are installed under <code>/usr/local/CrossPack-AVR</code> | ||
+ | ** Note: this will be a symlink to a folder like <code>/usr/local/CrossPack-AVR-20131216</code> | ||
− | + | == GNU ARM toolchain == | |
− | + | * Download the GNU bare metal ARM toolchain from https://launchpad.net/gcc-arm-embedded | |
− | + | ** Note: get the Mac version (something like <code>gcc-arm-none-eabi-4_8-2014q1-20140314-mac.tar.bz2</code>) | |
+ | * Extract the compressed tar file to /usr/local | ||
− | + | cd /usr/local && tar -jxf /path/to/gcc-arm-none-eabi-4_8-2014q1-20140314-mac.tar.bz2 | |
− | |||
− | == | + | == Set environment variables == |
− | We | + | * We need to set a couple of environment variables for both compiler sets. |
− | + | export ARM_TOOLKIT_ROOT=/usr/local/gcc-arm-none-eabi-4_8-2014q1 | |
− | + | export AVR_TOOLKIT_ROOT=/usr/local/CrossPack-AVR | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | * You could add these to your <code>$HOME/.bashrc</code> to avoid setting them every time you start a terminal | |
− | + | ** Note: run <code>source $HOME/.bashrc</code> to avoid restarting your terminal the first time you do this | |
− | |||
− | + | == LXR source code == | |
+ | A number of different repositories are available: | ||
− | https://github.com/ | + | Julian's repository (original SonicPotions): https://github.com/SonicPotions/LXR |
− | https://github.com/ | + | rudeog's repository: https://github.com/rudeog/LXR -> extra features compared to Julian's repo. |
− | https://github.com/patrickdowling/LXR | + | pld's repository: https://github.com/patrickdowling/LXR |
− | https://github.com/ | + | rstephane repository (https://github.com/rstephane/LXR -> equivalent to Julian's repo. |
− | + | For example, from Terminal | |
− | |||
− | + | # This will create a new directory called "LXR" | |
− | + | git clone https://github.com/rudeog/LXR | |
− | |||
− | |||
− | |||
− | + | See https://help.github.com/ and http://git-scm.com/book for further tutorials about how to use Git. | |
− | |||
− | |||
− | == Compile == | + | == Compile the firmware == |
− | * | + | * Open a terminal window, and change directory to where you cloned the repository |
− | * | + | cd /Users/music/Documents/workspace/LXR/ |
+ | * To build the firmware | ||
+ | make firmware | ||
+ | * To remove local build files | ||
+ | make clean | ||
+ | * The generated firmware will be in <code>'firmware image/FIRMWARE.BIN'</code> | ||
+ | * Copy to your SD card, and [[LXR_Owners_Manual#Firmware_update|update the firmware]] | ||
− | If you have downloaded rstephane code, similar to @Julian and @PLD, you will | + | If you have downloaded rstephane code, similar to @Julian and @PLD, you will notice that when you power on the machine, it displays "LXR-Drums-V" instead of "LXR Drums V". If so, you have successfully loaded (and compiled) the LXR firmware!!!! |
Well done and happy hacking! | Well done and happy hacking! |
Latest revision as of 09:33, 10 May 2014
Tested on 10.8.x and 10.9.2; likely needs Xcode installed also (https://developer.apple.com/xcode/downloads/)
Contents
General steps
The LXR code is divided into two main parts
- the AVR Atmel code (display and front-panel control)
- the Cortex M4 ARM code (main LXR code for DSP, sequencer, USB etc.)
We need different toolkits to handle compilation of each set of code.
There is also a firmware utility (see tools/FirmwareImageBuilder
); this generates the final firmware image for the LXR and requires regular g++
to compile. It combines the AVR and the ARM code into a single image that can be uploaded from the SD-Card.
AVR toolchain
- Download the Atmel AVR 8-bit toolchain for Mac from http://www.obdev.at/products/crosspack/download.html
- You will get a
.dmg
file that you should extract and install (CrossPack-AVR-20131216.dmg
is the most recent as of 2014/05/02) - The compiler and libs are installed under
/usr/local/CrossPack-AVR
- Note: this will be a symlink to a folder like
/usr/local/CrossPack-AVR-20131216
- Note: this will be a symlink to a folder like
GNU ARM toolchain
- Download the GNU bare metal ARM toolchain from https://launchpad.net/gcc-arm-embedded
- Note: get the Mac version (something like
gcc-arm-none-eabi-4_8-2014q1-20140314-mac.tar.bz2
)
- Note: get the Mac version (something like
- Extract the compressed tar file to /usr/local
cd /usr/local && tar -jxf /path/to/gcc-arm-none-eabi-4_8-2014q1-20140314-mac.tar.bz2
Set environment variables
- We need to set a couple of environment variables for both compiler sets.
export ARM_TOOLKIT_ROOT=/usr/local/gcc-arm-none-eabi-4_8-2014q1 export AVR_TOOLKIT_ROOT=/usr/local/CrossPack-AVR
- You could add these to your
$HOME/.bashrc
to avoid setting them every time you start a terminal- Note: run
source $HOME/.bashrc
to avoid restarting your terminal the first time you do this
- Note: run
LXR source code
A number of different repositories are available:
Julian's repository (original SonicPotions): https://github.com/SonicPotions/LXR rudeog's repository: https://github.com/rudeog/LXR -> extra features compared to Julian's repo. pld's repository: https://github.com/patrickdowling/LXR rstephane repository (https://github.com/rstephane/LXR -> equivalent to Julian's repo.
For example, from Terminal
# This will create a new directory called "LXR" git clone https://github.com/rudeog/LXR
See https://help.github.com/ and http://git-scm.com/book for further tutorials about how to use Git.
Compile the firmware
- Open a terminal window, and change directory to where you cloned the repository
cd /Users/music/Documents/workspace/LXR/
- To build the firmware
make firmware
- To remove local build files
make clean
- The generated firmware will be in
'firmware image/FIRMWARE.BIN'
- Copy to your SD card, and update the firmware
If you have downloaded rstephane code, similar to @Julian and @PLD, you will notice that when you power on the machine, it displays "LXR-Drums-V" instead of "LXR Drums V". If so, you have successfully loaded (and compiled) the LXR firmware!!!!
Well done and happy hacking!