The Linux FireWire Record-Now Mini-HowTo for UbuntuStudio
Revision 1.00u
(C) 2007 Carlo Capocasa. Licensed under the terms of the GNU Free Documentation License.
Note: This guide makes use of a measurement tool called JDelay that generates a quite unpleasant test signal that might damage your speakers or even ears if you're not careful. Pay close attention to disable hardware monitoring whenever using the tool. There are reminders in thes steps below, but ensuring the test signal never reaches your speakers or headphones is still your own responsiblity, and I don't offer any warranties. Please make sure you understand this; when you do, please continue.
Introduction
If you already have a linux digital audio workstation with a FireWire interface set up, it is likely that recording works for you, while the sound might be a bit jittery and out of rhythm.
This is because the current linux FireWire drivers work very well, but have an issue when it comes to their latency being predictable; in other words, your recording software never knows how long it took the sound it is receiving from the microphone membranes to the hard drive, so it can't really align it properly.
While you wait for this to be fixed, you can align your sound by hand and start recording now.
NOTE: This guide has been tested using HARDWARE MONITORING. There is a theoretical suggestion on how to use software monitoring in the appendix, but it is currently not clear how well it works in practice.
Preconditions
This guide assumes you already have a linux-based digital audio workstation set up, and are using the Jack audio server to connect to your FireWire device. Recording already works, but is jittery or out of sync.
Ardour 2 works particularly well and is used as an example in this guide, but the guide may apply to other recording software as well, as long as you are using the Jack audio server and a FireWire audio interface.
You also need an audio cable to loop an output of your Audio Interface back into an input.
I. Measure your Latency
- Connect an output of your audio interface directly back to an input with an audio cable.
- Get JDelay, a Jack latency measurement tool, with your distribution's package management system.
- Start the Jack audio server.
- Start JDelay in a terminal. It will start spewing out a message telling you that it can't hear its test signal yet.
- Connect the output of JDelay to your audio interfaces output channel you connected the cable with in step 1. Connect the input channel you connected to the input of JDelay.
Now that you have a complete loop (JDelay -> audio out -> cable -> audio in -> JDelay) it will start giving you the delay ("Round trip latency") of your audio interface, as measured in audio frames.
II. Stabilize the Latency
At this point, it is likely that the latency will fluctuate quite a bit, which is the jitter you were hearing in your recordings presented to you in numbers. You now have proof that you're not rhythmically challenged after all
While it's ok that you will get a different latency every time you start up Jack, this latency cannot suddenly change while you are recording. The current Linux FireWire changed their latency every time you start up Jack, and every time there is a Jack XRun (even those that are so slight they are not normally reported by Jack). You will see these when you get a latency change in JDelay.
In order to get usable results, you need to be able to stay XRun-Free for at least 15 minutes to get good odds of getting a reasonable take.
The first step to take is to get a realtime-kernel. Not a low-latency kernel, and not a pre-emption kernel, but a Realtime-kernel. The most common one features patches by Ingo Molnar and is of the 2.6 series. In UbuntuStudio, you can do this by adding the following repository to your installation:
deb http://www.texware.it/ubuntu feisty
and install the package
- linux-image-realtime
One way to do this is with Synaptic; Go to the System menu in the top left corner, then select Administration and then Synaptic. Enter your user password. When Synaptic has started, select Software Sources in the menu. Go to the Third Party Software tab and select Add... You will be prompted for a 'deb' line, where you can enter the above. Then click the Reload button in the main Synaptic window and search for and install the package linux-image-realtime. Its dependencies will be installed automatically. As a final step, restart your machine; it will automatically boot into the new realtime kernel.
Joy! The Ubuntu realtime kernel supports all hardware the regular one does, including proprietary graphics drivers and wireless.
Even so, to stay without the slightest of XRuns it is likely you will have to increase your buffer size as much as you can; 64ms nominal latency works well for the author.
Finally, Florian Schmidt has a list of excellent latency tips you can try if you are technically minded.
http://tapas.affenbande.org/wordpress/?page_id=40
III. Align your Audio Tracks
Now that you have virtually xrun-free operation, all you need to do is record. Here's how to do it, compensating latency by hand:
- Shut down hardware monitoring on your card, and start up and connect JDelay. Make a note of the latency. Turn hardware monitoring back on again.
- Record your track. Keep plugins disabled while you're recording.
- Turn hardware monitoring back off, and start up and connect JDelay again. If the latency is still the same, you've got a winner. Congratulations! If you don't, you will have to re-record the track. Sorry about that... if this happens too often, improve the performance of your system until it doesn't any more.
- Use your digital audio workstation's 'nudge' feature to nudge your recording backward by the amount of frames JDelay reported. (Backward means your track will play earlier.)
In 'Ardour', you do this with the nudge clock: it's a small box with green numbers on the right hand side of the tool bar, with two small arrow buttons to the left of it. First you right click it, and select 'Frames' in the 'Mode' menu. Then you enter the value reported by JDelay here, and click the '<' (left arrow) button.
- Play your track and see if it sounds as rhythmic as it did playing it. If it doesn't, you can contact the author of this guide to get some help if you want to. If it does, congratulations, you have a correctly aligned take of your recording.
-- biased content --
If your digital audio workstation doesn't support nudging tracks, this is your opportunity to start using Ardour 2. Not only will you have a quick solution to your current problem, you will also join an amazing community of wonderful people, and be able to witness true dedication and passion, which is as precious as life experience can get. So head over to ardour.org, donate as much as you can afford to the project (best via a subscription), and download your copy of the brand new and polished Ardour 2 from your distribution!
-- end of biased content --
Appendis A. Technical Explanation
Normally, when you record something with a Digital Audio Workstation (DAW), it automagically aligns your tracks according to how long it took you to hear the accompaniment signal (a click sound, what's already recorded, or both), and how long it takes to reach. If you are using hardware monitoring, your sound card feeds you the signal instanteniously (for practical purposes), while your DAW gets it after the one way latency (theoretically 50% of the round trip latency you measured, or the time the signal takes from your Microphone to to the hard drive).
The accompaniment signal also takes a one way latency, from the hard drive through your output to your headphones.
While recording, your DAW needs to wait a full round trip latency until it gets a signal: Out to your headphones, in through you and your microphone. Since the latency information given out by current firewire drivers is zero, you will get a correctly aligned audio track if you compensate by a full round trip latency, which is the same thing measured by JDelay. (In this case, the connection cable takes the place of your headphones, you, and the Mic).
Theoretically, using software monitoring, you should compensate by 50% of the round trip latency; however, you would have to get quite low latency values that still produce no changes in JDelay in order to be able to use it at all. Also, it is not known whether the one-way latency on the way in is the same size as on the way out, or how large the difference is. It is currently not clear if this is practical or not. Email the author if you have information on this, and especially how you got XRUN-Free operation at latencies low enough to support software monitoring!
Appendix B. Note From The Author
Thank you for reading, I hope you will be able to fulfill your recording dreams right now thanks to the information in this guide and the dedicated work of the community. Donate often, donate generously!
My background is recording music professionally with Ardour 2 and releasing it as Free Music (Free as in Freedom) to the community. My work can be found at
Carlo Capocasa, May 2007