2020-09-05 05:36:52 +08:00
|
|
|
---
|
2020-09-25 01:35:54 +08:00
|
|
|
BasedOnStyle: LLVM
|
2020-09-05 05:36:52 +08:00
|
|
|
AlignConsecutiveAssignments: true
|
2022-04-20 02:08:09 +08:00
|
|
|
BraceWrapping:
|
|
|
|
AfterFunction: true
|
|
|
|
#llvm10-11: AfterControlStatement: false - Never
|
|
|
|
BeforeCatch: true
|
|
|
|
BeforeElse: true
|
|
|
|
#llvm11: BeforeLambdaBody: false
|
|
|
|
#llvm11: BeforeWhile: false
|
|
|
|
BreakBeforeBraces: Stroustrup
|
|
|
|
BreakAfterJavaFieldAnnotations: true
|
|
|
|
BreakStringLiterals: true
|
2024-04-13 00:16:41 +08:00
|
|
|
ColumnLimit: 110
|
2022-04-20 02:08:09 +08:00
|
|
|
IndentWidth: 4
|
|
|
|
---
|
|
|
|
Language: Cpp
|
2021-01-28 07:51:59 +08:00
|
|
|
#llvm11: AlignConsecutiveBitFields: false
|
2020-09-05 05:36:52 +08:00
|
|
|
AlignConsecutiveDeclarations: true
|
2021-02-26 05:12:57 +08:00
|
|
|
AlignConsecutiveMacros: true
|
2021-01-28 07:51:59 +08:00
|
|
|
#llvm10-11: AlignOperands: true - Align
|
|
|
|
#llvm11: AllowShortEnumsOnASingleLine: true
|
2021-03-17 23:25:39 +08:00
|
|
|
AllowShortFunctionsOnASingleLine: None
|
2020-09-05 05:36:52 +08:00
|
|
|
AlwaysBreakAfterReturnType: AllDefinitions
|
2020-10-07 06:37:42 +08:00
|
|
|
# Can enable the following section when llvm 12.x is out
|
|
|
|
#AttributeMacros:
|
|
|
|
# - H5_ATTR_FORMAT
|
|
|
|
# - H5_ATTR_UNUSED
|
|
|
|
# - H5_ATTR_DEPRECATED_USED
|
|
|
|
# - H5_ATTR_NDEBUG_UNUSED
|
|
|
|
# - H5_ATTR_DEBUG_API_USED
|
|
|
|
# - H5_ATTR_PARALLEL_UNUSED
|
|
|
|
# - H5_ATTR_PARALLEL_USED
|
|
|
|
# - H5_ATTR_NORETURN
|
|
|
|
# - H5_ATTR_CONST
|
|
|
|
# - H5_ATTR_PURE
|
|
|
|
# - H5_ATTR_FALLTHROUGH
|
2021-03-17 23:25:39 +08:00
|
|
|
ForEachMacros: ['ALL_MEMBERS', 'UNIQUE_MEMBERS']
|
2020-09-05 05:36:52 +08:00
|
|
|
IncludeCategories:
|
|
|
|
- Regex: '^"(llvm|llvm-c|clang|clang-c)/'
|
|
|
|
Priority: 3
|
|
|
|
SortPriority: 0
|
|
|
|
- Regex: '^(<|"(gtest|gmock|isl|json)/)'
|
|
|
|
Priority: 4
|
|
|
|
SortPriority: 0
|
|
|
|
- Regex: '.*'
|
|
|
|
Priority: 0
|
|
|
|
SortPriority: 0
|
|
|
|
- Regex: '^H5*.*'
|
|
|
|
Priority: 1
|
|
|
|
SortPriority: 0
|
|
|
|
- Regex: 'private.*'
|
|
|
|
Priority: 2
|
|
|
|
SortPriority: 0
|
|
|
|
IncludeIsMainRegex: '(public)?$'
|
|
|
|
IndentCaseLabels: true
|
2021-01-28 07:51:59 +08:00
|
|
|
#llvm11: IndentCaseBlocks: false
|
2020-09-05 05:36:52 +08:00
|
|
|
IndentGotoLabels: false
|
2021-01-28 07:51:59 +08:00
|
|
|
#llvm11: IndentExternBlock: AfterExternBlock
|
|
|
|
#llvm11: InsertTrailingCommas: None
|
Add new multithreaded concurrency configuration (#5015)
Added infrastructure support for multithreaded concurrency by adding an optional way to switch to using a non-recursive R/W lock for the global API lock. This is enabled with a new 'concurrency' configuration flag for the autotools & CMake builds, which is disabled by default.
When the 'concurrency' build option is chosen, the global API lock will use the R/W lock and all API calls currently will acquire a write lock, ensuring exclusive access by one thread. Over time, the API routines that are converted to support multithreaded concurrency will switch to acquiring a read lock instead.
Reentering the library from application callbacks is managed by the 'disable locking for this thread' (DLFTT) threadsafety protocol. This is internally handled within the H5_API_LOCK / H5_API_UNLOCK macros in H5private.h (as before), which invoke the 'dlftt' routines in H5TSint.c.
To support this change, the threadsafety configuration macros for the library have been updated:
- --enable-threadsafe now defines the H5_HAVE_THREADSAFE macro
- --enable-concurrency defines the H5_HAVE_CONCURRENCY macro
The new H5_HAVE_THREADSAFE_API macro is set if either H5_HAVE_THREADSAFE or H5_HAVE_CONCURRENCY is enabled.
New Github actions are added to include the concurrency configuration in the CI for the develop branch.
To support the new non-recursive R/W locking for API routines, some other changes are necessary:
Added macro wrappers around all callback invocations that could call an
application function, and therefore re-enter the library:
H5_BEFORE_USER_CB* / H5_AFTER_USER_CB*
Added H5_user_cb_prepare / H5_user_cb_restore routines that save the
state of the library when callback leaves the library. Includes error
stack and threadsafe reentry state currently.
There's also some small cleanups to various places in the library:
Moved the H5E_mpi_error_str / H5E_mpi_error_str_len globals to be local for
pushing MPI errors, so that multiple threads can't interfere with each
other.
Added H5TS_rwlock_trywrlock() routine to R/W lock interface.
Emulate R/W locks on MacOS because its implementation of
pthread_rwlock_wrlock() does not conform to the POSIX standard.
Don't acquire the global API lock in H5close, since it's acquired in H5_term_library, which is necessary because H5_term_library is invoked via other code paths that don't hold the global API lock.
Don't call H5Eget_auto2 API routine within H5_term_library.
Switched 'return NULL' in H5allocate_memory to HGOTO_DONE(NULL).
Switched H5Pget_file_space_strategy / H5Pset_file_space_strategy to use
internal routines instead of API routines.
Switched H5Oopen_by_addr & H5Ovisit1 to use internal routines instead of
API routines.
Fixed a few places in src/H5Odeprec.c where a major
error ID was passed as a minor ID.
2024-12-19 17:35:21 +08:00
|
|
|
MacroBlockBegin: "^H5_BEFORE_USER_CB*|^H5E_PAUSE_ERRORS"
|
|
|
|
MacroBlockEnd: "^H5_AFTER_USER_CB*|^H5E_RESUME_ERRORS"
|
2020-09-05 05:36:52 +08:00
|
|
|
ObjCBlockIndentWidth: 4
|
2021-01-28 07:51:59 +08:00
|
|
|
#llvm11: ObjCBreakBeforeNestedBlockParam: true
|
2020-09-05 05:36:52 +08:00
|
|
|
ReflowComments: true
|
|
|
|
SortIncludes: false
|
|
|
|
StatementMacros:
|
2023-06-16 12:49:02 +08:00
|
|
|
- CATCH
|
|
|
|
- END_MEMBERS
|
2020-09-05 05:36:52 +08:00
|
|
|
- FUNC_ENTER_API
|
2024-04-08 22:57:54 +08:00
|
|
|
- FUNC_ENTER_API_NAMECHECK_ONLY
|
2023-06-16 12:49:02 +08:00
|
|
|
- FUNC_ENTER_NOAPI
|
Refactor threading and other concurrency support (#4469)
Complete overhaul of the concurrency-related aspects of the library (threading, atomics, locking, etc.), adding private routines in the H5TS package to allow internal algorithms to use all of these capabilities.
Adds many new features & components in the H5TS package that are equivalent to common concurrency data structures and capabilities: "regular" and recursive mutices, condition variables, semaphores, thread barriers, 'once' support, thread pools, atomic variables, thread-local keys, and spawning & joining internal threads.
Now supports C11, pthreads, and Windows threading for all H5TS capabilities, except the recursive readers/writers lock, which is not supported on Windows (because Windows threads don't provide a callback on thread-local variable deletion).
The "global" API lock is switched to use a recursive mutex from the H5TS package, instead of its own variant.
API context code (H5CX package) and error stacks (H5E package) now use the common thread-local info, instead of their own variants.
Subfiling code is switched from using Mercury threading features to the new internal H5TS features.
Removes the mercury threading code.
Adds a configure option (--enable-threads / HDF5_ENABLE_THREADS), enabled by default, to control whether threading is enabled within the library.
2024-08-01 01:34:43 +08:00
|
|
|
- FUNC_ENTER_NOAPI_NAMECHECK_ONLY
|
2023-06-16 12:49:02 +08:00
|
|
|
- FUNC_ENTER_NOAPI_NOERR
|
|
|
|
- FUNC_ENTER_NOAPI_NOINIT
|
2020-09-05 05:36:52 +08:00
|
|
|
- FUNC_ENTER_NOAPI_NOINIT_NOERR
|
2023-06-16 12:49:02 +08:00
|
|
|
- FUNC_ENTER_PACKAGE
|
|
|
|
- FUNC_LEAVE_API
|
2024-04-08 22:57:54 +08:00
|
|
|
- FUNC_LEAVE_API_NAMECHECK_ONLY
|
2020-09-05 05:36:52 +08:00
|
|
|
- FUNC_LEAVE_NOAPI
|
Refactor threading and other concurrency support (#4469)
Complete overhaul of the concurrency-related aspects of the library (threading, atomics, locking, etc.), adding private routines in the H5TS package to allow internal algorithms to use all of these capabilities.
Adds many new features & components in the H5TS package that are equivalent to common concurrency data structures and capabilities: "regular" and recursive mutices, condition variables, semaphores, thread barriers, 'once' support, thread pools, atomic variables, thread-local keys, and spawning & joining internal threads.
Now supports C11, pthreads, and Windows threading for all H5TS capabilities, except the recursive readers/writers lock, which is not supported on Windows (because Windows threads don't provide a callback on thread-local variable deletion).
The "global" API lock is switched to use a recursive mutex from the H5TS package, instead of its own variant.
API context code (H5CX package) and error stacks (H5E package) now use the common thread-local info, instead of their own variants.
Subfiling code is switched from using Mercury threading features to the new internal H5TS features.
Removes the mercury threading code.
Adds a configure option (--enable-threads / HDF5_ENABLE_THREADS), enabled by default, to control whether threading is enabled within the library.
2024-08-01 01:34:43 +08:00
|
|
|
- FUNC_LEAVE_NOAPI_NAMECHECK_ONLY
|
|
|
|
- FUNC_LEAVE_NOAPI_VOID_NAMECHECK_ONLY
|
2023-06-16 12:49:02 +08:00
|
|
|
- FUNC_LEAVE_NOAPI_NOFS
|
Add new multithreaded concurrency configuration (#5015)
Added infrastructure support for multithreaded concurrency by adding an optional way to switch to using a non-recursive R/W lock for the global API lock. This is enabled with a new 'concurrency' configuration flag for the autotools & CMake builds, which is disabled by default.
When the 'concurrency' build option is chosen, the global API lock will use the R/W lock and all API calls currently will acquire a write lock, ensuring exclusive access by one thread. Over time, the API routines that are converted to support multithreaded concurrency will switch to acquiring a read lock instead.
Reentering the library from application callbacks is managed by the 'disable locking for this thread' (DLFTT) threadsafety protocol. This is internally handled within the H5_API_LOCK / H5_API_UNLOCK macros in H5private.h (as before), which invoke the 'dlftt' routines in H5TSint.c.
To support this change, the threadsafety configuration macros for the library have been updated:
- --enable-threadsafe now defines the H5_HAVE_THREADSAFE macro
- --enable-concurrency defines the H5_HAVE_CONCURRENCY macro
The new H5_HAVE_THREADSAFE_API macro is set if either H5_HAVE_THREADSAFE or H5_HAVE_CONCURRENCY is enabled.
New Github actions are added to include the concurrency configuration in the CI for the develop branch.
To support the new non-recursive R/W locking for API routines, some other changes are necessary:
Added macro wrappers around all callback invocations that could call an
application function, and therefore re-enter the library:
H5_BEFORE_USER_CB* / H5_AFTER_USER_CB*
Added H5_user_cb_prepare / H5_user_cb_restore routines that save the
state of the library when callback leaves the library. Includes error
stack and threadsafe reentry state currently.
There's also some small cleanups to various places in the library:
Moved the H5E_mpi_error_str / H5E_mpi_error_str_len globals to be local for
pushing MPI errors, so that multiple threads can't interfere with each
other.
Added H5TS_rwlock_trywrlock() routine to R/W lock interface.
Emulate R/W locks on MacOS because its implementation of
pthread_rwlock_wrlock() does not conform to the POSIX standard.
Don't acquire the global API lock in H5close, since it's acquired in H5_term_library, which is necessary because H5_term_library is invoked via other code paths that don't hold the global API lock.
Don't call H5Eget_auto2 API routine within H5_term_library.
Switched 'return NULL' in H5allocate_memory to HGOTO_DONE(NULL).
Switched H5Pget_file_space_strategy / H5Pset_file_space_strategy to use
internal routines instead of API routines.
Switched H5Oopen_by_addr & H5Ovisit1 to use internal routines instead of
API routines.
Fixed a few places in src/H5Odeprec.c where a major
error ID was passed as a minor ID.
2024-12-19 17:35:21 +08:00
|
|
|
- H5E_BEGIN_TRY
|
2023-06-16 12:49:02 +08:00
|
|
|
- H5E_END_TRY
|
2020-09-05 05:36:52 +08:00
|
|
|
- H5_BEGIN_TAG
|
|
|
|
- H5_END_TAG
|
2023-06-16 12:49:02 +08:00
|
|
|
- H5_GCC_DIAG_OFF
|
|
|
|
- H5_GCC_DIAG_ON
|
2023-08-26 02:24:42 +08:00
|
|
|
- H5_CLANG_DIAG_OFF
|
|
|
|
- H5_CLANG_DIAG_ON
|
|
|
|
- H5_GCC_CLANG_DIAG_OFF
|
|
|
|
- H5_GCC_CLANG_DIAG_ON
|
2023-06-16 12:49:02 +08:00
|
|
|
- H5_LEAVE
|
2020-09-05 05:36:52 +08:00
|
|
|
- HGOTO_DONE
|
|
|
|
- HMPI_DONE_ERROR
|
2023-06-16 12:49:02 +08:00
|
|
|
- HMPI_ERROR
|
2020-09-05 05:36:52 +08:00
|
|
|
- HMPI_GOTO_ERROR
|
2023-06-16 12:49:02 +08:00
|
|
|
- HSYS_DONE_ERROR
|
|
|
|
- HSYS_GOTO_ERROR
|
2021-01-28 07:51:59 +08:00
|
|
|
#llvm10: TypenameMacros:
|
|
|
|
#llvm10: - STACK_OF
|
|
|
|
#llvm10: - LIST
|
|
|
|
#llvm11: WhitespaceSensitiveMacros:
|
|
|
|
#llvm11: - STRINGIZE
|
|
|
|
#llvm11: - PP_STRINGIZE
|
2022-04-20 02:08:09 +08:00
|
|
|
---
|
|
|
|
Language: Java
|
|
|
|
BreakAfterJavaFieldAnnotations: true
|
|
|
|
JavaImportGroups: ['java', 'hdf', 'hdf.hdf5lib', 'org']
|
2020-09-05 05:36:52 +08:00
|
|
|
...
|