-
Notifications
You must be signed in to change notification settings - Fork 15
feat(library-config): support windows memory file #1262
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
base: main
Are you sure you want to change the base?
Conversation
Implement a memfd-like for Windows to store in-memory the tracer configuration. It relies on Windows API to create in-memory file that can be shared and accessed by other processes.
BenchmarksComparisonBenchmark execution time: 2025-10-09 09:11:49 Comparing candidate commit 57a4e3d in PR branch Found 2 performance improvements and 0 performance regressions! Performance is the same for 51 metrics, 2 unstable metrics. scenario:credit_card/is_card_number/378282246310005
CandidateCandidate benchmark detailsGroup 1
Group 2
Group 3
Group 4
Group 5
Group 6
Group 7
Group 8
Group 9
Group 10
Group 11
Group 12
Group 13
Group 14
Group 15
BaselineOmitted due to size. |
Codecov Report❌ Patch coverage is Additional details and impacted files@@ Coverage Diff @@
## main #1262 +/- ##
==========================================
- Coverage 71.85% 71.80% -0.05%
==========================================
Files 356 356
Lines 56685 56692 +7
==========================================
- Hits 40731 40709 -22
- Misses 15954 15983 +29
🚀 New features to boost your workflow:
|
Artifact Size Benchmark Reportaarch64-alpine-linux-musl
aarch64-unknown-linux-gnu
libdatadog-x64-windows
libdatadog-x86-windows
x86_64-alpine-linux-musl
x86_64-unknown-linux-gnu
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I might have missed it, but do we have test running in CI for that ?
nope |
) | ||
.context("failed to create a memory file mapping")?; | ||
|
||
let addr = MapViewOfFile(handle, FILE_MAP_WRITE, 0, 0, buf.len()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not a windows dev, but if you are writing a null byte down below on line 173, shouldn't this be buf.len() + 1
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
+1
} | ||
|
||
// EEEEEEEEEHHHH can this be outside of `unsafe`? | ||
let dest = addr.Value as *mut u8; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Casting to a pointer is safe, but actually using it (like as in copy_nonoverlapping
) is unsafe. In practice though, pointer casting gets put into the unsafe code since, how else do you know the pointer is safe to use lol
What does this PR do?
Implement a memfd-like for Windows to store in-memory the tracer configuration. It relies on Windows API to create in-memory file that can be shared and accessed by other processes.
Main difference with the linux implementation is the anonymous file format:
datadog-tracer-info-<PID>
.Motivation
@raphaelgavache and supporting service renaming on Windows.
How to test the change?
Boot a windows VM. Compile this code:
writer
reader
Expected result:
