Apache HTTPD
apr_atomic.c
Go to the documentation of this file.
1/* Licensed to the Apache Software Foundation (ASF) under one or more
2 * contributor license agreements. See the NOTICE file distributed with
3 * this work for additional information regarding copyright ownership.
4 * The ASF licenses this file to You under the Apache License, Version 2.0
5 * (the "License"); you may not use this file except in compliance with
6 * the License. You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include "apr_arch_atomic.h"
18
23
25{
26#if (defined(_M_IA64) || defined(_M_AMD64))
28#else
29 return InterlockedExchangeAdd((long *)mem, val);
30#endif
31}
32
33/* Of course we want the 2's compliment of the unsigned value, val */
34#ifdef _MSC_VER
35#pragma warning(disable: 4146)
36#endif
37
39{
40#if (defined(_M_IA64) || defined(_M_AMD64))
42#else
44#endif
45}
46
48{
49 /* we return old value, win32 returns new value :( */
50#if (defined(_M_IA64) || defined(_M_AMD64)) && !defined(RC_INVOKED)
51 return InterlockedIncrement(mem) - 1;
52#else
53 return InterlockedIncrement((long *)mem) - 1;
54#endif
55}
56
58{
59#if (defined(_M_IA64) || defined(_M_AMD64)) && !defined(RC_INVOKED)
61#else
62 return InterlockedDecrement((long *)mem);
63#endif
64}
65
67{
68#if (defined(_M_IA64) || defined(_M_AMD64)) && !defined(RC_INVOKED)
70#else
72#endif
73}
74
76{
77 return *mem;
78}
79
82{
83#if (defined(_M_IA64) || defined(_M_AMD64)) && !defined(RC_INVOKED)
85#else
86 return InterlockedCompareExchange((long*)mem, with, cmp);
87#endif
88}
89
90APR_DECLARE(void *) apr_atomic_casptr(volatile void **mem, void *with, const void *cmp)
91{
92#if (defined(_M_IA64) || defined(_M_AMD64)) && !defined(RC_INVOKED)
93 return InterlockedCompareExchangePointer((void* volatile*)mem, with, (void*)cmp);
94#else
95 return InterlockedCompareExchangePointer((void**)mem, with, (void*)cmp);
96#endif
97}
98
100{
101#if (defined(_M_IA64) || defined(_M_AMD64)) && !defined(RC_INVOKED)
102 return InterlockedExchange(mem, val);
103#else
104 return InterlockedExchange((long *)mem, val);
105#endif
106}
107
108APR_DECLARE(void*) apr_atomic_xchgptr(volatile void **mem, void *with)
109{
110 return InterlockedExchangePointer((void**)mem, with);
111}
apr_uint32_t apr_atomic_add32(volatile apr_uint32_t *mem, apr_uint32_t val)
Definition atomic.c:30
void apr_atomic_sub32(volatile apr_uint32_t *mem, apr_uint32_t val)
Definition atomic.c:41
apr_uint32_t apr_atomic_inc32(volatile apr_uint32_t *mem)
Definition atomic.c:51
apr_uint32_t apr_atomic_xchg32(volatile apr_uint32_t *mem, apr_uint32_t val)
Definition atomic.c:111
int apr_atomic_dec32(volatile apr_uint32_t *mem)
Definition atomic.c:56
apr_status_t apr_atomic_init(apr_pool_t *p)
Definition atomic.c:21
void apr_atomic_set32(volatile apr_uint32_t *mem, apr_uint32_t val)
Definition atomic.c:73
apr_uint32_t apr_atomic_cas32(volatile apr_uint32_t *mem, apr_uint32_t swap, apr_uint32_t cmp)
Definition atomic.c:78
apr_uint32_t apr_atomic_read32(volatile apr_uint32_t *mem)
Definition atomic.c:68
apr_size_t size
apr_uint32_t apr_uint32_t cmp
Definition apr_atomic.h:106
apr_uint32_t with
Definition apr_atomic.h:105
apr_uint32_t val
Definition apr_atomic.h:66
#define APR_SUCCESS
Definition apr_errno.h:225
int apr_status_t
Definition apr_errno.h:44
APR_DECLARE(void)
Definition apr_atomic.c:35
void * mem
apr_pool_t * p
Definition md_event.c:32