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

  • snow peak - Saturday, July 21, 2012 - link

    I have similar annoying issue here, while playing songs which in iTunes on my new MBA(mid-2012) out via TB display's speaker.
    The audio data stream is routed from MBA to ThunderBolt display, and just one apple's USB keyboard connected to ThunderBolt display.

    You might be interested in trying experiment without external storage attached on TB display, and get same result with mine.

    The symptom is little static noise came with music play at beginning, and then the music gradually merged by static noise after a few of minutes or a couple of hours.

    I think it caused by hardware power ground layout issue, so no confidence apple could fix it via firmware update and no idea if I should return both my new MBA and TB display.

    This is really annoying!!
  • paulrmc - Tuesday, August 7, 2012 - link

    Hi Anand,

    I don't know whether you looked at comparing directly connected USB drives to same drives hooked up to the TB Display. I was shocked today when I found out the difference. I'm using a USB 2.0-connected LaCie 2GB drive as a secondary drive to my dual-SSD mid-2011 Mac mini Server. Using BlackMagicDesign's Disk Speed Test I came to following results:
    - directly connected to the back of the Mac mini: 29MB/sec write, 33 MB/sec read
    - connected to the TB Display: 7.5MB/sec write, 11.7MB/sec read.
    I'm running OS X Mountain Lion 10.8 on the mini, and the tests were repeatable, after fresh power down - reboot cycles.

    Any ideas? Anyone?

    Paul
  • hiscore - Tuesday, August 20, 2013 - link

    I have just discovered the source of my Thunderbolt display distorted audio issue. It is being created by my Drobo which is interfaced through iSCSI. I can replicate the issue every time when moving files to it. Granted the files are moving from my Pegasus array, so I guess there may still be some questions.

    I have been in constant contact with Apple support, Promise support, and Drobo support. Hopefully a fix will be supplied from someone.
  • highscore - Tuesday, December 23, 2014 - link

    Update:
    It wasn't the Drobo.
    I no longer run a drobo and still encounter the issue. The problem seems to occur whenever there is high I/O through Thunderbolt. I have 3 Promise RAIDs and one Lacie 8Big all on one TB bus, with the TBD on the second bus and the problem still occurs. It really just points to a USB buffer issue. The same issue that Anandtech hypothesized in this review.
  • krakago - Saturday, June 7, 2014 - link

    Unfortunately this display is now a dinosaur, and a very expensive one. As of 2014 there are finally more devices and computers appearing with Thunderbolt, but peripherals tend to be very expensive and meanwhile USB 3 has become pretty much ubiquitous. That makes this Apple display unacceptably crippled. If it were cheap that could be overlooked, but it sells for a premium price. I've been looking for a display to use with my Macbook Pro, and comparing the price and features of the Apple offering to their competitors I can't see a good reason to choose the Thunderbolt Display. Apple really needs to bin this thing and bring out a modern version.

Log in

Don't have an account? Sign up now