Lift
Library of parallel computing primitives for GPUs and multi-core CPUs
Main Page
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
lift
util.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
36
// swap two variables
37
template
<
typename
T>
38
static
inline
LIFT_HOST_DEVICE
void
swap
(T& a, T& b)
39
{
40
T temp;
41
temp = a;
42
a = b;
43
b = temp;
44
}
45
46
// get the lane ID for a GPU thread
47
static
inline
__device__
unsigned
int
lane_id
(
void
)
48
{
49
unsigned
int
ret;
50
asm
(
"mov.u32 %0, %laneid;"
:
"=r"
(ret));
51
return
ret;
52
}
53
54
}
// namespace lift
lift::swap
static LIFT_HOST_DEVICE void swap(T &a, T &b)
Definition:
util.h:38
LIFT_HOST_DEVICE
#define LIFT_HOST_DEVICE
Definition:
local_memory.h:40
lift::lane_id
static __device__ unsigned int lane_id(void)
Definition:
util.h:47
Generated by
1.8.6