2017-02-03 06:55:55 +08:00
|
|
|
//===- X86InstrFMA3Info.h - X86 FMA3 Instruction Information ----*- C++ -*-===//
|
2016-08-12 06:07:33 +08:00
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2016-08-12 06:07:33 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file contains the implementation of the classes providing information
|
|
|
|
// about existing X86 FMA3 opcodes, classifying and grouping them.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_LIB_TARGET_X86_UTILS_X86INSTRFMA3INFO_H
|
|
|
|
#define LLVM_LIB_TARGET_X86_UTILS_X86INSTRFMA3INFO_H
|
|
|
|
|
|
|
|
#include "X86.h"
|
|
|
|
#include "llvm/ADT/DenseMap.h"
|
|
|
|
#include <cassert>
|
2017-02-03 06:55:55 +08:00
|
|
|
#include <cstdint>
|
2016-08-12 06:07:33 +08:00
|
|
|
#include <set>
|
|
|
|
|
2016-10-19 03:39:31 +08:00
|
|
|
namespace llvm {
|
2017-02-03 06:55:55 +08:00
|
|
|
|
2016-08-12 06:07:33 +08:00
|
|
|
/// This class is used to group {132, 213, 231} forms of FMA opcodes together.
|
2018-06-27 08:42:24 +08:00
|
|
|
/// Each of the groups has either 3 opcodes, Also, each group has an attributes
|
|
|
|
/// field describing it.
|
2018-06-18 14:32:22 +08:00
|
|
|
struct X86InstrFMA3Group {
|
2018-06-27 08:42:24 +08:00
|
|
|
/// An array holding 3 forms of FMA opcodes.
|
|
|
|
uint16_t Opcodes[3];
|
2016-08-12 06:07:33 +08:00
|
|
|
|
|
|
|
/// This bitfield specifies the attributes associated with the created
|
|
|
|
/// FMA groups of opcodes.
|
2018-06-18 14:32:22 +08:00
|
|
|
uint16_t Attributes;
|
|
|
|
|
|
|
|
enum {
|
|
|
|
Form132,
|
|
|
|
Form213,
|
|
|
|
Form231,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum : uint16_t {
|
|
|
|
/// This bit must be set in the 'Attributes' field of FMA group if such
|
|
|
|
/// group of FMA opcodes consists of FMA intrinsic opcodes.
|
2018-07-02 14:23:39 +08:00
|
|
|
Intrinsic = 0x1,
|
2018-06-18 14:32:22 +08:00
|
|
|
|
|
|
|
/// This bit must be set in the 'Attributes' field of FMA group if such
|
|
|
|
/// group of FMA opcodes consists of AVX512 opcodes accepting a k-mask and
|
|
|
|
/// passing the elements from the 1st operand to the result of the operation
|
|
|
|
/// when the correpondings bits in the k-mask are unset.
|
2018-07-02 14:23:39 +08:00
|
|
|
KMergeMasked = 0x2,
|
2018-06-18 14:32:22 +08:00
|
|
|
|
|
|
|
/// This bit must be set in the 'Attributes' field of FMA group if such
|
|
|
|
/// group of FMA opcodes consists of AVX512 opcodes accepting a k-zeromask.
|
2018-07-02 14:23:39 +08:00
|
|
|
KZeroMasked = 0x4,
|
2018-06-18 14:32:22 +08:00
|
|
|
};
|
2016-08-12 06:07:33 +08:00
|
|
|
|
2018-06-27 08:42:24 +08:00
|
|
|
/// Returns the 132 form of FMA opcode.
|
|
|
|
unsigned get132Opcode() const {
|
|
|
|
return Opcodes[Form132];
|
2016-08-12 06:07:33 +08:00
|
|
|
}
|
|
|
|
|
2018-06-27 08:42:24 +08:00
|
|
|
/// Returns the 213 form of FMA opcode.
|
|
|
|
unsigned get213Opcode() const {
|
|
|
|
return Opcodes[Form213];
|
2016-08-12 06:07:33 +08:00
|
|
|
}
|
|
|
|
|
2018-06-27 08:42:24 +08:00
|
|
|
/// Returns the 231 form of FMA opcode.
|
|
|
|
unsigned get231Opcode() const {
|
|
|
|
return Opcodes[Form231];
|
2016-08-12 06:07:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Returns true iff the group of FMA opcodes holds intrinsic opcodes.
|
2018-07-02 14:23:39 +08:00
|
|
|
bool isIntrinsic() const { return (Attributes & Intrinsic) != 0; }
|
2016-08-12 06:07:33 +08:00
|
|
|
|
|
|
|
/// Returns true iff the group of FMA opcodes holds k-merge-masked opcodes.
|
|
|
|
bool isKMergeMasked() const {
|
2018-07-02 14:23:39 +08:00
|
|
|
return (Attributes & KMergeMasked) != 0;
|
2016-08-12 06:07:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Returns true iff the group of FMA opcodes holds k-zero-masked opcodes.
|
2018-07-02 14:23:39 +08:00
|
|
|
bool isKZeroMasked() const { return (Attributes &KZeroMasked) != 0; }
|
2016-08-12 06:07:33 +08:00
|
|
|
|
|
|
|
/// Returns true iff the group of FMA opcodes holds any of k-masked opcodes.
|
|
|
|
bool isKMasked() const {
|
2018-07-02 14:23:39 +08:00
|
|
|
return (Attributes & (KMergeMasked | KZeroMasked)) != 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator<(const X86InstrFMA3Group &RHS) const {
|
|
|
|
return Opcodes[0] < RHS.Opcodes[0];
|
2016-08-12 06:07:33 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-07-01 06:38:42 +08:00
|
|
|
/// Returns a reference to a group of FMA3 opcodes to where the given
|
|
|
|
/// \p Opcode is included. If the given \p Opcode is not recognized as FMA3
|
|
|
|
/// and not included into any FMA3 group, then nullptr is returned.
|
2018-07-02 14:23:39 +08:00
|
|
|
const X86InstrFMA3Group *getFMA3Group(unsigned Opcode, uint64_t TSFlags);
|
2016-08-12 06:07:33 +08:00
|
|
|
|
2017-02-03 06:55:55 +08:00
|
|
|
} // end namespace llvm
|
|
|
|
|
|
|
|
#endif // LLVM_LIB_TARGET_X86_UTILS_X86INSTRFMA3INFO_H
|