Magic Lantern Firmware Wiki
Advertisement

[28Apr2013] I am in the process of getting Magic Lantern (ML) to compile and run on a 650D on Mac OS X Mountain Lion. I decided to add yet another howto for this as the others I found were for slightly older versions and I ran into some hiccups along the way.  I am currently able to compile an autoexec.bat for the 650D but have not tried running it yet.  I wanted to try to get this down before I forgot too much. The guide assumes you can Next through a standard installation.  More complex installs will be called out.

Specifics:[]

  • Mac Mini 2011 | 2.5GHz Core i5 | 8GB RAM
  • Mac OS X 10.8.3
  • Xcode 4.6.2
  • MacPorts 2.1.3
  • MacHg 0.9.25
  • hg 2.5.4
  • yagarto 4.7.2
  • TextWrangler

Install Xcode and Command Line Tools[]

Xcode is available on the Mac App Store.  Open up the store and download and install Xcode (free).

You will need to install the command line tools from within Xcode.  Open Xcode. Go to Preferences (Cmd + <comma>). Go to the Downloads tab, Components section.  It should look like this:

400px-Screen_Shot_2013-04-27_at_4.24.22_PM.png

Select the install button next to Command Line Tools.  This will download and install the tools.  You will need to agree to the EULA using the command line.  Open Terminal and run the following.

xcodebuild -license

"Read" the EULA. Hit the spacebar to proceed.  At the bottom, type agree to agree to the EULA.

Switch to gnutar (mentioned by other howto's)[]

Mac OS X uses bsdtar by default. I howto's have mentioned switching the default to be gnutar.  To do this, run the following commands in a Terminal shell.

cd /usr/bin

sudo ln -fs gnutar tar

tar --version

The second line may ask for your password.  The third line will output a version message that should include GNU.

Install MacPorts and dependencies[]

ML requires some denpendencies that can be install from MacPorts.  MacPorts can be found HERE. I used the pkg installer.  Download the Mountain Lion installer and run the standard install.  You will need to close any Terminal shells the were open before installing MacPorts to run the command port.

To install the denpendencies, run the following command in a new Terminal shell.

sudo port install gmp mpfr libmpc libiconv wget

Enter your password if requested.  This will take a few minutes to download and install.

Install MacHg and hg[]

MacHg is a nice GUI for accessing a Mercurial repository.  You will also need hg for the command line for the make files to run properly.  You can find MacHg HERE. Unzip and run the standard install.

To setup the ML repository, select Clone a Repository in MacHg. Enter magic-lantern for the short name and https://bitbucket.org/hudson/magic-lantern/ for the Server URL.

400px-Screen_Shot_2013-04-27_at_4.23.58_PM.png

For the clone setup, you can keep the short name the same.  Make sure the Local Path is /Users/<your_username>/magic-lantern  This should cause the least amount of issues later.  Click Clone Repository.

400px-Screen_Shot_2013-04-27_at_5.16.18_PM.png

ML is currently using the unified branch of the repository.  To get on to this branch, open Preferences in MacHg and go to the appearance tab.  Make sure that Show Branch Column is checked.

Save the preferences. Select the clone (local) magic-lantern repository. Switch to the Detailed view. Use the gear on the right side to navigate to the tip of the unified branch. 

Screen Shot 2013-04-27 at 5.20

The revision should be labeled tip and unified with color coded tags. Right-click on the revision and select Update Repository to Revision.  You can select the clean checkbox to remove any changes or not if you have made changes you want to keep. Click update.

You will also need a command line version of hg. You can download it HERE.  Unzip and run the standard install.  You will need to close any open Terminal shell windows to be able to use the hg command.

Install yagarto (Yet Another GNU ARM Toolchain)[]

Download yagarto from HERE.  The install is a bit different from normal.  It is described in the README, but I will go through it briefly here.  Mount and open the dmg downloaded from above and agree to the terms (if you do agree). Create a directory that you want yagarto to be installed in.  I suggest ~/yagarto.  Run the below lines in a terminal or use the finder GUI.

cd ~

mkdir yagarto

Copy the yagarto-<version> bundle into the newly created directory.  Double click on the bundle and it will install itself into the directory that contains the bundle (should be ~/yagarto).

<setup bashrc>

...

Advertisement