diff options
author | arkady-e1ppa <arkady-e1ppa@yandex-team.com> | 2023-11-16 17:24:02 +0300 |
---|---|---|
committer | arkady-e1ppa <arkady-e1ppa@yandex-team.com> | 2023-11-16 18:51:45 +0300 |
commit | 6b40f0f1060a3e9d54347e52c7dc8fb278e6e86b (patch) | |
tree | da4c8447ff495a023682292e1ac90309312ddb8f /library/cpp/yt/threading/traceless_guard.h | |
parent | 8f8023320207d4dfa6e9b6c595fe272382595cdd (diff) | |
download | ydb-6b40f0f1060a3e9d54347e52c7dc8fb278e6e86b.tar.gz |
Active spinlock tracking from pr3151306. Added TracelessGuards to disable mentioned tracking
1) Добавлена возможность инструментировать ваш любимый мьютекс/спинлок/что-либо с методами Acquire/Release со схожим смыслом. Делается это засчет методов ```NThreading::NDetail::RecordSpinlockAcquired```/```NThreading::NDetail::RecordSpinlockReleased```. Они отслеживают число захваченных спинлоков.
2) Добавлен макрос ```REGISTER_TRACKED_SPIN_LOCK_CLASS```, который позволяет номинально проверить на этапе компиляции, что данный спинлок отслеживается.
3) Добавлен метод ```NThreading::VerifyNoSpinlockAffinity```, который коркается, если число захваченных спинлоков больше нуля.
4) Добавлены Traceless версии (почти) всех гардов, чтобы можно было не отслеживать конкретную критическую секцию, если очень нужно.
5) Внутри файберного ```WaitUntilSet``` вызывается ```VerifyNoSpinlockAffinity``` -- делать ```WaitFor``` или ```Yield``` внутри отслеживаемых критических секций нельзя. Если очень хочется -- используем TracelessGuard нужного вида.
6) Теперь отслеживаются такие спинлоки и их наследники: ```TSpinLock```, ```TRecursiveSpinLock```, ```TReaderWriterSpinLock```.
7) Зарегистрированы как отслеживаемые все вышеперечисленные спинлоки и их Padded версии.
8) Все эти действия имеют эффект только в дебаг сборке. В релизе вся эта диагностика стирается.
Diffstat (limited to 'library/cpp/yt/threading/traceless_guard.h')
-rw-r--r-- | library/cpp/yt/threading/traceless_guard.h | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/library/cpp/yt/threading/traceless_guard.h b/library/cpp/yt/threading/traceless_guard.h new file mode 100644 index 0000000000..10ad0ded98 --- /dev/null +++ b/library/cpp/yt/threading/traceless_guard.h @@ -0,0 +1,29 @@ +#pragma once + +#define TRACELESS_GUARD_INL_H_ +#include "traceless_guard-inl.h" +#undef TRACELESS_GUARD_INL_H_ + +namespace NYT::NThreading { + +// This guards are zero-cost replacements for normal ones +// which allow user to avoid spinlocks being tracked. + +//////////////////////////////////////////////////////////////////////////////// + +using NPrivate::TTracelessGuard; +using NPrivate::TTracelessInverseGuard; +using NPrivate::TTracelessTryGuard; +using NPrivate::TTracelessReaderGuard; +using NPrivate::TTracelessWriterGuard; + +//////////////////////////////////////////////////////////////////////////////// + +using NPrivate::TracelessGuard; +using NPrivate::TracelessTryGuard; +using NPrivate::TracelessReaderGuard; +using NPrivate::TracelessWriterGuard; + +//////////////////////////////////////////////////////////////////////////////// + +} // namespace NYT::NThreading |