Overview
Request 839763 accepted
- Changes for 23.1.1:
* erts: inet:setopts([{active,once}]) wakes up IO polling thread
unnecessarily, leading to lock contention and visibly higher
CPU utilization.
* erts: Two bugs in the ERTS internal thread wakeup functionality
have been fixed. These bugs mainly hit when all threads in the
system tried to go to sleep. When the bugs were triggered,
certain operations were delayed until a thread woke up due to
some other reason. Most important operations effected were code
loading, persistent term updates, and memory deallocation.
* erts: Fixed bug in ets:select_replace/2 on compressed tables
that could produce faulty results or VM crash. Bug exists since
OTP 20.
* erts: When compiling Erlang/OTP on macOS using Xcode 12, the
performance of the BEAM interpreter would be degraded.
* erts: As of OTP 22, the allocator specific memory carrier pools
were replaced by a node global carrier pool. This unfortunately
caused substantial memory fragmentation in some cases due to
long lived data being spread into carriers used by allocators
mainly handling short lived data. A new command line argument
+Mcp has been introduced with which one can enable the old
behavior as well as configuring other behaviors for the carrier
pools. In order to configure the old behavior, with allocator
specific carrier pools for all allocators, pass +Mucp :
(including the colon character) as a command line argument to
erl when starting the Erlang system. The default configuration
for carrier pools will be changed to +Mucp : some time in the
future, but not in this patch.
* os_mon: The configuration parameter
memsup_improved_system_memory_data has been introduced. It can
- Created by matwey
- In state accepted
- Supersedes 839762
- Open review for matwey
- Open review for gsantomaggio_suse
Request History
matwey created request
- Changes for 23.1.1:
* erts: inet:setopts([{active,once}]) wakes up IO polling thread
unnecessarily, leading to lock contention and visibly higher
CPU utilization.
* erts: Two bugs in the ERTS internal thread wakeup functionality
have been fixed. These bugs mainly hit when all threads in the
system tried to go to sleep. When the bugs were triggered,
certain operations were delayed until a thread woke up due to
some other reason. Most important operations effected were code
loading, persistent term updates, and memory deallocation.
* erts: Fixed bug in ets:select_replace/2 on compressed tables
that could produce faulty results or VM crash. Bug exists since
OTP 20.
* erts: When compiling Erlang/OTP on macOS using Xcode 12, the
performance of the BEAM interpreter would be degraded.
* erts: As of OTP 22, the allocator specific memory carrier pools
were replaced by a node global carrier pool. This unfortunately
caused substantial memory fragmentation in some cases due to
long lived data being spread into carriers used by allocators
mainly handling short lived data. A new command line argument
+Mcp has been introduced with which one can enable the old
behavior as well as configuring other behaviors for the carrier
pools. In order to configure the old behavior, with allocator
specific carrier pools for all allocators, pass +Mucp :
(including the colon character) as a command line argument to
erl when starting the Erlang system. The default configuration
for carrier pools will be changed to +Mucp : some time in the
future, but not in this patch.
* os_mon: The configuration parameter
memsup_improved_system_memory_data has been introduced. It can
gsantomaggio_suse accepted request
Tahnk you