| /* |
| * Copyright (c) 2021 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #ifndef SYSTEM_WRAPPERS_INCLUDE_DENORMAL_DISABLER_H_ |
| #define SYSTEM_WRAPPERS_INCLUDE_DENORMAL_DISABLER_H_ |
| |
| #include "rtc_base/system/arch.h" |
| |
| namespace webrtc { |
| |
| // Activates the hardware (HW) way to flush denormals (see [1]) to zero as they |
| // can very seriously impact performance. At destruction time restores the |
| // denormals handling state read by the ctor; hence, supports nested calls. |
| // Equals a no-op if the architecture is not x86 or ARM or if the compiler is |
| // not CLANG. |
| // [1] https://en.wikipedia.org/wiki/Denormal_number |
| // |
| // Example usage: |
| // |
| // void Foo() { |
| // DenormalDisabler d; |
| // ... |
| // } |
| class DenormalDisabler { |
| public: |
| // Ctor. If architecture and compiler are supported, stores the HW settings |
| // for denormals, disables denormals and sets `disabling_activated_` to true. |
| // Otherwise, only sets `disabling_activated_` to false. |
| DenormalDisabler(); |
| // Ctor. Same as above, but also requires `enabled` to be true to disable |
| // denormals. |
| explicit DenormalDisabler(bool enabled); |
| DenormalDisabler(const DenormalDisabler&) = delete; |
| DenormalDisabler& operator=(const DenormalDisabler&) = delete; |
| // Dtor. If `disabling_activated_` is true, restores the denormals HW settings |
| // read by the ctor before denormals were disabled. Otherwise it's a no-op. |
| ~DenormalDisabler(); |
| |
| // Returns true if architecture and compiler are supported. |
| static bool IsSupported(); |
| |
| private: |
| const int status_word_; |
| const bool disabling_activated_; |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // SYSTEM_WRAPPERS_INCLUDE_DENORMAL_DISABLER_H_ |