Powering iPad Pro: A12X

Section by Andrei Frumusanu

Apple’s new A12X SoC continues the tradition of representing an up-scaled version of the newest generation phone SoCs, in this case the A12. We’ve covered the A12 extensively in our review of the iPhone XS and XS Max, including more extensive coverage of the microarchitectural characteristics of Apple’s newest generation Vortex and Tempest cores.

The A12X, microarchitecturally, looks to be largely sharing the same generation IP blocks as the A12, with the only big difference being that the number of units has been increased in all major aspects of the SoC. Apple now for the first time employs a total of 8 CPU cores on the A12X, and compared to the A12, the figure was achieved by doubling the amount of the big Vortex cores from a dual-core to a quad-core setup. On the GPU side of things, we’ve seen the core count increase from 4 cores in the A12 to a 7-core setup in the A12X. Most important for GPU performance though – and a key aspect of the A-X series from Apple – is that the company has doubled the memory interface width 64-bit wide to 128-bit.

CPU Frequencies

In terms of CPU frequencies, Apple largely follows the same scaling pattern as on the A12, with the only difference being that there’s of course two more big cores at play. Here the A12X can support up to 8 total threads without having to resort to time-slicing their processing times.

Maximum Frequency vs Loaded Threads
Per-Core Maximum MHz
Apple A12 1 2 3 4 5 6 7 8
Big 1 2500 2380 2380 2380 2380 2380 - -
Big 2   2380 2380 2380 2380 2380 - -
Little 1     1587 1562 1562 1538 - -
Little 2       1562 1562 1538 - -
Little 3         1562 1538 - -
Little 4           1538 - -
Apple A12X 1 2 3 4 5 6 7 8
Big 1 2500 2380 2325 2325 2325 2325 2325 2325
Big 2   2380 2325 2325 2325 2325 2325 2325
Big 3     2325 2325 2325 2325 2325 2325
Big 4       2325 2325 2325 2325 2325
Little 1         1587 1562 1562 1538
Little 2           1562 1562 1538
Little 3             1562 1538
Little 4               1538

On a single CPU core, the A12X clocks up to an identical 2500MHz as the A12. The similarities continue with two active big cores where the peak frequency is limited to 2380MHz. Finally, when three or four Vortex cores are active, the peak frequency on the A12X is limited to 2325MHz. The small Tempest cores see an identical frequency scaling as on the A12, with one core clocking up to 1587MHz, two to three cores at 1562MHz and finally 1538MHz when all four cores are active.

Cache Hierachy

Another way of scaling performance of a SoC is not only increasing the amount of computation blocks, but also changing aspects such as the amount of cache available to the various blocks. Let’s see if the A12X differs from the A12 in this regard:

Analysing the memory latency behaviour of the A12X and comparing it to the A12, it looks like Apple hasn’t really changed the cache configuration. The L1 caches are still at 128KB – but that was something to be expected. What is more interesting, is it seems the L2 cache also has an identical size to the A12.

The A12 L2 cache was quite unique in its behaviour in that it seemingly is of 8MB of physical size on the SoC die, however there looked to be a sort of logical partitioning in a way that a single core only has access to 6MB at fast access latencies. Furthermore in the latency graph we also see the separation of the L2 cache into two banks, with the second half of the 6MB region being slightly slower for full random access patterns.

Overall there’s a bit of a conundrum here, as we can’t really reach an accurate conclusion: Has Apple maintained the L2 cache at 8MB, or do we simply not see more of it because of a continuation of this logical partitioning? While we don’t have access to a die shot of the A12X to confirm this, I still think this is simply a case of Apple maintaining 8MB of L2 and sharing it among the four Vortex cores.

One of the A12’s big improvements was the new system level cache coming in at 8MB and employing a new microarchitecture. It looks like this part of the memory cache hierarchy has also remained unchanged as we just see minor differences in the latency behaviour past 8MB (Past the L2).

SPEC2006 Performance

We’ve extensively covered the SPEC2006 performance of the A12 in our review of the iPhone XS/XS Max and analysed the microarchitectural characteristics of the new Vortex CPU as observed in the performance results of the various SPEC workloads.

We continue the same exercise on the A12X: In general we shouldn’t expect too big variations here from the iPhone results, with the only big difference between the two SoCs being the increased memory bandwidth available to the A12X.

SPECint2006 Base Estimate

In SPECin2006, the A12X’s performance is pretty much in line with the A12, with the scores being pretty much within the margin of error, although the A12X ends up a percentage point or two faster than the A12 in some benchmarks.

The big outlier here is 462.libquantum: The benchmark workload here is characterised as heavily vectorised and extremely memory bandwidth intensive. Here the 21% increase could very well be attributed to the doubled memory bandwidth available to the A12X.

SPECfp2006_(C/C++) Base Estimate

In SPECfp2006, a more significant amount of workloads are characterised by their memory and latency intensive nature. Here, the advantages of the A12X are more visible as we’re seeing an average 7% increase, ranging from 3% as the lowest increase in 444.namd up to more significant 14 and 12% increases in 433.milc and 470.lbm.

The overall SPEC2006 scores for the A12X are 45.95 in SPECint2006 and 58.78 in the C/C++ workloads of SPECfp2006 – representing 2% and 7% increases over the A12.

For the sake of comparison against the various existing mobile SoCs, here’s again a large graph overview comparison containing all relevant recent Arm microarchitectures.

Unfortunately for this review we weren’t able to probe the power and efficiency of the A12X – however I’m expecting figures not all too different to what we’ve published on the A12, meaning single-core active system power should be in the 3.6-4.3W range. Naturally this should be a bit higher on the A12X due to the doubled memory controller interfaces.

Overall, the A12X is a beast of a SoC and very much follows the performance of the A12. The CPU on the A12X seems pretty much the same as on the A12 – with slight performance increases in workloads that more heavily stress the memory subsystem, here the doubled memory bandwidth helps the A12X to rise above the A12.  

Accessories - Pencil & Folio Testing Notes & System Performance
Comments Locked

145 Comments

View All Comments

  • Spunjji - Wednesday, December 5, 2018 - link

    Honestly wondered this too. Apple don't seem to like performance segmentation at the top-end, and I'd bet that 1TB unit uses TLC flash, so extra caching in system RAM would massively help performance and longevity. Just a supposition though.
  • Socius - Wednesday, December 5, 2018 - link

    I picked up the 1TB model for the 6GB of ram. Apps/games stay in memory far longer than they do on the iPhone XS Max with 4GB of ram. Of course, that could also be related to the way iOS is designed to perform on iphones vs. ipads. But either way, the 1TB model also has a much faster disk. If you use your iPad for productivity, I would try to find a way to justify the extra expenditure. My justification was the pending release of Adobe Photoshop, as well as trying to do some of my 4K video editing strictly on the iPad.
  • Speedfriend - Tuesday, December 4, 2018 - link

    If the single core power consumption is 3.6-4.3, what would it be at most stressed multicore?
  • eastcoast_pete - Tuesday, December 4, 2018 - link

    Writing this as somebody who is not an iOS fan or Apple fanboy, this tablet is clearly the reigning king of tablets, with the pricing to match. However, a laptop replacement it is not, despite what Apple keeps saying. The one aspect that I did find disappointing is the rear camera setup; despite statement by some of Apple's head-honchos, plenty of people I know do use their tablet (usually iPads) for photography, and for the current iPad Pro prices, Apple could have thrown in the camera setup from the iPhone XS.
  • KPOM - Tuesday, December 4, 2018 - link

    I think what Apple is saying is that it does what most people need a computer to do, not that it would replace everything a notebook does. For me, it does about 90% of what I need. This plus a low-end ultralight notebook with a big screen would be all I need right now. My employer insists on giving me a quad-core notebook that weighs a bulky 3.5 lbs. I’d take a Spectre over my PC setup. On business trips, the iPad is all I need.
  • WasHopingForAnHonestReview - Wednesday, December 5, 2018 - link

    So, email. K.
  • crash86 - Tuesday, December 4, 2018 - link

    On the GPU test - it looks like there is no change in resolution between the iPAD 1112x834 and 2224x1668 settings. Instead, it looks like the rendered resolution is exactly the same, just scaled by 2X (the @2.0?). Are you sure the rendered resolution actually changed between the tests? It seems unreasonable that the average / frame would be completely unchanged.
  • Ryan Smith - Tuesday, December 4, 2018 - link

    We're sure.

    Take a good look at the photos. The Retina resolution photos are far clearer since they're not being internally rendered at 1/4 resolution.
  • tipoo - Tuesday, December 4, 2018 - link

    That's wild.

    *ask to render 4x more pixels*
    A12X: *Shrugs*
  • KateH - Wednesday, December 5, 2018 - link

    the author said the framerate appeared to be capped at 27fps (presumably for the sake of power consumption and thermals). So we don't know how fast it could render Civ at full tilt, only that it's at least 27fps at both resolutions. I assume this just means the GPU is just working less hard to hit the framerate at the lower resolution, but we don't know how much... Apple may have GPU design chops but even they can't magic their way out of resolution performance scaling limits, only obfuscate said limits ;)

Log in

Don't have an account? Sign up now