Skip to content

Conversation

@DavidSpickett
Copy link
Collaborator

Since #157170 this test has been flakey on several LLDB buildbots. I suspect it's to do with mutli-threading, there are more details in #159377.

Disable parallel loading for now so we are not spamming people making unrelated changes.

Since llvm#157170 this test has been flakey on several LLDB buildbots.
I suspect it's to do with mutli-threading, there are more details
in llvm#159377.

Disable parallel loading for now so we are not spamming people
making unrelated changes.
@DavidSpickett DavidSpickett added the skip-precommit-approval PR for CI feedback, not intended for review label Sep 17, 2025
@llvmbot llvmbot added the lldb label Sep 17, 2025
@DavidSpickett DavidSpickett merged commit d0bdc5d into llvm:main Sep 17, 2025
8 of 12 checks passed
@DavidSpickett DavidSpickett deleted the lldb-netbsdcore branch September 17, 2025 16:40
@llvmbot
Copy link
Member

llvmbot commented Sep 17, 2025

@llvm/pr-subscribers-lldb

Author: David Spickett (DavidSpickett)

Changes

Since #157170 this test has been flakey on several LLDB buildbots. I suspect it's to do with mutli-threading, there are more details in #159377.

Disable parallel loading for now so we are not spamming people making unrelated changes.


Full diff: https://github.com/llvm/llvm-project/pull/159395.diff

1 Files Affected:

  • (modified) lldb/test/API/functionalities/postmortem/netbsd-core/TestNetBSDCore.py (+2)
diff --git a/lldb/test/API/functionalities/postmortem/netbsd-core/TestNetBSDCore.py b/lldb/test/API/functionalities/postmortem/netbsd-core/TestNetBSDCore.py
index ff1ef21e02e31..179dbdf88fa8a 100644
--- a/lldb/test/API/functionalities/postmortem/netbsd-core/TestNetBSDCore.py
+++ b/lldb/test/API/functionalities/postmortem/netbsd-core/TestNetBSDCore.py
@@ -117,6 +117,8 @@ def check_backtrace(self, thread, filename, backtrace):
                 )
 
     def do_test(self, filename, pid, region_count):
+        # Temporary workaround for https://github.com/llvm/llvm-project/issues/159377
+        self.runCmd("settings set target.parallel-module-load false")
         target = self.dbg.CreateTarget(filename)
         process = target.LoadCore(filename + ".core")
 

dmpots added a commit to dmpots/llvm-project that referenced this pull request Sep 17, 2025
The `ProcessElfCore::FindModuleUUID` function can be called by multiple
threads at the same time when `target.parallel-module-load` is true. We
were using the `operator[]` to lookup the UUID which will mutate the map
when the key is not present. This is unsafe in a multi-threaded contex
so we now use a read-only `find` operation and explicitly return an
invalid UUID when the key is not present.

The `m_uuids` map can follow a create-then-query pattern. It is
populated in the `DoLoadCore` function which looks like it is only
called in a single-threaded context so we do not need extra locking as
long as we keep the other accesses read-only.

Other fixes I considered

  * Use a lock to protect access
     - We don't need to modify the map after creation so we can allow
       concurrent read-only access.
  * Store the map in a const pointer container to prevent accidental
    mutation in other places.
     - Only accessed in one place currently so just added a comment.
  * Store the UUID in the NT_FILE_Entry after building the mapping
    correctly in `UpdateBuildIdForNTFileEntries`.
     - The map lets us avoid a linear search in `FindModuleUUID`.

This commit also reverts the temporary workaround from llvm#159395 which
disabled parallel module loading to avoid the test failure.
dmpots added a commit that referenced this pull request Sep 18, 2025
…9444)

The `ProcessElfCore::FindModuleUUID` function can be called by multiple
threads at the same time when `target.parallel-module-load` is true. We
were using the `operator[]` to lookup the UUID which will mutate the map
when the key is not present. This is unsafe in a multi-threaded contex
so we now use a read-only `find` operation and explicitly return an
invalid UUID when the key is not present.

The `m_uuids` map can follow a create-then-query pattern. It is
populated in the `DoLoadCore` function which looks like it is only
called in a single-threaded context so we do not need extra locking as
long as we keep the other accesses read-only.

Other fixes I considered

* Use a lock to protect access - We don't need to modify the map after
creation so we can allow concurrent read-only access.
* Store the map in a const pointer container to prevent accidental
mutation in other places.
     - Only accessed in one place currently so just added a comment.
* Store the UUID in the NT_FILE_Entry after building the mapping
correctly in `UpdateBuildIdForNTFileEntries`. - The map lets us avoid a
linear search in `FindModuleUUID`.

This commit also reverts the temporary workaround from #159395 which
disabled parallel module loading to avoid the test failure.

Fixes #159377
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

lldb skip-precommit-approval PR for CI feedback, not intended for review

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants