Increased Dynamic Range: Understanding the Power Profile of Modern SoCs

Section by Anand Shimpi

The iPhone 4S greatly complicated the matter of smartphone power consumption. With the A5 SoC Apple introduced a much wider dynamic range of power consumption to the iPhone than we were previously used to. Depending on the workload, the A5 SoC could either use much more power than its predecessor or enjoy decreased overall energy usage. I began our battery life analysis last time with some graphs showing the power savings realized by a more power hungry, faster CPU.

The iPhone 5 doesn't simplify things any more. I believe the days of us having straightforward discussions about better/worse battery life are long gone. We are now firmly in the era of expanded dynamic range when it comes to smartphone power consumption. What do I mean by that? The best way to explain is to look at some data. The graphs below show total device power consumption over time for a handful of devices running the Mozilla Kraken javascript benchmark. Kraken is multithreaded and hits the CPU cores fairly well. The power profile of the benchmark ends up being very similar to loading a very js-heavy web page, although for a longer period of time. All of the device displays were calibrated to 200 nits, although obviously larger displays can consume more power.

Let's start out by just looking at the three most recent iPhone generations:

The timescale for this chart is just how long the iPhone 4 takes to complete the Kraken benchmark. The iPhone 4/4S performance gap feels a lot bigger now going back to the 4 than it did when the 4S launched, but that's how it usually seems to work. Note how tight the swings are between min and max power consumption on the iPhone 4 during the test. As a standalone device you might view the iPhone 4 as being fairly variable when it comes to power consumption but compared to the 4S and 5 it might as well be a straight line.

The 4S complicated things by consuming tangibly more power under load than the 4, but being fast enough to complete tasks in appreciably less time. In the case of this Kraken run, the 4S consumes more power than the 4, however it's able to go to sleep quicker than the 4 and thus draw less power. If we extended the timeline for the iPhone 4 significantly beyond the end of its benchmark run we'd see the 4S eventually come out ahead in battery life as it was able to race to sleep quicker. The reality is that with more performance comes increased device usage - in other words, it's highly unlikely that with a 50% gain in performance users are simply going to continue to use their smartphone the same way as they would a slower device. Usage (and thus workload) doesn't remain constant, it's somewhat related to response time.

The iPhone 5 brings new meaning to device level power consumption. With a larger display and much more powerful CPU, it can easily draw 33% more power than the 4S under load, on average. Note the big swings in power consumption during the test. The A6 SoC appears to be more aggressive in transitioning down to idle states than any previous Apple SoC, which makes sense given how much higher its peak power consumption can be. Looking at total energy consumed however, the iPhone 5 clearly has the ability to be more power efficient on battery. The 5 drops down to iPhone 4 levels of idle power consumption in roughly half the time of the iPhone 4S. Given the same workload that doesn't run indefinitely (or nearly indefinitely), the iPhone 5 will outlast the iPhone 4S on a single charge. Keep the device pegged however and it will die quicker.

Out of curiosity I wanted to toss in a couple of other devices based on NVIDIA and Qualcomm silicon to see how things change. I grabbed both versions of the HTC One X:

The Tegra 3 based One X actually performs very well in this test, but its peak power consumption is significantly worse than everything else. It makes sense given the many ARM Cortex A9 cores built on a 40nm G process running at high clock speeds on the Tegra 3.

The 28nm Snapdragon S4 (dual-core Krait) based One X gives us some very interesting results. Peak power consumption looks identical to the iPhone 5, however Apple is able to go into deeper sleep states than HTC can with its S4 platform. Performance is a little worse here but that could be a combination of SoC and software/browser. I used Chrome for all of the tests so it should be putting Android's best foot forward, but the latest update to Safari in iOS 6 really did boost javascript performance to almost untouchable levels.

At the end of the day, the power profile of the iPhone 5 appears to be very close to that of a modern Snapdragon S4 based Android smartphone. Any battery life gains that Apple sees are strictly as a result of software optimizations that lead to better performance or the ability to push aggressively to lower idle power states (or both). It shouldn't be very surprising that these sound like a lot of the same advantages Apple has when talking about Mac battery life as well. Don't let the CPU cores go to sleep and Apple behaves similarly to other device vendors, but it's really in idle time or periods of lighter usage that Apple is able to make up a lot of ground.

There's one member of the modern mobile SoC market that we haven't looked at thus far: Intel's Medfield. The data below isn't directly comparable to the data above, my measurement methods were a little different but the idea is similar - we're looking at device level power consumption over time while Kraken runs. Here I'm only focusing on the latest and greatest, the Atom based Motorola RAZR i, the Snapdragon S4 based Droid RAZR M and the iPhone 5. The RAZR i/M are nearly identical devices making this the perfect power profile comparison of Atom vs. Snapdragon S4. The RAZR i is also the first Atom Z2460 based part to turbo up to 2.0GHz.

Very interesting. Atom is the only CPU that can complete the Kraken benchmark in less time than Apple's Swift. Peak power consumption is definitely higher than both the Qualcomm and Apple devices, although Intel's philosophy is likely that the added power usage is worth it given the quicker transition to idle. Note that Atom is able to drive to a slightly lower idle level than the Snapdragon S4, although the Swift based iPhone 5 can still go lower.

At least based on this data, it looks like Intel is the closest to offering a real competitor to Apple's own platform from a power efficiency standpoint. We're a couple quarters away from seeing the next generation of mobile SoCs so anything can happen next round, but I can't stress enough that the x86 power myth has been busted at this point.

I will add that despite Intel's performance advantage here, I'm not sure it justifies the additional peak power consumption. The RAZR i ends up being faster than the iPhone 5 but it draws substantially more power in doing so, and the time savings may not necessarily offset that. We'll see what happens when we get to our battery life tests.

 

GPU Analysis/Performance Battery Life
Comments Locked

276 Comments

View All Comments

  • OldAndBusted - Wednesday, October 24, 2012 - link

    "I'm not an apple product owner, and never plan to be"

    That's actually kind of sad. That no matter what the product, you can't even consider it if it comes from Apple.
  • SolidusOne - Saturday, October 20, 2012 - link

    How can you write page after page about geeky nuances, many of which cannot be discerned without lab equipment, and not utter a single word about the device's music player quality? This model particularly, as other reviews have said it was inferior to 4s in audio quality. ??????
  • phillyry - Sunday, October 21, 2012 - link

    Sorry but are you serious or trolling?

    Google search reveals nothing about this.

    If you're serious then Engadget has an article for you that compares the sound quality of iPhone 5, GS3, One X, etc. with basically no appreciable difference. http://www.engadget.com/2012/10/02/iphone-vs-rival...
  • mshdk - Sunday, October 21, 2012 - link

    What is the name of the IM app shown in the review?
  • mohit2805 - Sunday, October 21, 2012 - link

    Why Apple never goes for an inbuilt radio? why just its own ipod, when there are so many radio stations to listen to for free?
  • Krysto - Tuesday, October 23, 2012 - link

    The new Chromebook, which has a dual core 1.7 Ghz Cortex A15 CPU, reaches 668 points in Sunspider. That's compared to the 900+ for Apple's A6.
  • darkcrayon - Wednesday, January 2, 2013 - link

    Comparing a chip in a laptop to one in a smartphone.. A laptop with terrible battery life (for an ARM device) at a that. Nice work. Let us know when Apple puts an Ax chip inside of a small laptop and then let's compare performance.
  • eanazag - Thursday, November 1, 2012 - link

    I live in MN and have been using the maps app in iOS 6 on an iPhone 4 and iPad 3. I have encountered no issues with it. In fact it has been a little more accurate than the GPS I have and Google previously. I am guessing that in more urban areas there is a larger difference.

    I would have liked to see some more features that my GPS has, such as current speed, estimated arrival time, and remaining total miles for trip.

    If I'm going to complain, wish they would have included turn-by-turn on the 4.
  • Coffeebean20 - Saturday, November 24, 2012 - link

    Wow great review, I got my iPhone 5 free And tested it. I came up with similar results. Great review, good job :)
  • cpu_arch - Wednesday, November 28, 2012 - link

    Your block diagram of Swift is inaccurate, not because I know the block diagram of the Swift CPU, but because it fails to describe the basic out-of-order execution pipeline of any modern CPU's. Hint: instruction re-ordering is in the wrong place in your diagram.

    Your measurements of branch prediction microarchitecture performance are not useful. The key measurement is mispredict rate.

    Also modern branch prediction is a function of branch outcome of the branch in question and prior branches, not some multiply/divide mechanism which you describe in your article.

Log in

Don't have an account? Sign up now