Apple A9
Apple A9 processor
|
|
Produced | From September 9, 2015 to Present |
---|---|
Designed by | Apple Inc. |
Common manufacturer(s) | |
Max. CPU clock rate | 1.85 GHz (iPhone 6s, iPhone 6s Plus, iPhone SE)[1][2] |
Min. feature size | 16 nm (TSMC) to 14 nm (Samsung) |
Instruction set | A64, A32, T32 |
Microarchitecture | Twister[3][4] ARMv8-A-compatible |
Product code | APL0898,[5] APL1022[6] |
Cores | 2[7] |
L1 cache | Per core: 64 KB instruction + 64 KB data |
L2 cache | 3 MB shared[7] |
L3 cache | 4 MB shared[8] |
Predecessor | Apple A8 |
GPU | PowerVR Series 7XT GT7600 (six-core) [9][10] |
Application | Mobile |
Variant | Apple A9X |
The Apple A9 is a 64-bit system-on-chip (SoC), designed by Apple Inc. Manufactured for Apple by both Samsung and TSMC, it first appeared in the iPhone 6S and 6S Plus which were introduced on September 9, 2015.[11] Apple states that it has 70% more CPU performance and 90% more graphics performance compared to its predecessor, the Apple A8,[11] and is currently one of the most powerful and energy-efficient mobile chips on the market today along with the Samsung Exynos 8890 and Qualcomm Snapdragon 820.
Contents
Design
The A9 features an Apple-designed 64-bit 1.85 GHz[1] ARMv8-A dual-core[7] CPU called Twister.[4] The A9 in the iPhone 6S has 2 GB of LPDDR4 RAM included in the package.[5][7] The A9 has a per-core L1 cache of 64 KB for data and 64 KB for instructions, an L2 cache of 3 MB shared by both CPU cores, and a 4 MB L3 cache that services the entire SoC and acts as a victim cache.[8]
The A9 includes a new image processor, a feature originally introduced in the A5 and last updated in the A7, with better temporal and spatial noise reduction as well as improved local tone mapping.[12] The A9 directly integrates an embedded M9 motion coprocessor, a feature originally introduced with the A7 as a separate chip. In addition to servicing the accelerometer, gyroscope, compass, and barometer, the M9 coprocessor can recognize Siri voice commands.[12]
The A9 features a custom storage solution, which uses an Apple-designed NVMe-based controller that communicates over a PCIe connection.[13] The iPhone 6s' NAND design is more akin to a PC-class SSD than embedded flash memory common on mobile devices. This gives the phone a significant storage performance advantage over competitors which often use eMMC or UFS to connect to their flash memory.
Microarchitecture
A9 microarchitecture is similar to second generation Cyclone (used in A8 chip) microarchitecture. Some of the microarchitectural features are as following:
Pipeline depth (stages) | 16 |
---|---|
Issue width | 6 micro-ops |
ROB | 192 micro-ops |
Load latency | 4 cycles |
Branch misprediction penalty | 9 |
Number of integer pipes | 4 |
Number of shifter ALUs | 4 |
Load/Store Units | 2 |
Integer pipe buffer size | 48 |
Num of branch units | 2 |
Indirect branch units | 1 |
Branch pipe buffer size | 24 |
FP ALUs | 3 |
About half of the performance boost over A8 comes from the 1.85 GHz freq. About a quarter comes from the better memory subsystem (3x bigger caches). The remaining quarter comes from the microarchitectural tuning and smaller technology node.[citation needed]
Dual sourcing
Apple A9 chips are fabricated by two companies: Samsung and TSMC. The Samsung version is called APL0898, which is manufactured on a 14 nm FinFET process and is 96 mm2 large, while the TSMC version is called APL1022, which is manufactured on a 16 nm FinFET process and is 104.5 mm2 large.
There was intended to be no significant difference in performance between the parts,[14] but in October 2015, it was alleged that iPhone 6S models with Samsung-fabricated A9 chips had slightly lower battery life than those with TSMC-fabricated versions.[15] Apple responded that "tests which run the processors with a continuous heavy workload until the battery depletes are not representative of real-world usage", and said that internal testing combined with customer data demonstrated a variance of only 2-3%.[16][17]
Naming
While the Twister CPU core implements the ARMv8-A architecture licensed from ARM Holdings, it is an independent CPU design and is unrelated to the much older but similarly named Cortex-A9 and ARM9 CPU that are designed by ARM themselves and implement the 32-bit ARMv7-A and ARMv5E versions of the architecture.
Gallery
The processors are nearly identical visually. The packaging have the same dimensions (approx 15.0×14.5 mm) and only superficial differences, like the designation text. Inside the packaging the silicon die differs in size.
Products that include the Apple A9
See also
- Apple mobile application processors, the range of ARM-based mobile processors designed by Apple for their consumer electronic devices.
- Apple A9X
References
<templatestyles src="Reflist/styles.css" />
Cite error: Invalid <references>
tag; parameter "group" is allowed only.
<references />
, or <references group="..." />
- ↑ 1.0 1.1 Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.
- ↑ 4.0 4.1 Lua error in package.lua at line 80: module 'strict' not found.
- ↑ 5.0 5.1 Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.
- ↑ 7.0 7.1 7.2 7.3 Lua error in package.lua at line 80: module 'strict' not found.
- ↑ 8.0 8.1 Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.
- ↑ 11.0 11.1 Lua error in package.lua at line 80: module 'strict' not found.
- ↑ 12.0 12.1 Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.
- ↑ Lua error in package.lua at line 80: module 'strict' not found.