mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 14:54:20 +01:00
refs #5504 not used in production
git-svn-id: file:///svn/toku/tokudb@48086 c7de825b-a66e-492c-adef-691d508d4ae1
This commit is contained in:
parent
7179e1112b
commit
5bf2d896b0
1 changed files with 0 additions and 68 deletions
68
ft/lock.h
68
ft/lock.h
|
@ -1,68 +0,0 @@
|
|||
/* -*- mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
||||
// vim: ft=cpp:expandtab:ts=8:sw=4:softtabstop=4:
|
||||
#ifndef TOKU_LOCK_H
|
||||
#define TOKU_LOCK_H
|
||||
|
||||
#ident "$Id$"
|
||||
#ident "Copyright (c) 2007-2012 Tokutek Inc. All rights reserved."
|
||||
#ident "The technology is licensed by the Massachusetts Institute of Technology, Rutgers State University of New Jersey, and the Research Foundation of State University of New York at Stony Brook under United States of America Serial No. 11/760379 and to the patents and/or patent applications resulting from it."
|
||||
|
||||
|
||||
#if defined(__x86_64) || defined(__i386)
|
||||
|
||||
static inline void mfence (void) {
|
||||
__asm__ volatile ("mfence":::"memory");
|
||||
}
|
||||
static inline void rfence (void) {
|
||||
__asm__ volatile ("rfence":::"memory");
|
||||
}
|
||||
static inline void sfence (void) {
|
||||
__asm__ volatile ("sfence":::"memory");
|
||||
}
|
||||
|
||||
/* According to the Intel Architecture Software Developer's
|
||||
* Manual, Volume 3: System Programming Guide
|
||||
* (http://www.intel.com/design/pro/manuals/243192.htm), page 7-6,
|
||||
* "For the P6 family processors, locked operations serialize all
|
||||
* outstanding load and store operations (that is, wait for them to
|
||||
* complete)."
|
||||
*
|
||||
* Bradley found that fence instructions is faster on an opteron
|
||||
* mfence takes 8ns on a 1.5GHZ AMD64 (maybe this is an 801)
|
||||
* sfence takes 5ns
|
||||
* lfence takes 3ns
|
||||
* xchgl takes 14ns
|
||||
*/
|
||||
|
||||
static inline lock_xchgl(volatile int *ptr, int x)
|
||||
{
|
||||
__asm__("xchgl %0,%1" :"=r" (x) :"m" (*(ptr)), "0" (x) :"memory");
|
||||
return x;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
typedef volatile int SPINLOCK[1];
|
||||
|
||||
static inline void spin_init (SPINLOCK v) {
|
||||
v[0] = 0;
|
||||
mfence();
|
||||
}
|
||||
|
||||
static inline void spin_lock (SPINLOCK v) {
|
||||
while (lock_xchgl((int*)v, 1)!=0) {
|
||||
while (v[0]); /* Spin using only reads. It would be better to use MCS locks, but this reduces bus traffic. */
|
||||
}
|
||||
}
|
||||
static inline void spin_unlock (SPINLOCK v) {
|
||||
sfence(); // Want all previous stores to take place before we unlock.
|
||||
v[0]=0;
|
||||
}
|
||||
|
||||
#else
|
||||
#error Need to define architecture-specific stuff for other machines.
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
#endif
|
Loading…
Add table
Reference in a new issue