summaryrefslogtreecommitdiff
path: root/include/atomic
Commit message (Collapse)AuthorAgeFilesLines
* MDEV-19696 - Cleanup gcc sync builtinsRobert Bindar2019-07-031-106/+0
| | | | | Since 10.4 requires C++11 capable compiler, gcc sync builtins became dead code. Remove relevant cmake checks and cleanup include files.
* Merge 10.2 into 10.3Marko Mäkelä2019-05-143-3/+3
|\
| * Merge 10.1 into 10.2Marko Mäkelä2019-05-134-4/+4
| |\
| | * Merge branch '5.5' into 10.1Vicențiu Ciorbaru2019-05-115-5/+5
| | |\
| | | * Update FSF AddressVicențiu Ciorbaru2019-05-116-6/+6
| | | | | | | | | | | | | | | | * Update wrong zip-code
* | | | Merge bb-10.2-ext into 10.3Marko Mäkelä2017-12-122-32/+6
|\ \ \ \
| * | | | Restore LF_BACKOFFSergey Vojtovich2017-12-081-30/+0
| |/ / / | | | | | | | | | | | | | | | | Moved InnoDB UT_RELAX_CPU() to server. Restored cross-platform LF_BACKOFF implementation basing on UT_RELAX_CPU().
* | | | Faster atomic loads and stores on windowsSergey Vojtovich2017-12-081-6/+37
| | | |
* | | | MDEV-13728 - Import MySQL 5.7 atomic operations for MSVC and SolarisSergey Vojtovich2017-11-274-151/+300
| | | | | | | | | | | | | | | | gcc_sync.h, solaris.h, generic-msvc.h copied verbatim.
* | | | MDEV-11212 - Clean-up MariaDB atomic operationsSergey Vojtovich2016-12-131-14/+30
| | | | | | | | | | | | | | | | No more black magic for gcc atomic bultins. Fixes some warnings.
* | | | MDEV-11212 - Clean-up MariaDB atomic operationsSergey Vojtovich2016-12-131-0/+37
| | | | | | | | | | | | | | | | | | | | | | | | Moved gcc specific code to gcc_builtins.h. Moved intptr into the black magic code block. Moved definition of atomic operations for "long" out of black magic code block.
* | | | MDEV-11212 - Clean-up MariaDB atomic operationsSergey Vojtovich2016-12-133-20/+1
| | | | | | | | | | | | | | | | | | | | Removed MY_ATOMIC_MODE_DUMMY and WITH_ATOMIC_OPS: MariaDB is not functional without atomic operations anymore.
* | | | MDEV-11212 - Clean-up MariaDB atomic operationsSergey Vojtovich2016-12-131-2/+0
| | | | | | | | | | | | | | | | Removed MY_ATOMIC_HAS_8_16: never defined.
* | | | MDEV-11212 - Clean-up MariaDB atomic operationsSergey Vojtovich2016-12-131-151/+0
|/ / / | | | | | | | | | | | | Removed "somewhat broken native x86 implementation". Should never be used on supported platforms.
* | | MDEV-8791 - AIX: Unresolved Symbols during linkingSergey Vojtovich2016-10-312-54/+6
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Clean-up nolock.h: it doesn't serve any purpose anymore. Appropriate code moved to x86-gcc.h and my_atomic.h. If gcc sync bultins were detected, we want to make use of them independently of __GNUC__ definition. E.g. XLC simulates those, but doesn't define __GNUC__. HS/Spider: According to AIX manual alloca() returns char*, which cannot be casted to any type with static_cast. Use explicit cast instead. MDL: Removed namemangling pragma, which didn't let MariaDB build with XLC. WSREP: _int64 seem to be conflicting name with XLC, replaced with _integer64. CONNECT: RTLD_NOLOAD is GNU extention. Removed rather meaningless check if library is loaded. Multiple dlopen()'s of the same library are permitted, and it never gets closed anyway. Except for error, which was a bug: it may close library, which can still be referenced by other subsystems. InnoDB: __ppc_get_timebase() is GNU extention. Only use it when __GLIBC__ is defined. Based on contribution by flynn1973.
* | Merge tag 'mariadb-10.0.20' into 10.1Sergei Golubchik2015-06-271-2/+2
|\ \
| * | MDEV-7398 mysqld segfaults on FreeBSD 10.1 i386 when built with clang 3.4Sergei Golubchik2015-06-161-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | in cmake tests let's treat clang like gcc (same options, same builtins) in many cases. * don't check the compiler when * testing for -fvisibility=hidden support * testing for HAVE_ABI_CXA_DEMANGLE * testing for HAVE_GCC_ATOMIC_BUILTINS * when removing options with string(replace) * when running ${CC} --version (ignore the error instead) * run ABI checks for clang * use "canonical" gcc flags for clang * fix groonga too Also: * add cmake detection for gcc __atomic_* builtins. they might be supported (__ATOMIC_SEQ_CST is defined), but not for all operand sizes. In particular, 64-bit atomic load is problematic on i386 * cache check results for Windows * remove the test for HAVE_CXXABI_H (HAVE_ABI_CXA_DEMANGLE is suffifient)
* | | MDEV-7437 remove suport for "atomics" with rwlocksSergei Golubchik2015-01-132-78/+0
|/ /
* | compilation fixes for WITH_ATOMIC_OPS=rwlocksSergei Golubchik2014-09-081-38/+0
| |
* | MDEV-5766 - my_atomic_load does memory writesSergey Vojtovich2014-03-071-0/+6
|/ | | | | | | | | my_atomic_load() is implemented as __sync_fetch_and_or(var, 0) which writes or-ed value back to var. Memory writes as such have worse performance and scalability than reads. gcc 4.7 and up offers better facility for atomic loads/stores. Use it whenever it is available.
* centos5 gcc 4.1 asm bugSergei Golubchik2013-05-071-3/+3
| | | | | | include/atomic/x86-gcc.h: force %esi register, don't give gcc a choice. (otherwise it could choose %ebx, and 4.1 did)
* MDEV-417 - fix typo that prevented use of atomic instructions on WindowsVladislav Vaintroub2012-07-301-1/+1
| | | | use correct macro for Microsoft compiler. It is _MSC_VER , not _MSV_VER
* Updated/added copyright headersKent Boortz2011-06-306-12/+14
|\
| * Bug#22320: my_atomic-t unit test failsDavi Arnaut2010-07-055-279/+0
| | | | | | | | | | | | The atomic operations implementation on 5.1 has a few problems, which might cause tests to abort randomly. Since no code in 5.1 uses atomic operations, simply remove the code.
* | Bug#56760: my_atomics failures on osx10.5-x86-64bitDavi Arnaut2010-11-301-7/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The problem was due to a misuse of GCC asm constraints used to implement a atomic load. On x86_64, the load was implemented as a cmpxchg which implicitly uses the eax register as a source and destination operand, yet the dummy value used for comparison wasn't being properly loaded into eax (and other problems). The core problem is that cmpxchg is unnecessary as a load on x86_64 as there are other simpler instructions such as xadd. Even though, such instructions are only used to have a memory barrier as load and stores are atomic by definition. Hence, the solution is to explicitly issue the required CPU and compiler barriers. include/atomic/x86-gcc.h: Issue a synchronizing instruction before loading the value. Afterwards, issue a compiler barrier to prevent reordering.
* | Bug#52419: x86 assembly based atomic CAS causes test failuresDavi Arnaut2010-09-171-8/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The problem was that the x86 assembly based atomic CAS (compare and swap) implementation could copy the wrong value to the ebx register, where the cmpxchg8b expects to see part of the "comparand" value. Since the original value in the ebx register is saved in the stack (that is, the push instruction causes the stack pointer to change), a wrong offset could be used if the compiler decides to put the source of the comparand value in the stack. The solution is to copy the comparand value directly from memory. Since the comparand value is 64-bits wide, it is copied in two steps over to the ebx and ecx registers. include/atomic/x86-gcc.h: For reference, an excerpt from a faulty binary follows. It is a disassembly of my_atomic-t, compiled at -O3 with ICC 11.0. Most of the code deals with preparations for a atomic cmpxchg8b operation. This instruction compares the value in edx:eax with the destination operand. If the values are equal, the value in ecx:ebx is stored in the destination, otherwise the value in the destination operand is copied into edx:eax. In this case, my_atomic_add64 is implemented as a compare and exchange. The addition is done over temporary storage and loaded into the destination if the original term value is still valid. volatile int64 a64; int64 b=0x1000200030004000LL; a64=0; mov 0xfffffda8(%ebx),%eax xor %ebp,%ebp mov %ebp,(%eax) mov %ebp,0x4(%eax) my_atomic_add64(&a64, b); mov 0xfffffda8(%ebx),%ebp # Load address of a64 mov 0x0(%ebp),%edx # Copy value mov 0x4(%ebp),%ecx mov %edx,0xc(%esp) # Assign to tmp var in the stack mov %ecx,0x10(%esp) add $0x30004000,%edx # Sum values adc $0x10002000,%ecx mov %edx,0x8(%esp) # Save part of result for later mov 0x0(%ebp),%esi # Copy value of a64 again mov 0x4(%ebp),%edi mov 0xc(%esp),%eax # Load the value of a64 used mov 0x10(%esp),%edx # for comparison mov %esi,(%esp) mov %edi,0x4(%esp) push %ebx # Push %ebx into stack. Changes esp. mov 0x8(%esp),%ebx # Wrong restore of the result. lock cmpxchg8b 0x0(%ebp) sete %cl pop %ebx
* | Bug#52261: 64 bit atomic operations do not work on Solaris i386 ..Davi Arnaut2010-07-271-1/+7
| | | | | | | | | | | | Workaround a interface problem with the atomic macros that was causing warnings. The correct type is retrieved using typeof if compiling with GCC.
* | Bug#22320: my_atomic-t unit test failsDavi Arnaut2010-07-233-22/+41
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Bug#52261: 64 bit atomic operations do not work on Solaris i386 gcc in debug compilation One of the various problems was that the source operand to CMPXCHG8b was marked as a input/output operand, causing GCC to use the EBX register as the destination register for the CMPXCHG8b instruction. This could lead to crashes as the EBX register is also implicitly used by the instruction, causing the value to be potentially garbaged and a protection fault once the value is used to access a position in memory. Another problem was the lack of proper clobbers for the atomic operations and, also, a discrepancy between the implementations for the Compare and Set operation. The specific problems are described and fixed by Kristian Nielsen patches: Patch: 1 Fix bugs in my_atomic_cas*(val,cmp,new) that *cmp is accessed after CAS succeds. In the gcc builtin implementation, problem was that *cmp was read again after atomic CAS to check if old *val == *cmp; this fails if CAS is successful and another thread modifies *cmp in-between. In the x86-gcc implementation, problem was that *cmp was set also in the case of successful CAS; this means there is a window where it can clobber a value written by another thread after successful CAS. Patch 2: Add a GCC asm "memory" clobber to primitives that imply a memory barrier. This signifies to GCC that any potentially aliased memory must be flushed before the operation, and re-read after the operation, so that read or modification in other threads of such memory values will work as intended. In effect, it makes these primitives work as memory barriers for the compiler as well as the CPU. This is better and more correct than adding "volatile" to variables. include/atomic/gcc_builtins.h: Do not read from *cmp after the operation as it might be already gone if the operation was successful. include/atomic/nolock.h: Prefer system provided atomics over the broken x86 asm. include/atomic/x86-gcc.h: Do not mark source operands as input/output operands. Add proper memory clobbers. include/my_atomic.h: Add notes about my_atomic_add and my_atomic_cas behaviors. unittest/mysys/my_atomic-t.c: Remove work around, if it fails, there is either a problem with the atomic operations code or the specific compiler version should be black-listed.
* | Fix compiler warnings in my_atomic.hKonstantin Osipov2010-02-191-1/+1
| | | | | | | | | | | | | | include/atomic/x86-gcc.h: Fix a warning about empty while loop body. include/my_atomic.h: Fix a warning about empty while loop body.
* | mergedSergei Golubchik2009-12-241-1/+1
|\ \
| * | Force use of c-register in CAS instruction on x86-32 bit architecture, ↵Mikael Ronstrom2009-12-211-1/+1
| | | | | | | | | | | | b-register used for push and pop, so don't want to give compile the chance to choose the wrong register
* | | fix atomic/solaris.h to conformSergei Golubchik2009-12-232-223/+31
|/ / | | | | | | remove duplicated boilerplate code
* | Increase probability of correct atomics implementation by choosing stable ↵Mikael Ronstrom2009-12-191-0/+1
| | | | | | | | implementations first
* | Make choices of atomic implementation based on highest stabilityMikael Ronstrom2009-12-191-9/+21
| |
* | Fixed Solaris Atomics build issuesMikael Ronstrom2009-12-181-1/+2
| |
* | Added extra checks of 64-bit atomic support on GCC and Solaris, also added ↵Mikael Ronstrom2009-12-181-1/+45
| | | | | | | | 64-bit support in solaris.h which was missing
* | Fix for Windows atomicsMikael Ronstrom2009-12-161-15/+19
| |
* | Fixed complex gcc assembler issues with 64-bit operations on 32-bit ↵Mikael Ronstrom2009-12-151-18/+47
| | | | | | | | platforms using PIC codes, commented x86-gcc.h a lot more
* | Include windows.h in atomics framework for windowsMikael Ronstrom2009-12-151-0/+1
| |
* | Fixed 64-bit atomics on Win x86 and removed support for 8 and 16-bit atomic ↵Mikael Ronstrom2009-12-151-12/+1
| | | | | | | | operations
* | Fixed atomic instruction headers for Windows and x86-gccMikael Ronstrom2009-12-152-4/+34
| |
* | Merge WL#5138 to mysql-next-mrMikael Ronstrom2009-11-272-6/+42
|\ \
| * | Misc cleanupMarc Alff2009-11-171-96/+0
| | |
| * | WL#2595 kernel-independent atomic operationsMarc Alff2009-11-176-54/+222
| | | | | | | | | | | | | | | | | | Backport from 6.0.14 to 5.6.0 Original code from Sergei Golubchik
* | | WL#5138 merged to mysql-next-mrMikael Ronstrom2009-11-207-150/+207
|\ \ \ | |/ / |/| |
| * | Backported my_atomic from 6.0-codebase and added support for 64-bit atomics ↵Mikael Ronstrom2009-10-122-14/+49
| | | | | | | | | | | | to enable removal of LOCK_thread_count from every query, removed LOCK_thread_count from use in dispatch_command and close of query which is used in every query, now uses atomic increments/decrements instead
| * | Moved atomics from 6.0 codebase to prepare for using atomic increments in ↵Mikael Ronstrom2009-10-096-139/+179
| | | | | | | | | | | | places where LOCK_thread_count previously was used
* | | manual merge: mysql-5.1-rep+2-delivery1 --> mysql-5.1-rpl-mergeLuis Soares2009-10-224-0/+17
|\ \ \ | |/ / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Conflicts ========= Text conflict in .bzr-mysql/default.conf Text conflict in libmysqld/CMakeLists.txt Text conflict in libmysqld/Makefile.am Text conflict in mysql-test/collections/default.experimental Text conflict in mysql-test/extra/rpl_tests/rpl_row_sp006.test Text conflict in mysql-test/suite/binlog/r/binlog_tmp_table.result Text conflict in mysql-test/suite/rpl/r/rpl_loaddata.result Text conflict in mysql-test/suite/rpl/r/rpl_loaddata_fatal.result Text conflict in mysql-test/suite/rpl/r/rpl_row_create_table.result Text conflict in mysql-test/suite/rpl/r/rpl_row_sp006_InnoDB.result Text conflict in mysql-test/suite/rpl/r/rpl_stm_log.result Text conflict in mysql-test/suite/rpl_ndb/r/rpl_ndb_circular_simplex.result Text conflict in mysql-test/suite/rpl_ndb/r/rpl_ndb_sp006.result Text conflict in mysql-test/t/mysqlbinlog.test Text conflict in sql/CMakeLists.txt Text conflict in sql/Makefile.am Text conflict in sql/log_event_old.cc Text conflict in sql/rpl_rli.cc Text conflict in sql/slave.cc Text conflict in sql/sql_binlog.cc Text conflict in sql/sql_lex.h 21 conflicts encountered. NOTE ==== mysql-5.1-rpl-merge has been made a mirror of mysql-next-mr: - "mysql-5.1-rpl-merge$ bzr pull ../mysql-next-mr" This is the first cset (merge/...) committed after pulling from mysql-next-mr.
| * | WL#5016: Fix header file include guardsMats Kindahl2009-09-234-0/+17
| |/ | | | | | | | | Adding header include file guards to files that are missing such.
* | Fix for BUG#45131Mikael Ronstrom2009-06-101-1/+1
| |