You've already forked mariadb-columnstore-engine
							
							
				mirror of
				https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
				synced 2025-10-30 07:25:34 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			117 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* Copyright (C) 2014 InfiniDB, Inc.
 | |
| 
 | |
|    This program is free software; you can redistribute it and/or
 | |
|    modify it under the terms of the GNU General Public License
 | |
|    as published by the Free Software Foundation; version 2 of
 | |
|    the License.
 | |
| 
 | |
|    This program is distributed in the hope that it will be useful,
 | |
|    but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|    GNU General Public License for more details.
 | |
| 
 | |
|    You should have received a copy of the GNU General Public License
 | |
|    along with this program; if not, write to the Free Software
 | |
|    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
 | |
|    MA 02110-1301, USA. */
 | |
| 
 | |
| /** @file */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <unistd.h>
 | |
| #include <stdint.h>
 | |
| #include <sched.h>
 | |
| #include <atomic>
 | |
| 
 | |
| /*
 | |
| This is an attempt to wrap the differneces between Windows and Linux around atomic ops.
 | |
| Boost has something in interprocess::ipcdetail, but it doesn't have 64-bit API's.
 | |
| */
 | |
| 
 | |
| namespace atomicops
 | |
| {
 | |
| // Atomic operations for atomic<int64_t> references
 | |
| inline int64_t atomicAddRef(std::atomic<int64_t>& ref, int64_t val)
 | |
| {
 | |
|   return ref.fetch_add(val, std::memory_order_relaxed);
 | |
| }
 | |
| 
 | |
| inline int64_t atomicSubRef(std::atomic<int64_t>& ref, int64_t val)
 | |
| {
 | |
|   return ref.fetch_sub(val, std::memory_order_relaxed);
 | |
| }
 | |
| 
 | |
| inline void atomicStoreRef(std::atomic<int64_t>& ref, int64_t val)
 | |
| {
 | |
|   ref.store(val, std::memory_order_relaxed);
 | |
| }
 | |
| 
 | |
| inline int64_t atomicLoadRef(const std::atomic<int64_t>& ref)
 | |
| {
 | |
|   return ref.load(std::memory_order_relaxed);
 | |
| }
 | |
| // Returns the resulting, incremented value
 | |
| template <typename T>
 | |
| inline T atomicInc(volatile T* mem)
 | |
| {
 | |
|   return __sync_add_and_fetch(mem, 1);
 | |
| }
 | |
| 
 | |
| // decrements, but returns the pre-decrement value
 | |
| template <typename T>
 | |
| inline T atomicDec(volatile T* mem)
 | |
| {
 | |
|   return __sync_fetch_and_add(mem, -1);
 | |
| }
 | |
| 
 | |
| // Returns the resulting value (but doesn't need to yet)
 | |
| template <typename T>
 | |
| inline T atomicAdd(volatile T* mem, T val)
 | |
| {
 | |
|   return __sync_add_and_fetch(mem, val);
 | |
| }
 | |
| 
 | |
| // Returns the resulting value
 | |
| template <typename T>
 | |
| inline T atomicSub(volatile T* mem, T val)
 | |
| {
 | |
|   return __sync_sub_and_fetch(mem, val);
 | |
| }
 | |
| 
 | |
| // Implements a memory barrier
 | |
| inline void atomicMb()
 | |
| {
 | |
|   __sync_synchronize();
 | |
| }
 | |
| 
 | |
| // Returns true iff the CAS took place, that is
 | |
| // if (*mem == comp) {
 | |
| //   *mem = swap;
 | |
| //   return true;
 | |
| // } else {
 | |
| //   return false;
 | |
| // }
 | |
| template <typename T>
 | |
| inline bool atomicCAS(volatile T* mem, T comp, T swap)
 | |
| {
 | |
|   // If the current value of *mem is comp, then write swap into *comp. Return true if the comparison is
 | |
|   // successful and swap was written.
 | |
|   return __sync_bool_compare_and_swap(mem, comp, swap);
 | |
| }
 | |
| 
 | |
| // implements a zero out of a variable
 | |
| template <typename T>
 | |
| inline void atomicZero(volatile T* mem)
 | |
| {
 | |
|   __sync_xor_and_fetch(mem, *mem);
 | |
| }
 | |
| 
 | |
| // Implements a scheduler yield
 | |
| inline void atomicYield()
 | |
| {
 | |
|   sched_yield();
 | |
| }
 | |
| 
 | |
| }  // namespace atomicops
 |