Igor Sysoev | d90282d | 2004-09-28 08:34:51 +0000 | [diff] [blame] | 1 | |
| 2 | /* |
Igor Sysoev | ff8da91 | 2004-09-29 16:00:49 +0000 | [diff] [blame] | 3 | * Copyright (C) Igor Sysoev |
Maxim Konovalov | f8d59e3 | 2012-01-18 15:07:43 +0000 | [diff] [blame] | 4 | * Copyright (C) Nginx, Inc. |
Igor Sysoev | d90282d | 2004-09-28 08:34:51 +0000 | [diff] [blame] | 5 | */ |
| 6 | |
| 7 | |
Igor Sysoev | 078d1b2 | 2004-06-30 15:30:41 +0000 | [diff] [blame] | 8 | #ifndef _NGX_ATOMIC_H_INCLUDED_ |
| 9 | #define _NGX_ATOMIC_H_INCLUDED_ |
| 10 | |
| 11 | |
| 12 | #include <ngx_config.h> |
| 13 | #include <ngx_core.h> |
| 14 | |
| 15 | |
Igor Sysoev | 85080d0 | 2004-09-22 16:18:21 +0000 | [diff] [blame] | 16 | #define NGX_HAVE_ATOMIC_OPS 1 |
| 17 | |
Igor Sysoev | 7845223 | 2005-10-12 13:50:36 +0000 | [diff] [blame] | 18 | typedef int32_t ngx_atomic_int_t; |
| 19 | typedef uint32_t ngx_atomic_uint_t; |
Igor Sysoev | 11d7532 | 2005-03-01 15:20:36 +0000 | [diff] [blame] | 20 | typedef volatile ngx_atomic_uint_t ngx_atomic_t; |
Igor Sysoev | 29e7d8c | 2009-09-25 20:25:47 +0000 | [diff] [blame] | 21 | #define NGX_ATOMIC_T_LEN (sizeof("-2147483648") - 1) |
Igor Sysoev | 078d1b2 | 2004-06-30 15:30:41 +0000 | [diff] [blame] | 22 | |
| 23 | |
Igor Sysoev | 1b73583 | 2004-11-11 14:07:14 +0000 | [diff] [blame] | 24 | #if defined( __WATCOMC__ ) || defined( __BORLANDC__ ) || ( _MSC_VER >= 1300 ) |
Igor Sysoev | 078d1b2 | 2004-06-30 15:30:41 +0000 | [diff] [blame] | 25 | |
Igor Sysoev | 85080d0 | 2004-09-22 16:18:21 +0000 | [diff] [blame] | 26 | /* the new SDK headers */ |
| 27 | |
Igor Sysoev | 078d1b2 | 2004-06-30 15:30:41 +0000 | [diff] [blame] | 28 | #define ngx_atomic_cmp_set(lock, old, set) \ |
Igor Sysoev | c31a9bb | 2005-11-26 10:11:11 +0000 | [diff] [blame] | 29 | ((ngx_atomic_uint_t) InterlockedCompareExchange((long *) lock, set, old) \ |
| 30 | == old) |
Igor Sysoev | 078d1b2 | 2004-06-30 15:30:41 +0000 | [diff] [blame] | 31 | |
| 32 | #else |
| 33 | |
Igor Sysoev | 85080d0 | 2004-09-22 16:18:21 +0000 | [diff] [blame] | 34 | /* the old MS VC6.0SP2 SDK headers */ |
| 35 | |
Igor Sysoev | 078d1b2 | 2004-06-30 15:30:41 +0000 | [diff] [blame] | 36 | #define ngx_atomic_cmp_set(lock, old, set) \ |
| 37 | (InterlockedCompareExchange((void **) lock, (void *) set, (void *) old) \ |
| 38 | == (void *) old) |
| 39 | |
| 40 | #endif |
| 41 | |
| 42 | |
Igor Sysoev | 7845223 | 2005-10-12 13:50:36 +0000 | [diff] [blame] | 43 | #define ngx_atomic_fetch_add(p, add) InterlockedExchangeAdd((long *) p, add) |
| 44 | |
| 45 | |
Igor Sysoev | c2068d0 | 2005-10-19 12:33:58 +0000 | [diff] [blame] | 46 | #define ngx_memory_barrier() |
| 47 | |
| 48 | |
Igor Sysoev | 875893b | 2007-05-05 05:50:41 +0000 | [diff] [blame] | 49 | #if defined( __BORLANDC__ ) || ( __WATCOMC__ < 1230 ) |
| 50 | |
| 51 | /* |
| 52 | * Borland C++ 5.5 (tasm32) and Open Watcom C prior to 1.3 |
| 53 | * do not understand the "pause" instruction |
| 54 | */ |
| 55 | |
Igor Sysoev | ffe7144 | 2006-02-08 15:33:12 +0000 | [diff] [blame] | 56 | #define ngx_cpu_pause() |
| 57 | #else |
| 58 | #define ngx_cpu_pause() __asm { pause } |
| 59 | #endif |
| 60 | |
| 61 | |
| 62 | void ngx_spinlock(ngx_atomic_t *lock, ngx_atomic_int_t value, ngx_uint_t spin); |
Igor Sysoev | 078d1b2 | 2004-06-30 15:30:41 +0000 | [diff] [blame] | 63 | |
| 64 | #define ngx_trylock(lock) (*(lock) == 0 && ngx_atomic_cmp_set(lock, 0, 1)) |
| 65 | #define ngx_unlock(lock) *(lock) = 0 |
| 66 | |
| 67 | |
| 68 | #endif /* _NGX_ATOMIC_H_INCLUDED_ */ |