marked_pointer.hh

00001 // This file is a part of Aurelia.
00002 // Copyright (C) 2010  Valentin David
00003 // Copyright (C) 2010  University of Bergen
00004 //
00005 // This program is free software: you can redistribute it and/or modify
00006 // it under the terms of the GNU General Public License as published by
00007 // the Free Software Foundation, either version 3 of the License, or
00008 // (at your option) any later version.
00009 //
00010 // This program is distributed in the hope that it will be useful,
00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00013 // GNU General Public License for more details.
00014 //
00015 // You should have received a copy of the GNU General Public License
00016 // along with this program.  If not, see <http://www.gnu.org/licenses/>.
00017 
00018 #ifndef __MARKED_POINTER_HH
00019 # define __MARKED_POINTER_HH
00020 
00021 # include <type_traits>
00022 # include <memory>
00023 
00024 namespace lockfree {
00025   namespace details {
00026     template <typename T>
00027     void assert_align() {
00028       static_assert(std::alignment_of<T>::value != 1,
00029                     "Pointer cannot be marked as its alignment is 1");
00030     }
00031 
00032     template <typename T>
00033     bool is_marked(T* p) {
00034       assert_align<T>();
00035       return 0x1 & (size_t)p;
00036     };
00037 
00038     template <typename T>
00039     T* unmarked(T* p) {
00040       assert_align<T>();
00041       return (T*)((~0x1) & (size_t)p);
00042     };
00043 
00044     template <typename T>
00045     T* marked(T* p) {
00046       assert_align<T>();
00047       return (T*)(0x1 | (size_t)p);
00048     };
00049   }
00050 }
00051 
00052 #endif