Trouble in Promise-land

What's the first thing you do when you've got a display that has tons of interfaces and bandwidth at its disposal? Try them all at once to see if anything breaks of course. Over the course of the past few days that's exactly what I did. Unfortunately I did find a situation where things broke.

For whatever reason, if you're doing a lot of writes to the Promise Pegasus while playing music (or any other constant audio) through the Thunderbolt Display's internal speakers the audio will eventually corrupt. You can hear exactly what I'm talking about below:

TB Pegasus Audio Issue by AnandTech

This is a recording taken of me listening to music on the Thunderbolt Display (via its internal speakers) while writing a couple hundred gigabytes to the Pegasus R6. Note the introduction of what can only be described as really bad noise at the 6 second marker.

If you stop music playback and quickly resume, the problem will still be there. You have to restart the application that's using the audio codec to recover from this point. From a hardware standpoint, the codec just needs to go through an off/on (sleep/wake?) cycle to return back to normal. If you do this however and haven't stopped the transfer, the problem will creep up again. Stopping the transfer while playing back music won't fix the issue either. You have to stop the transfer and restart the music playback application for it to go away.

The issue goes deeper than that. I went out and bought a Creative Labs X-Fi Go Pro USB sound card to see if the problem stopped at the internal audio codec or extended to all USB sound devices. Unfortunately, it does even happen if you're using an external USB sound card connected to the Thunderbolt Display. Connect the same sound card directly to your Mac or use your Mac's 1/8" stereo jack and the problem goes away.

I was worried that what may appear as noise through speakers could result in data corruption over USB transfers. I ran the Pegasus write test while copying a bunch of files to an SSD attached via USB to the Thunderbolt Display and never saw any corruption on the SSD. This appears to be limited entirely to audio playback.

What's truly bizarre is I can only get the issue to appear when writing to the Pegasus, hundreds of GBs of sequential reads don't seem to produce it. Short bursts of writes don't seem to cause it either. Sending tons of data across the monitor's Gigabit Ethernet, FireWire 800 and USB ports doesn't seem to trigger it either. It appears to be an issue with the Pegasus and the Thunderbolt Display. But which device is ultimately at fault? Is it a problem with the Thunderbolt Display or the Pegasus? Ideally I'd use another Thunderbolt storage device to see if the issue remained, but I couldn't get my hands on a LaCie Little Big Disk.

I thought of something else.

First I needed to test and see if perhaps the issue was related to ultra high speed transfers. As we've already shown, the Pegasus can push as much as 1GB/s over Thunderbolt whereas none of the other bandwidth eaters come even remotely close to that. To determine if the issue was data rate invariant I wrote to the Pegasus at different speeds ranging from 480Mbps all the way up to 7.2Gbps. I tried putting SSDs in the Pegasus as well as standard mechanical hard drives. The problem remained. I got audio corruption regardless of what drives were in the Pegasus or what speed I wrote to the drives. The problem wasn't related to transfer rates.

I also took apart the Thunderbolt Display to confirm there weren't any obvious issues on the controller board (E.g. putting the Thunderbolt IC far too close to the audio controller). Nothing obvious there either.

While I was doing all of this, Apple put forth a Thunderbolt firmware update the other day, however it didn't seem to address the issue either. So I went back to my testing.

Since the problem appeared regardless of how fast (or slow) I was transferring and all I needed was another Thunderbolt storage device to vindicate either the Pegasus or the Thunderbolt Display I turned to the trusty MacBook Air.

As I mentioned in our original Pegasus review, if you have two Thunderbolt equipped Macs and a Thunderbolt cable you can actually put one of the machines in target disk mode and access its drives via Thunderbolt on the remaining Mac. You don't get super high performance but you can get around 500Mbps. Since I had reproduced the audio corruption issue at an even slower data rate I decided to give this a try.

I booted the MacBook Air in target disk mode by holding down the 't' key after turning on the machine. My MacBook Pro was connected to the Apple Thunderbolt Display and a Thunderbolt cable connected the display to the MacBook Air. This was the same setup as the Pegasus, but with the MBA in place of the Pegasus.

I wrote to the MBA just like I did the Pegasus (from a file server connected over the Thunderbolt Display's GigE, transfer rates were capped at around 500Mbps from the file server). After a couple hundred gigabytes were transferred without any audio corruption I swapped out the MBA and connected the Pegasus. I copied the same files at the same rate from the same source. After no more than 7GBs were written to the Pegasus the audio stream started to corrupt.

Based on my testing I can only conclude that the Pegasus seems to be at fault here, not the Thunderbolt Display. Given that the Pegasus was introduced prior to Apple's Thunderbolt Display it's not all that surprising that this issue made it through to production. It's unclear what the root cause is but it's hopefully something Promise can address either through firmware or a driver revision.

Update: I'm still verifying that this is indeed a "fix" but it looks like if you use a USB sound card plugged into a USB hub which is then plugged into the Thunderbolt Display then the sound corruption doesn't happen. This seems to point at noisy power as being the cause with the USB hub acting as a crude filter. It's still not ideal but this may be a workaround for Pegasus users until Promise supplies a fix.

Windows/Boot Camp Experience Dissection
Comments Locked

275 Comments

View All Comments

  • danjw - Friday, September 23, 2011 - link

    I really thought the computer industry was done with the whole daisy chain idea. Requiring every device to have two connectors just adds to cost. Requiring licensing from Intel for the icon and Intel being the only controller manufacturer, will further drag it down. I think it will be just about as successful as firewire, limited success with Apple customers, but not much else. Sure, you may see the ports on PCs, but there will be a much larger selection of peripherals that support USB 3.0.
  • touringsedan - Friday, September 23, 2011 - link

    Listened to your audio clip that was corrupted during your file transfer.

    Wanted to comment that I have a 1st gen 27" and it does the same thing to me and usually I have to recycle the power to the display and all is returned to normal.

    It seems to occur almost never now for some reason, but was about to return it and it eventually tapered off.

    I do have the keyboard and an external USB drobo attached to my display.
  • AmishElvis - Friday, September 23, 2011 - link

    It seems like the next logical step would be to include the video card inside the monitor, then let the computer use it via the pci-e lanes.
  • jecs - Friday, September 23, 2011 - link

    I will love that. Even an upgradable option.
  • Dug - Friday, September 23, 2011 - link

    FANTASTIC IDEA!!!!!!
  • Constructor - Friday, September 23, 2011 - link

    10Gb/s is a lot for an external port, but graphics cards can need even more bandwidth under heavy load, so even Thunderbolt would still be a bottleneck, particularly for the bigger cards.

    Nevertheless, more than one manufacturer has already announced external PCIe enclosures for Thunderbolt, so you'll be able to plug any graphics card into that and as long as there's a TB-compatible driver for it it will work as desired.

    Putting the GPU into the display is nice for the few months as long as the GPU is still up to date, but it will become a drag on the monitor when the GPU is overtaken by newer models. The separate box may be the more flexible option there.
  • Iketh - Friday, September 23, 2011 - link

    why can't the monitor have a removable backplate?
  • Constructor - Friday, September 23, 2011 - link

    It does, sort of. You just need suction cups and a set of Torx screwdrivers getting there...! B-)

    But seriously: What for, exactly?
  • jecs - Saturday, September 24, 2011 - link

    Ok. But isn't this the first Thunderbolt implementation? Intel promised a lot more bandwidth. An external box could be an option but obviously not as great as inside the display.
  • Constructor - Saturday, September 24, 2011 - link

    Right now it's 10+10Gb/s and that will remain the limit for some time.

    And I still wouldn't want a quickly outdated GPU in the display which could have a much longer usable lifespan, but that's of course a matter of preference. We'll see what will become available.

Log in

Don't have an account? Sign up now