GraphLab: Distributed Graph-Parallel API
2.1
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Groups
Pages
lock_free_internal.hpp
1
/*
2
* Copyright (c) 2009 Carnegie Mellon University.
3
* All rights reserved.
4
*
5
* Licensed under the Apache License, Version 2.0 (the "License");
6
* you may not use this file except in compliance with the License.
7
* You may obtain a copy of the License at
8
*
9
* http://www.apache.org/licenses/LICENSE-2.0
10
*
11
* Unless required by applicable law or agreed to in writing,
12
* software distributed under the License is distributed on an "AS
13
* IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
14
* express or implied. See the License for the specific language
15
* governing permissions and limitations under the License.
16
*
17
* For more about this software visit:
18
*
19
* http://www.graphlab.ml.cmu.edu
20
*
21
*/
22
23
24
#ifndef GRAPHLAB_UTIL_LOCK_FREE_INTERNAL_HPP
25
#define GRAPHLAB_UTIL_LOCK_FREE_INTERNAL_HPP
26
27
#include <graphlab/util/generics/integer_selector.hpp>
28
29
namespace
graphlab {
30
namespace
lock_free_internal {
31
32
template
<
typename
index_type>
33
union
reference_with_counter {
34
struct
{
35
index_type val;
36
index_type counter;
37
} q;
38
index_type& value() {
39
return
q.val;
40
}
41
index_type& counter() {
42
return
q.counter;
43
}
44
typename
u_integer_selector<sizeof(index_type) * 2>::integer_type combined;
45
};
46
47
}
48
}
49
#endif
graphlab
util
lock_free_internal.hpp
Generated on Mon Jun 3 2013 05:00:05 for GraphLab: Distributed Graph-Parallel API by
1.8.1.1