Lift
Library of parallel computing primitives for GPUs and multi-core CPUs
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros
vector_flags.h
Go to the documentation of this file.
1 /*
2  * Lift
3  *
4  * Copyright (c) 2014-2015, NVIDIA CORPORATION
5  * Copyright (c) 2015, Nuno Subtil <subtil@gmail.com>
6  * Copyright (c) 2015, Roche Molecular Systems, Inc.
7  * All rights reserved.
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions are met:
11  * * Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  * * Redistributions in binary form must reproduce the above copyright
14  * notice, this list of conditions and the following disclaimer in the
15  * documentation and/or other materials provided with the distribution.
16  * * Neither the name of the copyright holders nor the names of its
17  * contributors may be used to endorse or promote products derived from
18  * this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
21  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
22  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
23  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE
24  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
26  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
28  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30  */
31 
32 #pragma once
33 
34 namespace lift {
35 namespace x86_64 {
36 
37 // vector extension flags
38 static constexpr uint32 SSE = 1 << 0;
39 static constexpr uint32 SSE2 = 1 << 1;
40 static constexpr uint32 SSE3 = 1 << 2;
41 static constexpr uint32 SSE3_S = 1 << 3; // SSE3 supplemental
42 static constexpr uint32 SSE4_1 = 1 << 4; // SSE 4.1 (Penryn)
43 static constexpr uint32 SSE4_2 = 1 << 5; // SSE 4.2 (Nehalem)
44 static constexpr uint32 SSE4_a = 1 << 6;
45 static constexpr uint32 SSE_XOP = 1 << 7; // SSE extended operations
46 static constexpr uint32 SSE_FMA4 = 1 << 8;
47 static constexpr uint32 SSE_FMA3 = 1 << 9;
48 static constexpr uint32 SSE_F16C = 1 << 10;
49 static constexpr uint32 AVX = 1 << 11;
50 static constexpr uint32 AVX2 = 1 << 12;
51 
52 } // namespace x86_64
53 } // namespace lift
static constexpr uint32 SSE4_1
Definition: vector_flags.h:42
static constexpr uint32 AVX2
Definition: vector_flags.h:50
static constexpr uint32 AVX
Definition: vector_flags.h:49
uint32_t uint32
Definition: types.h:43
static constexpr uint32 SSE_FMA4
Definition: vector_flags.h:46
static constexpr uint32 SSE
Definition: vector_flags.h:38
static constexpr uint32 SSE3_S
Definition: vector_flags.h:41
static constexpr uint32 SSE4_2
Definition: vector_flags.h:43
static constexpr uint32 SSE_FMA3
Definition: vector_flags.h:47
static constexpr uint32 SSE2
Definition: vector_flags.h:39
static constexpr uint32 SSE_XOP
Definition: vector_flags.h:45
static constexpr uint32 SSE4_a
Definition: vector_flags.h:44
static constexpr uint32 SSE_F16C
Definition: vector_flags.h:48
static constexpr uint32 SSE3
Definition: vector_flags.h:40