mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 03:33:20 +01:00
c702b7f668
-mcpu=# will support: . generic: the default insn set . v1: insn set version 1, the same as generic . v2: insn set version 2, version 1 + additional jmp insns . probe: the compiler will probe the underlying kernel to decide proper version of insn set. We did not not use -mcpu=native since llc/llvm will interpret -mcpu=native as the underlying hardware architecture regardless of -march value. Currently, only x86_64 supports -mcpu=probe. Other architecture will silently revert to "generic". Also added -mcpu=help to print available cpu parameters. llvm will print out the information only if there are at least one cpu and at least one feature. Add an unused dummy feature to enable the printout. Examples for usage: $ llc -march=bpf -mcpu=v1 -filetype=asm t.ll $ llc -march=bpf -mcpu=v2 -filetype=asm t.ll $ llc -march=bpf -mcpu=generic -filetype=asm t.ll $ llc -march=bpf -mcpu=probe -filetype=asm t.ll $ llc -march=bpf -mcpu=v3 -filetype=asm t.ll 'v3' is not a recognized processor for this target (ignoring processor) ... $ llc -march=bpf -mcpu=help -filetype=asm t.ll Available CPUs for this target: generic - Select the generic processor. probe - Select the probe processor. v1 - Select the v1 processor. v2 - Select the v2 processor. Available features for this target: dummy - unused feature. Use +feature to enable a feature, or -feature to disable it. For example, llc -mcpu=mycpu -mattr=+feature1,-feature2 ... Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Signed-off-by: Yonghong Song <yhs@fb.com> Acked-by: Alexei Starovoitov <ast@kernel.org> llvm-svn: 311522
101 lines
3.3 KiB
C++
101 lines
3.3 KiB
C++
//===- llvm/Support/Host.h - Host machine characteristics --------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Methods for querying the nature of the host machine.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_SUPPORT_HOST_H
|
|
#define LLVM_SUPPORT_HOST_H
|
|
|
|
#include "llvm/ADT/StringMap.h"
|
|
#include "llvm/Support/MemoryBuffer.h"
|
|
|
|
#if defined(__linux__) || defined(__GNU__) || defined(__HAIKU__)
|
|
#include <endian.h>
|
|
#elif defined(_AIX)
|
|
#include <sys/machine.h>
|
|
#elif defined(__sun)
|
|
/* Solaris provides _BIG_ENDIAN/_LITTLE_ENDIAN selector in sys/types.h */
|
|
#include <sys/types.h>
|
|
#define BIG_ENDIAN 4321
|
|
#define LITTLE_ENDIAN 1234
|
|
#if defined(_BIG_ENDIAN)
|
|
#define BYTE_ORDER BIG_ENDIAN
|
|
#else
|
|
#define BYTE_ORDER LITTLE_ENDIAN
|
|
#endif
|
|
#else
|
|
#if !defined(BYTE_ORDER) && !defined(LLVM_ON_WIN32)
|
|
#include <machine/endian.h>
|
|
#endif
|
|
#endif
|
|
|
|
#include <string>
|
|
|
|
namespace llvm {
|
|
namespace sys {
|
|
|
|
#if defined(BYTE_ORDER) && defined(BIG_ENDIAN) && BYTE_ORDER == BIG_ENDIAN
|
|
constexpr bool IsBigEndianHost = true;
|
|
#else
|
|
constexpr bool IsBigEndianHost = false;
|
|
#endif
|
|
|
|
static const bool IsLittleEndianHost = !IsBigEndianHost;
|
|
|
|
/// getDefaultTargetTriple() - Return the default target triple the compiler
|
|
/// has been configured to produce code for.
|
|
///
|
|
/// The target triple is a string in the format of:
|
|
/// CPU_TYPE-VENDOR-OPERATING_SYSTEM
|
|
/// or
|
|
/// CPU_TYPE-VENDOR-KERNEL-OPERATING_SYSTEM
|
|
std::string getDefaultTargetTriple();
|
|
|
|
/// getProcessTriple() - Return an appropriate target triple for generating
|
|
/// code to be loaded into the current process, e.g. when using the JIT.
|
|
std::string getProcessTriple();
|
|
|
|
/// getHostCPUName - Get the LLVM name for the host CPU. The particular format
|
|
/// of the name is target dependent, and suitable for passing as -mcpu to the
|
|
/// target which matches the host.
|
|
///
|
|
/// \return - The host CPU name, or empty if the CPU could not be determined.
|
|
StringRef getHostCPUName();
|
|
|
|
/// getHostCPUFeatures - Get the LLVM names for the host CPU features.
|
|
/// The particular format of the names are target dependent, and suitable for
|
|
/// passing as -mattr to the target which matches the host.
|
|
///
|
|
/// \param Features - A string mapping feature names to either
|
|
/// true (if enabled) or false (if disabled). This routine makes no guarantees
|
|
/// about exactly which features may appear in this map, except that they are
|
|
/// all valid LLVM feature names.
|
|
///
|
|
/// \return - True on success.
|
|
bool getHostCPUFeatures(StringMap<bool> &Features);
|
|
|
|
/// Get the number of physical cores (as opposed to logical cores returned
|
|
/// from thread::hardware_concurrency(), which includes hyperthreads).
|
|
/// Returns -1 if unknown for the current host system.
|
|
int getHostNumPhysicalCores();
|
|
|
|
namespace detail {
|
|
/// Helper functions to extract HostCPUName from /proc/cpuinfo on linux.
|
|
StringRef getHostCPUNameForPowerPC(const StringRef &ProcCpuinfoContent);
|
|
StringRef getHostCPUNameForARM(const StringRef &ProcCpuinfoContent);
|
|
StringRef getHostCPUNameForS390x(const StringRef &ProcCpuinfoContent);
|
|
StringRef getHostCPUNameForBPF();
|
|
}
|
|
}
|
|
}
|
|
|
|
#endif
|