|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 276156 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
Mirroring most cleanup changed from compiler-rt/lib/builtins/cpu_model.
x86 methods are still returning a bool.
Reviewers: llvm-commits, echristo, craig.topper, sanjoy
Subscribers: mehdi_amini
Differential Revision: https://reviews.llvm.org/D22480
llvm-svn: 276149 | 
| | 
| 
| 
| | llvm-svn: 275017 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | [cpu-detection] [amdfam10] Return barcelona, and amdfam10 for all other
subtypes. Address Bug 28067.
Along with the refactoring of Host.cpp, getHostCPUName() was modified to
return more precise types for CPUs in amdfam10.
However, callers of getHostCPUName() do string matching on type, so this
cannot be modified.
Currently there is support in the x86 backend for barcelona.
For all other subtypes the assumed return value is amdfam10.
Fix: getHostCPUName() returns barcelona subtype and amdfam10 for all
others. This can be extended further when support for the other subtypes
is added.
Differential revision: http://reviews.llvm.org/D21193
llvm-svn: 272333 | 
| | 
| 
| 
| | llvm-svn: 272332 | 
| | 
| 
| 
| | llvm-svn: 272329 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary: Remove architecture subtype from the string returned by getHostCPUName(). String matching done on type.
Reviewers: llvm-commits, echristo
Subscribers: mehdi_amini
Differential Revision: http://reviews.llvm.org/D21193
llvm-svn: 272328 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
Break on all switch cases for outer and inner switches.
No functionality changed.
Reviewers: llvm-commits, sanjoy
Differential Revision: http://reviews.llvm.org/D21158
llvm-svn: 272228 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
Following D20970 (committed as r271726).
This is a substantial refactoring of the host CPU detection code.
There is no functionality change intended, but the changes are extensive.
Definitions of architecture types and subtypes are by no means exhaustive or
perfectly defined, but a fair starting point.
Suggestions for futher improvements are welcome.
Reviewers: llvm-commits
Differential Revision: http://reviews.llvm.org/D20988
llvm-svn: 271921 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
    Follow-up to D20926 (committed as r271595, r271596).
    This patch is in preparation for a substantial refactoring of the code.
    No functionality changed.
Differential Revision: http://reviews.llvm.org/D20970
llvm-svn: 271726 | 
| | 
| 
| 
| | llvm-svn: 271598 | 
| | 
| 
| 
| | llvm-svn: 271596 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | code. To make the diffs easier to read, clang-format everything first.
No functionality changed.
Patch by Alina Sbirlea!
http://reviews.llvm.org/D20926
llvm-svn: 271595 | 
| | 
| 
| 
| | llvm-svn: 269915 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
MONITORX/MWAITX instructions provide similar capability to the MONITOR/MWAIT
pair while adding a timer function, such that another termination of the MWAITX
instruction occurs when the timer expires. The presence of the MONITORX and
MWAITX instructions is indicated by CPUID 8000_0001, ECX, bit 29.
The MONITORX and MWAITX instructions are intercepted by the same bits that
intercept MONITOR and MWAIT. MONITORX instruction establishes a range to be
monitored. MWAITX instruction causes the processor to stop instruction execution
and enter an implementation-dependent optimized state until occurrence of a
class of events.
Opcode of MONITORX instruction is "0F 01 FA". Opcode of MWAITX instruction is
"0F 01 FB". These opcode information is used in adding tests for the
disassembler.
These instructions are enabled for AMD's bdver4 architecture.
Patch by Ganesh Gopalasubramanian!
Reviewers: echristo, craig.topper, RKSimon
Subscribers: RKSimon, joker.eph, llvm-commits
Differential Revision: http://reviews.llvm.org/D19795
llvm-svn: 269911 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This patch corresponds to review:
http://reviews.llvm.org/D19683
Simply adds the bits for being able to specify -mcpu=pwr9 to the back end.
llvm-svn: 268950 | 
| | 
| 
| 
| 
| 
| | airmont and knl.
llvm-svn: 267670 | 
| | 
| 
| 
| 
| 
| | its easier to compare with Intel's docs. NFC
llvm-svn: 267669 | 
| | 
| 
| 
| | llvm-svn: 267666 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | files; other minor fixes."
This reverts commit r265454 since it broke the build.  E.g.:
  http://lab.llvm.org:8080/green/job/clang-stage1-cmake-RA-incremental_build/22413/
llvm-svn: 265459 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | other minor fixes.
Some Include What You Use suggestions were used too.
Use anonymous namespaces in source files.
Differential revision: http://reviews.llvm.org/D18778
llvm-svn: 265454 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
 - Rename `"skylake"` == SkylakeServerProc to `"skylake-avx512"`
 - Change `"skylake"` to denote SkylakeClientProc
 - Fix the detection of cpu family 6 and model 94 to be
   SkylakeClientProc instead of SkylakeServerProc
 - Remove the `"cnl"` for CannonLake
Reviewers: craig.topper, delena
Subscribers: zansari, echristo, qcolombet, RKSimon, spatel, DavidKreitzer, mcrosier, llvm-commits
Differential Revision: http://reviews.llvm.org/D17090
llvm-svn: 261482 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Changes in X86.td:
I set features of Intel processors in incremental form: IVB = SNB + X HSW = IVB + X ..
I added Skylake client processor and defined it's features
FeatureADX was missing on KNL
Added some new features to appropriate processors SMAP, IFMA, PREFETCHWT1, VMFUNC and others
Differential Revision: http://reviews.llvm.org/D16357
llvm-svn: 258659 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Fixing wrong typo (avx515) → (avx512) 
Review over the shoulder by asaf . 
Differential Revision: http://reviews.llvm.org/D16190
llvm-svn: 258041 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | The feature flag is for VPERMB,VPERMI2B,VPERMT2B and VPMULTISHIFTQB instructions. 
More about the instruction can be found in:
hattps://software.intel.com/sites/default/files/managed/07/b7/319433-023.pdf
Differential Revision: http://reviews.llvm.org/D16190
llvm-svn: 258012 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | the feature flag is essential for RDPKRU and WRPKRU instruction 
more about the instruction can be found in the SDM rev 56, vol 2 from http://www.intel.com/sdm
Differential Revision: http://reviews.llvm.org/D15491
llvm-svn: 255644 | 
| | 
| 
| 
| 
| 
| | enabled them and the saving of YMM state. This seems to be consistent with gcc behavior.
llvm-svn: 250269 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Add intrinsics for the
  XSAVE instructions (XSAVE/XSAVE64/XRSTOR/XRSTOR64)
  XSAVEOPT instructions (XSAVEOPT/XSAVEOPT64)
  XSAVEC instructions (XSAVEC/XSAVEC64)
  XSAVES instructions (XSAVES/XSAVES64/XRSTORS/XRSTORS64)
Differential Revision: http://reviews.llvm.org/D13012
llvm-svn: 250029 | 
| | 
| 
| 
| 
| 
| 
| | splits to actually use the single character split routine which does
less work, and in a debug build is *substantially* faster.
llvm-svn: 247245 | 
| | 
| 
| 
| | llvm-svn: 244385 | 
| | 
| 
| 
| | llvm-svn: 244384 | 
| | 
| 
| 
| | llvm-svn: 244352 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This patch adds support for the z13 processor type and its vector facility,
and adds MC support for all new instructions provided by that facilily.
Apart from defining the new instructions, the main changes are:
- Adding VR128, VR64 and VR32 register classes.
- Making FP64 a subclass of VR64 and FP32 a subclass of VR32.
- Adding a D(V,B) addressing mode for scatter/gather operations
- Adding 1-, 2-, and 3-bit immediate operands for some 4-bit fields.
  Until now all immediate operands have been the same width as the
  underlying field (hence the assert->return change in decode[SU]ImmOperand).
In addition, sys::getHostCPUName is extended to detect running natively
on a z13 machine.
Based on a patch by Richard Sandiford.
llvm-svn: 236520 | 
| | 
| 
| 
| 
| 
| | supports AVX. getHostCPUFeatures should be used instead to determine whether to support AVX.
llvm-svn: 233674 | 
| | 
| 
| 
| 
| 
| | flags to guess what it might be.
llvm-svn: 233671 | 
| | 
| 
| 
| 
| 
| | support saving ymm state.
llvm-svn: 233518 | 
| | 
| 
| 
| 
| 
| | etc. Split Nehalem and Westmere CPUs.
llvm-svn: 233516 | 
| | 
| 
| 
| 
| 
| | Dothan based SOC.
llvm-svn: 233515 | 
| | 
| 
| 
| 
| 
| | processor.
llvm-svn: 233514 | 
| | 
| 
| 
| | llvm-svn: 233488 | 
| | 
| 
| 
| 
| 
| | Plan to use this as part of CPU 'native' support so we can stop picking a different CPU name if CPU doesn't support AVX or AVX2.
llvm-svn: 233487 | 
| | 
| 
| 
| | llvm-svn: 232929 | 
| | 
| 
| 
| 
| 
| | march=native.
llvm-svn: 232927 | 
| | 
| 
| 
| | llvm-svn: 229415 | 
| | 
| 
| 
| 
| 
| | Sorry for the noise, I have no idea how it survived to the final version.
llvm-svn: 224414 | 
| | 
| 
| 
| | llvm-svn: 224412 | 
| | 
| 
| 
| | llvm-svn: 224410 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Having two ways to do this doesn't seem terribly helpful and
consistently using the insert version (which we already has) seems like
it'll make the code easier to understand to anyone working with standard
data structures. (I also updated many references to the Entry's
key and value to use first() and second instead of getKey{Data,Length,}
and get/setValue - for similar consistency)
Also removes the GetOrCreateValue functions so there's less surface area
to StringMap to fix/improve/change/accommodate move semantics, etc.
llvm-svn: 222319 | 
| | 
| 
| 
| | llvm-svn: 211781 | 
| | 
| 
| 
| | llvm-svn: 211334 |