OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
11 | 11 |
12 // This header file includes the inline functions in | 12 // This header file includes the inline functions in |
13 // the fix point signal processing library. | 13 // the fix point signal processing library. |
14 | 14 |
15 #ifndef WEBRTC_COMMON_AUDIO_SIGNAL_PROCESSING_INCLUDE_SPL_INL_H_ | 15 #ifndef WEBRTC_SPL_SPL_INL_H_ |
16 #define WEBRTC_COMMON_AUDIO_SIGNAL_PROCESSING_INCLUDE_SPL_INL_H_ | 16 #define WEBRTC_SPL_SPL_INL_H_ |
17 | 17 |
18 #include "webrtc/system_wrappers/include/compile_assert_c.h" | 18 #include "webrtc/system_wrappers/include/compile_assert_c.h" |
19 | 19 |
20 extern const int8_t kWebRtcSpl_CountLeadingZeros32_Table[64]; | 20 extern const int8_t kWebRtcSpl_CountLeadingZeros32_Table[64]; |
21 | 21 |
22 // Don't call this directly except in tests! | 22 // Don't call this directly except in tests! |
23 static __inline int WebRtcSpl_CountLeadingZeros32_NotBuiltin(uint32_t n) { | 23 static __inline int WebRtcSpl_CountLeadingZeros32_NotBuiltin(uint32_t n) { |
24 // Normalize n by rounding up to the nearest number that is a sequence of 0 | 24 // Normalize n by rounding up to the nearest number that is a sequence of 0 |
25 // bits followed by a sequence of 1 bits. This number has the same number of | 25 // bits followed by a sequence of 1 bits. This number has the same number of |
26 // leading zeros as the original n. There are exactly 33 such values. | 26 // leading zeros as the original n. There are exactly 33 such values. |
(...skipping 22 matching lines...) Expand all Loading... |
49 COMPILE_ASSERT(sizeof(unsigned int) == sizeof(uint32_t)); | 49 COMPILE_ASSERT(sizeof(unsigned int) == sizeof(uint32_t)); |
50 return n == 0 ? 32 : __builtin_clz(n); | 50 return n == 0 ? 32 : __builtin_clz(n); |
51 #else | 51 #else |
52 return WebRtcSpl_CountLeadingZeros32_NotBuiltin(n); | 52 return WebRtcSpl_CountLeadingZeros32_NotBuiltin(n); |
53 #endif | 53 #endif |
54 } | 54 } |
55 | 55 |
56 // Returns the number of leading zero bits in the argument. | 56 // Returns the number of leading zero bits in the argument. |
57 static __inline int WebRtcSpl_CountLeadingZeros64(uint64_t n) { | 57 static __inline int WebRtcSpl_CountLeadingZeros64(uint64_t n) { |
58 #ifdef __GNUC__ | 58 #ifdef __GNUC__ |
59 COMPILE_ASSERT(sizeof(unsigned long long) == sizeof(uint64_t)); // NOLINT | 59 COMPILE_ASSERT(sizeof(unsigned long long) == sizeof(uint64_t)); |
60 return n == 0 ? 64 : __builtin_clzll(n); | 60 return n == 0 ? 64 : __builtin_clzll(n); |
61 #else | 61 #else |
62 return WebRtcSpl_CountLeadingZeros64_NotBuiltin(n); | 62 return WebRtcSpl_CountLeadingZeros64_NotBuiltin(n); |
63 #endif | 63 #endif |
64 } | 64 } |
65 | 65 |
66 #ifdef WEBRTC_ARCH_ARM_V7 | 66 #ifdef WEBRTC_ARCH_ARM_V7 |
67 #include "webrtc/common_audio/signal_processing/include/spl_inl_armv7.h" | 67 #include "webrtc/common_audio/signal_processing/include/spl_inl_armv7.h" |
68 #else | 68 #else |
69 | 69 |
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
144 return a == 0 ? 0 : WebRtcSpl_CountLeadingZeros32(a < 0 ? ~a32 : a32) - 17; | 144 return a == 0 ? 0 : WebRtcSpl_CountLeadingZeros32(a < 0 ? ~a32 : a32) - 17; |
145 } | 145 } |
146 | 146 |
147 static __inline int32_t WebRtc_MulAccumW16(int16_t a, int16_t b, int32_t c) { | 147 static __inline int32_t WebRtc_MulAccumW16(int16_t a, int16_t b, int32_t c) { |
148 return (a * b + c); | 148 return (a * b + c); |
149 } | 149 } |
150 #endif // #if !defined(MIPS32_LE) | 150 #endif // #if !defined(MIPS32_LE) |
151 | 151 |
152 #endif // WEBRTC_ARCH_ARM_V7 | 152 #endif // WEBRTC_ARCH_ARM_V7 |
153 | 153 |
154 #endif // WEBRTC_COMMON_AUDIO_SIGNAL_PROCESSING_INCLUDE_SPL_INL_H_ | 154 #endif // WEBRTC_SPL_SPL_INL_H_ |
OLD | NEW |