modules/ims_qos: added patch for flow-description bug when request originates from...
[sip-router] / compiler_opt.h
1 /*
2  * Copyright (C) 2007 iptelorg GmbH
3  *
4  * Permission to use, copy, modify, and distribute this software for any
5  * purpose with or without fee is hereby granted, provided that the above
6  * copyright notice and this permission notice appear in all copies.
7  *
8  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15  */
16
17 /*!
18  * \file
19  * \brief Kamailio core :: Compiler specific optimizations
20  * \see \ref CompilerOptions
21  * \auth Andrei
22  *
23  * \ingroup core
24  * Module: \ref core
25  *
26  * \page CompilerOptions compiler specific optimizations:
27  *
28 \verbatim
29  *   - likely(expr)         - branch predicition optimization - is more likely
30  *                          that expr value will be 1 so optimize for this 
31  *                          case.
32  *                          Example: if (likely(p!=NULL)) {... }
33  *   - unlikely(expr)       - branch prediction optimization - is unlikely that 
34  *                          expr will be true, so optimize for this case
35  *   - prefetch(addr)        - will prefetch addr. for reading
36  *   - prefetch_w(addr)      - will prefetch addr. for writing
37  *   - prefetch_loc_r(addr, loc) - prefetch for reading, data at addr has
38  *                                no temporal locality (loc==0), a short
39  *                                degree of temporal locality (loc==1), 
40  *                                moderate (loc==2) or high (loc==3).
41  *                                prefetch(addr) is equiv. to 
42  *                                prefetch_loc_r(addr, 3).
43  *  prefetch_loc_w(addr, loc) - like above but for writing.
44 \endverbatim
45  */
46
47 #ifndef __compiler_opt_h
48 #define __compiler_opt_h
49
50 /* likely/unlikely */
51 #if __GNUC__ >= 3
52
53 #define likely(expr)              __builtin_expect(!!(expr), 1)
54 #define unlikely(expr)            __builtin_expect(!!(expr), 0)
55
56 #else /* __GNUC__ */
57
58 /* #warning "No compiler optimizations supported try gcc 4.x" */
59 #define likely(expr) (expr)
60 #define unlikely(expr) (expr)
61
62 #endif /* __GNUC__ */
63
64
65
66 /* prefetch* */
67 #if ( __GNUC__ > 3 ) || ( __GNUC__ == 3 && __GNUC_MINOR__ >= 1 )
68
69 #define prefetch(addr)            __builtin_prefetch((addr))
70 #define prefetch_w(addr)          __builtin_prefetch((addr), 1)
71 #define prefetch_loc_r(addr, loc) __builtin_prefetch((addr), 0, (loc))
72 #define prefetch_loc_w(addr, loc) __builtin_prefetch((addr), 1, (loc))
73
74 #else
75
76 #define prefetch(addr)
77 #define prefetch_w(addr)
78 #define prefetch_loc_r(addr, loc)
79 #define prefetch_loc_w(addr, loc)
80
81 #endif /* __GNUC__ > 3  || ( __GNUC__ == 3 && __GNUC_MINOR__ >= 1 ) */
82
83 #endif