

# Intel® Xeon Phi<sup>™</sup> Processor "Knights Landing" Architectural Overview

Avinash Sodani, Senior Principal Engineer, Intel Corporation Chief Architect, Knights Landing Processor



# Next Intel<sup>®</sup> Xeon Phi<sup>™</sup> Processor: Knights Landing

First **self-boot** Xeon Phi<sup>™</sup> processor that is **binary compatible** with main line IA

Excellent scalar and vector performance

Integration of **Memory on package**: innovative memory architecture for high bandwidth and high capacity

Integration of Fabric on package

| Three products |                         |             |  |
|----------------|-------------------------|-------------|--|
| KNL Self-Boot  | KNL Self-Boot w/ Fabric | KNL Card    |  |
| (Baseline)     | (Fabric Integrated)     | (PCIe-Card) |  |



Potential future options subject to change without notice. Codenames.

All timeframes, features, products and dates are preliminary forecasts and subject to change without further notification.

(intel)

# **Knights Landing Overview**





Stand-alone, Self-boot CPU Up to 72 new Silvermont-based cores 4 Threads per core. 2 AVX 512 vector units Binary Compatible<sup>1</sup> with Intel<sup>®</sup> Xeon<sup>®</sup> processor 2-dimensional Mesh on-die interconnect MCDRAM: On-Package memory: 400+ GB/s of BW<sup>2</sup> DDR memory Intel<sup>®</sup> Omni-path Fabric 3+ TFLops (DP) peak per package

intel

~3x ST performance over KNC

Source Intel: All products, computer systems, dates and figures specified are preliminary based on current expectations, and are subject to change without notice. KNL data are preliminary based on current expectations and are subject to change without notice. IBinary Compatible with Intel Xeon processors using Haswell Instruction Set (except TSX). <sup>2</sup>Bandwidth numbers are based on STREAM-like memory access pattern when MCDRAM used as flat memory. Results have been estimated based on internal Intel analysis and are provided for informational purposes only. Any difference in system hardware or software design or configuration may affect actual performance.

Software and workloads used in performance tests may have been optimized for performance only on Intel microprocessors. Performance tests, such as SYSmark and MobileMark, are measured using specific computer systems, components, software, operations and functions. Any change to any of those factors may cause the results to vary. You should consult other information and performance tests to assist you in fully evaluating your contemplated purchases, including the performance of that product when combined with other products. For more information go to <a href="http://www.intel.com/performance">http://www.intel.com/performance</a>



# **Knights Landing Products**



Potential future options subject to change without notice. Codenames.

All timeframes, features, products and dates are preliminary forecasts and subject to change without further notification.

(intel)

# Many Trailblazing Improvements in KNL

| Improvements                           | What/Why                                                       |
|----------------------------------------|----------------------------------------------------------------|
| Self Boot Processor                    | No PCIe bottleneck                                             |
| Binary Compatibility with Xeon         | Runs all legacy software. No recompilation.                    |
| New Core: SLM based                    | ~3x higher ST performance over KNC                             |
| Improved Vector density                | 3+ TFLOPS (DP) peak per chip                                   |
| AVX 512 ISA                            | New 512-bit Vector ISA with Masks                              |
| Scatter/Gather Engine                  | Hardware support for gather and scatter                        |
| New memory technology:<br>MCDRAM + DDR | Large High Bandwidth Memory → MCDRAM<br>Huge bulk memory → DDR |
| New on-die interconnect: Mesh          | High BW connection between cores and memory                    |

Software and workloads used in performance tests may have been optimized for performance only on Intel microprocessors. Performance tests, such as SYSmark and MobileMark, are measured using specific computer systems, components, software, operations and functions. Any change to any of those factors may cause the results to vary. You should consult other information and performance tests to assist you in fully evaluating your contemplated purchases, including the performance of that product when combined with other products. For more information go to <a href="http://www.intel.com/performance">http://www.intel.com/performance</a> tests to assist you in fully evaluating your contemplated purchases, including the performance of that product when combined with other products. For more information go to <a href="http://www.intel.com/performance">http://www.intel.com/performance</a> tests to assist you in fully evaluating your contemplated purchases, including the performance of that product when combined with other products. For more information go to <a href="http://www.intel.com/performance">http://www.intel.com/performance</a> tests assist you in fully evaluating your contemplated purchases, including the performance of that product when combined with other products. For more information go to <a href="http://www.intel.com/performance">http://www.intel.com/performance</a> performance assist you in fully evaluating your contemplated purchases, including the performance of that product when combined with other products. For more information go to <a href="http://www.intel.com/performance">http://www.intel.com/performance</a> tests assist you in fully evaluating your contemplated purchases, including the performance on your performance in system hardware or software design or configuration may affect actual performance.

inte

Copyright © 2015, Intel Corporation. All rights reserved Avinash Sodani ISC 2015 Intel® Xeon Phi ™ Workshop.

### KNL Tile: <sup>2 Cores, each with 2 VPU</sup> 1M L2 shared between two Cores



**Core**: Changed from KNC to KNL. Based on Silvermont core – with <u>many</u> changes

#### **Selected Important features of the Core**

- Out of order 2-wide core: 72 inflight uops. 4 threads/core
- Back to back fetch and issue per thread
- 32KB Icache, 32KB Dcache. 2x 64B Loads ports in Dcache. Larger TLBs than in SLM
- L1 Prefetcher (IPP) and L2 Prefetcher. 46/48 PA/VA bits to match Xeon
- Fast unaligned and cache-line split support. Fast Gather/Scatter support
- 2x BW between Dcache and L2 than in SLM: 1 line Rd and ½ line Wr per cycle

### 2 VPUs: 2x 512b Vectors. 32SP and 16DP. X87, SSE and EMU support



# Intel<sup>®</sup> AVX Technology



| AVX                | AVX2               |
|--------------------|--------------------|
| 256-bit basic FP   | Float16 (IVB 2012) |
| 16 registers       | 256-bit FP FMA     |
| NDS (and AVX128)   | 256-bit integer    |
| Improved blend     | PERMD              |
| MASKMOV            | Gather             |
| Implicit unaligned |                    |

**HSW** 

#### AVX-512

512-bit FP/Integer 32 registers 8 mask registers Embedded rounding Embedded broadcast Scalar/SSE/AVX "promotions" HPC additions Gather/Scatter





**SNB** 



**Binary compatible with Intel® Xeon® Processor:** Prior Intel® Xeon® processor binaries will run on KNL without recompilation

• KNC Code will need recompilation to run on KNL

**Yes:** x87, MMX, SSE, AVX1 and AVX2. And all other legacy instructions **Yes:** BMI instructions

No: TSX instructions. In HSX, under separate CPUID bit

#### **KNL Adds:**

- AVX512: 512b vector extensions with mask support.
- AVX512PFI: New Prefetch Instructions
- AVX512ERI: New Exponential and Reciprocal Instructions
- AVX512CDI: Conflict Detection Instructions: To enable more vectorizing

# **Beyond AVX-512 Foundation**

• Intel AVX-512 Prefetch Instructions (PFI)

 Intel AVX-512 Exponential and Reciprocal Instructions (ERI)

 Intel AVX-512 Conflict Detection Instructions (CDI)

| CPUID    | Instructions           | Description                                                                                                  |
|----------|------------------------|--------------------------------------------------------------------------------------------------------------|
| AVX512PF | PREFETCHWT1            | Prefetch cache line into the L2 cache with intent to write                                                   |
|          | VGATHERPF{D,Q}{0,1}PS  | Prefetch vector of D/Qword indexes into the L1/L2 cache                                                      |
|          | VSCATTERPF{D,Q}{0,1}PS | Prefetch vector of D/Qword indexes into the L1/L2 cache with intent to write                                 |
| AVX512ER | VEXP2{PS,PD}           | Computes approximation of 2 <sup>x</sup> with maximum relative error of 2 <sup>-23</sup>                     |
|          | VRCP28{PS,PD}          | Computes approximation of reciprocal with max relative error of 2 <sup>-28</sup> before rounding             |
|          | VRSQRT28{PS,PD}        | Computes approximation of reciprocal square root with max relative error of 2 <sup>-28</sup> before rounding |
| AVX512CD | VPCONFLICT{D,Q}        | Detect duplicate values within a vector and create conflict-free subsets                                     |
|          | VPLZCNT{D,Q}           | Count the number of leading zero bits in each element                                                        |
|          | VPBROADCASTM{B2Q,W2D}  | Broadcast vector mask into vector elements                                                                   |



## **3 Memory Modes**

- Mode selected at boot
- MCDRAM-Cache covers all DDR



### Cache Model



Hybrid Model







MCDRAM latency more than DDR at low loads but much less at high loads

(intel)

### Flat MCDRAM: SW Architecture

### MCDRAM exposed as a separate NUMA node





Memory allocated in DDR by default

Keeps low bandwidth data out of MCDRAM.

Apps explicitly allocate important data in MCDRAM

- "Fast Malloc" functions: Built using NUMA allocations functions
- "Fast Memory" Compiler Annotation: For use in Fortran.

## Flat MCDRAM using existing NUMA support in Legacy OS



### Flat MCDRAM SW Usage: Code Snippets

#### Allocate 1000 floats from DDR

float \*fv;

```
fv = (float *)malloc(sizeof(float) * 1000);
```

#### Allocate 1000 floats from MCDRAM

float \*fv;

fv = (float \*)hbw malloc(sizeof(float) \* 1000);

#### Allocate arrays from MCDRAM & DDR in Intel FORTRAN

```
c Declare arrays to be dynamic
REAL, ALLOCATABLE :: A(:), B(:), C(:)

!DEC$ ATTRIBUTES, FASTMEM :: A

NSIZE=1024

c allocate array 'A' from MCDRAM

c ALLOCATE (A(1:NSIZE))

c Allocate arrays that will come from DDR

c ALLOCATE (B(NSIZE), C(NSIZE))
```

### **Keeping the App Effort Level Low**

## High Bandwidth (HBW) Malloc API



#### Publicly released at https://github.com/memkind



### **Growth Trends**

Core and Thread Count
Dual precision (DP) Flops
Power efficiency
Memory Bandwidth
Transistor Scaling



### **Multi-Core**

Optimized for Serial and Parallel Apps



### **Many-Core**

Optimized for Highly Parallel and Highly Vectorized Apps



## **High Performance Processor Trend**

- Many IA Cores
- Lots of IA Threads
- Lots of Wide Vectors
- Coherent Cache Hierarchy
- Large On-PKG high-bandwidth Memory in addition to DDR
- On-PKG Fabric

Standalone general purpose CPU



Threads

(intel)

Potential future options subject to change without notice. All timeframes, features, products and dates are preliminary forecasts and subject to change without further notification

## **Benefits of General Purpose Programming**

#### Familiar SW tools

New languages/models are not required

### Familiar programming model

– MPI, OpenMP\*, ...

#### Maintain a single code base

 Same SW can runs on multi-core and many-core CPUs

#### **Common Code optimizations**

 Optimizations for many core CPUs improve performance for multi-core ones as well





Avinash Sodani ISC 2015 Intel® Xeon Phi™ WorkShop \*Other brands and names are the property of their respective owners

## Summary

- Knights Landing (KNL) is the first self-boot Intel® Xeon Phi<sup>™</sup> processor
- Many improvements for performance and programmability
  - Significant leap in scalar and vector performance
  - Significant increase in memory bandwidth and capacity
  - Binary compatible with Intel<sup>®</sup> Xeon<sup>®</sup> processor
- Common programming models between Intel<sup>®</sup> Xeon<sup>®</sup> processor and Intel<sup>®</sup> Xeon Phi<sup>™</sup> processor
- KNL offers immense amount of parallelism (both data and thread)
  - Future trend is further increase in parallelism for both Intel<sup>®</sup> Xeon<sup>®</sup> processor and Intel<sup>®</sup> Xeon Phi<sup>™</sup> processor
  - Developers need to prepare software to extract full benefits from this trend

Software and workloads used in performance tests may have been optimized for performance only on Intel microprocessors. Performance tests, such as SYSmark and MobileMark, are measured using specific computer systems, components, software, operations and functions. Any change to any of those factors may cause the results to vary. You should consult other information and performance tests to assist you in fully evaluating your contemplated purchases, including the performance of that product when combined with other products. For more information go to <a href="http://www.intel.com/performance">http://www.intel.com/performance</a>







Copyright © 2015, Intel Corporation. All rights reserved Avinash Sodani ISC 2015 Intel® Xeon Phi 🖱 Workshop.

## Legal Disclaimer

INFORMATION IN THIS DOCUMENT IS PROVIDED IN CONNECTION WITH INTEL PRODUCTS. NO LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE, TO ANY INTELLECTUAL PROPERTY RIGHTS IS GRANTED BY THIS DOCUMENT. EXCEPT AS PROVIDED IN INTEL'S TERMS AND CONDITIONS OF SALE FOR SUCH PRODUCTS, INTEL ASSUMES NO LIABILITY WHATSOEVER AND INTEL DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY, RELATING TO SALE AND/OR USE OF INTEL PRODUCTS INCLUDING LIABILITY OR WARRANTIES RELATING TO FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT.

A "Mission Critical Application" is any application in which failure of the Intel Product could result, directly or indirectly, in personal injury or death. SHOULD YOU PURCHASE OR USE INTEL'S PRODUCTS FOR ANY SUCH MISSION CRITICAL APPLICATION, YOU SHALL INDEMNIFY AND HOLD INTEL AND ITS SUBSIDIARIES, SUBCONTRACTORS AND AFFILIATES, AND THE DIRECTORS, OFFICERS, AND EMPLOYEES OF EACH, HARMLESS AGAINST ALL CLAIMS COSTS, DAMAGES, AND EXPENSES AND REASONABLE ATTORNEYS' FEES ARISING OUT OF, DIRECTLY OR INDIRECTLY, ANY CLAIM OF PRODUCT LIABILITY, PERSONAL INJURY, OR DEATH ARISING IN ANY WAY OUT OF SUCH MISSION CRITICAL APPLICATION, WHETHER OR NOT INTEL OR ITS SUBCONTRACTOR WAS NEGLIGENT IN THE DESIGN, MANUFACTURE, OR WARNING OF THE INTEL PRODUCT OR ANY OF ITS PARTS.

Intel may make changes to specifications and product descriptions at any time, without notice. Designers must not rely on the absence or characteristics of any features or instructions marked "reserved" or "undefined". Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them. The information here is subject to change without notice. Do not finalize a design with this information.

The products described in this document may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request.

Contact your local Intel sales office or your distributor to obtain the latest specifications and before placing your product order.

Copies of documents which have an order number and are referenced in this document, or other Intel literature, may be obtained by calling 1-800-548-4725, or go to: <u>http://www.intel.com/design/literature.htm</u>

Knights Landing and Knights Corner and other code names featured are used internally within Intel to identify products that are in development and not yet publicly announced for release. Customers, licensees and other third parties are not authorized by Intel to use code names in advertising, promotion or marketing of any product or services and any such use of Intel's internal code names is at the sole risk of the user.

Intel®, Xeon®, Intel® Xeon Phi<sup>™</sup>, Intel® Omni-Path and the Intel logo are trademarks of Intel Corporation in the United States and other countries.

\*Other names and brands may be claimed as the property of others. Copyright ©2015 Intel Corporation.

# Legal Disclaimer

- Processor Numbering Notice: Intel processor numbers are not a measure of performance. Processor numbers differentiate features within each processor family, not across different processor families: Go to: <u>Learn About Intel® Processor Numbers</u>
- Roadmap Notice: All products, computer systems, dates and figures specified are preliminary based on current expectations, and are subject to change without notice.
- Intel<sup>®</sup> Active Management Technology (Intel<sup>®</sup> AMT) requires activation and a system with a corporate network connection, an Intel<sup>®</sup> AMT-enabled chipset, network hardware and software. For notebooks, Intel AMT may be unavailable or limited over a host OS-based VPN, when connecting wirelessly, on battery power, sleeping, hibernating or powered off. Results dependent upon hardware, setup and configuration. For more information, visit Intel<sup>®</sup> Active Management Technology.
- Intel® Advanced Vector Extensions (Intel® AVX/ Intel®AVX2): Intel® AVX/AVX2/AVX512 is designed to achieve higher throughput in certain integer and floating point operations. Depending on processor power and thermal characteristics, and system power and thermal conditions, AVX/AVX2/AVX512 floating point instructions may run at lower frequency to maintain reliable operations at all times. For further details see product data sheet.
- Built-In Security Claims: No computer system can provide absolute security. Requires an enabled Intel<sup>®</sup> processor, enabled chipset, firmware and/or software optimized to use the technologies. Consult your system manufacturer and/or software vendor for more information.
- Built-in Visuals (BIV): Built-in visual features are not enabled on all PCs and optimized software may be required. Check with y our system manufacturer. Learn more at <a href="http://www.intel.com/go/biv">http://www.intel.com/go/biv</a>.
- Intel® Data Protection Technology (includes the following features: Secure Key and Advanced Encryption Standard New Instructions (Intel® AES-NI)): No computer system can provide absolute security. Requires an enabled Intel® processor and software optimized for use of the technology. Consult your system manufacturer and/or software vendor for more information.
- Enhanced Intel SpeedStep<sup>®</sup> Technology See the Processor Spec Finder at <a href="http://ark.intel.com">http://ark.intel.com</a> or contact your Intel representative for more information.



### **Risk Factors**

The above statements and any others in this document that refer to plans and expectations for the second guarter, the year and the future are forward-looking statements that involve a number of risks and uncertainties. Words such as "anticipates," "expects," "intends," "plans," "believes," "seeks," "estimates," "will," "should" and their variations identify forward-looking statements. Statements that refer to or are based on projections, uncertain events or assumptions also identify forward-looking statements. Many factors could affect Intel's actual results, and variances from Intel's current expectations regarding such factors could cause actual results to differ materially from those expressed in these forward-looking statements. Intel presently considers the following to be important factors that could cause actual results to differ materially from the company's expectations. Demand for Intel's products is highly variable and, in recent years, Intel has experienced declining orders in the traditional PC market segment. Demand could be different from Intel's expectations due to factors including changes in business and economic conditions; consumer confidence or income levels; customer acceptance of Intel's and competitors' products; competitive and pricing pressures, including actions taken by competitors; supply constraints and other disruptions affecting customers; changes in customer order patterns including order cancellations; and changes in the level of inventory at customers. Intel operates in highly competitive industries and its operations have high costs that are either fixed or difficult to reduce in the short term. Intel's gross margin percentage could vary significantly from expectations based on capacity utilization; variations in inventory valuation, including variations related to the timing of gualifying products for sale; changes in revenue levels; segment product mix; the timing and execution of the manufacturing ramp and associated costs; excess or obsolete inventory; changes in unit costs; defects or disruptions in the supply of materials or resources; and product manufacturing quality/yields. Variations in gross margin may also be caused by the timing of Intel product introductions and related expenses, including marketing expenses, and Intel's ability to respond guickly to technological developments and to introduce new products or incorporate new features into existing products, which may result in restructuring and asset impairment charges. Intel's results could be affected by adverse economic, social, political and physical/infrastructure conditions in countries where Intel, its customers or its suppliers operate, including military conflict and other security risks, natural disasters, infrastructure disruptions, health concerns and fluctuations in currency exchange rates. Intel's results could be affected by the timing of closing of acquisitions, divestitures and other significant transactions. Intel's results could be affected by adverse effects associated with product defects and errata (deviations from published specifications), and by litigation or regulatory matters involving intellectual property, stockholder, consumer, antitrust, disclosure and other issues, such as the litigation and regulatory matters described in Intel's SEC filings. An unfavorable ruling could include monetary damages or an injunction prohibiting Intel from manufacturing or selling one or more products, precluding particular business practices, impacting Intel's ability to design its products, or requiring other remedies such as compulsory licensing of intellectual property. A detailed discussion of these and other factors that could affect Intel's results is included in Intel's SEC filings, including the company's most recent reports on Form 10-Q, Form 10-K and earnings release.

Rev. 4/15/14