Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

i#7303: Copy drsyscall from drmemory to dynamorio/ext. #7304

Closed
wants to merge 161 commits into from

Conversation

ivankyluk
Copy link
Contributor

@ivankyluk ivankyluk commented Feb 25, 2025

Copy files from drmemory/drsyscall to dynamorio/ext/drsyscall. Files required by drsyscall under drmemory/common and drmemory/framework are copied as well.

The following changes are made:

  • Add drcontext as the first parameter to LOG(...)
  • Remove rlimit64 declaration from linux_defines.h.
  • Remove IF_WINDOWS_ELSE from common/utils.h
  • Change op_verbose_level to verbose in common/utils.h
  • LOG if DEBUG is defined to remove drcontext
  • Update drsyscall/CMakeLists.txt to include files in framework and common.
  • Copy the DRMF_VERSION and set_library_version logic from drmemory/CMakeLists.txt to ext/drsyscall/CMakeList.txt.
  • Add a space in between "while(" for REPORT_DISK_ERROR in common/utils.h.
  • (MacOS) Comment out SYS_nfsclnt, SYS___old_semwait_signal, SYS___old_semwait_signal_nocancel and SYS_shared_region_map_and_slide_np in table_macos_bsd.c (xref macOS Ventura support drmemory#2483).
  • Skip Alpine, ANDROID and RISCV64 build in drsycall/CMakeLists.txt
  • Change make/resources.rc to core/win32/resources.rc in drsyscall/CMakeLists.txt.
  • Remove empty lines before EOF and change tabs to spaces in files.

Issue: #7303

@ivankyluk ivankyluk changed the title i7303: Copy drsyscall from drmemory to drnamorio/ext. i7303: Copy drsyscall from drmemory to dynamorio/ext. Feb 25, 2025
@ivankyluk ivankyluk changed the title i7303: Copy drsyscall from drmemory to dynamorio/ext. i#7303: Copy drsyscall from drmemory to dynamorio/ext. Feb 26, 2025
ivankyluk added a commit that referenced this pull request Mar 12, 2025
…mit messages. (#7345)

Skip clang-format checks and vera test if DISABLE_FORMAT_CHECKS appears
in one of the commit messages.
This feature enables us to copy code over without format changes as a
base line and use subsequent PRs to fix format issues. And it is useful
to add .patch files or other files where tabs are part of the format.

Format checks can also be disabled by setting DISABLE_FORMAT_CHECKS to
ON, for example,
cmake -DDISABLE_FORMAT_CHECKS=ON ...

Test: I added DISABLE_FORMAT_CHECKS as part of a commit message to #7304
and verified format checks were disabled except aarch64 build.
 
"gh api" is not installed on the aarchxx machines. Adding "gh" to the
install list didn't work, and manually installing gh or github-cli
failed using tmate. I have added a TODO in
.github/workflows/ci-aarchxx.yml to add the support once "gh api" is
installed.

Issue: #7344
ivankyluk added a commit that referenced this pull request Mar 14, 2025
…mit messages. (#7361)

Skip clang-format, vera and tab checks if DISABLE_FORMAT_CHECKS appears
in one of the commit messages.
This feature enables us to copy code over without format changes as a
base line and use subsequent PRs to fix format issues. And it is useful
to add .patch files or other files where tabs are part of the format.

Format checks can also be disabled by setting DISABLE_FORMAT_CHECKS to
ON, for example,
cmake -DDISABLE_FORMAT_CHECKS=ON ...

Test: I added DISABLE_FORMAT_CHECKS as part of a commit message to
#7304 and verified format
checks were disabled except aarch64 build.

"gh api" is not installed on the aarchxx machines. Adding "gh" to the
install list didn't work, and manually installing gh or github-cli
failed using tmate. I have added a TODO in
.github/workflows/ci-aarchxx.yml to add the support once "gh api" is
installed.

The original PR #7345 was reverted because
github.event.pull_request._links.commits.href is absent in case of
push/merge.
This PR handles the push/merge case by using
```
  if ${{ contains(toJSON(github.event.commits.*.message), 'DISABLE_FORMAT_CHECKS') }}
```
for push.
 
Test: 
- I added DISABLE_FORMAT_CHECKS as part of a commit message in a clone
repository, ivankyluk/dynamorio, to verify format checks were disable
when DISABLE_FORMAT_CHECKS was added as a commit message. And formats
checks were enabled when DISABLE_FORMAT_CHECKS was absent.
- I used the cloned repository to test the push/merge event.

Issue: #7344
@ivankyluk
Copy link
Contributor Author

Copying DrSyscall from DrMemory to DynamoRIO is done by #7389, #7393, and #7396.

@ivankyluk ivankyluk closed this Mar 26, 2025
ivankyluk added a commit that referenced this pull request Apr 2, 2025
…leases. (#7425)

Syscall statx was introduced in Linux Kernel 4.11. struct statx and
statx_timestamp are not defined in older versions.

Define the structs in core/unix/include/stat.h and use the header file
instead of linux/stat.h.



Issue: #7304
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant