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

fix: suppress clang -Wdeprecated-declarations in libuv #4486

Merged
merged 1 commit into from
Aug 14, 2024

Conversation

codebytere
Copy link
Contributor

Electron builds on Windows with clang, not msvc, and likewise hits this issue without this extra handling. This would allow us to remove a patch

@bnoordhuis
Copy link
Member

Do we actually need to call GetVersionEx? That's the fallback for when RtlGetVersion isn't available but it always is nowadays, isn't it? (Windows Vista and up?)

@saghul
Copy link
Member

saghul commented Aug 2, 2024

Actually I think you're right, we should assume it's there these days!

@codebytere
Copy link
Contributor Author

@saghul @bnoordhuis alright - shall i go ahead and just remove GetVersionEx then?

@saghul
Copy link
Member

saghul commented Aug 2, 2024

I'd say so yeah!

@codebytere codebytere force-pushed the deprecated-win-call-clang branch from c18b58e to 9652758 Compare August 2, 2024 13:01
@codebytere
Copy link
Contributor Author

@saghul @bnoordhuis done!

@codebytere codebytere force-pushed the deprecated-win-call-clang branch from 9652758 to ae5c347 Compare August 2, 2024 13:03
@saghul
Copy link
Member

saghul commented Aug 2, 2024

Since we can call the API directly does it still make sense to load the symbol dynamically?

@codebytere
Copy link
Contributor Author

@saghul i was going to ask that actually 😅 personal thought is no, and am happy to refactor that appropriately!

@saghul
Copy link
Member

saghul commented Aug 2, 2024

Let's do it yeah 🙌

@bnoordhuis
Copy link
Member

Since we can call the API directly does it still make sense to load the symbol dynamically?

Yes, because RtlGetVersion is from ntdll.dll, which we don't link against, we GetModuleHandle it. I'd say this PR is good to merge.

@vtjnash
Copy link
Member

vtjnash commented Aug 9, 2024

Using GetModuleHandle is exactly the same as saying that we link against it. In fact, I think everything must link against ntdll (IIUC, it is the only address range allowed to make syscalls)

@bnoordhuis
Copy link
Member

Link as in compile-time link. Is ntdll.dll always compile-time linked? Even if, the definition of RtlGetVersion is in ntddk.h or wdm.h so it's probably not available without installing the DDK; e.g. mingw doesn't have it in its headers.

@vtjnash
Copy link
Member

vtjnash commented Aug 10, 2024

Yes, the GetModuleHandle function only returns compile-time linked modules. It is similar to specifying RTLD_DEFAULT, except that on Windows you always have to give the name of the library to search. I can see it is in ddk/ntddk.h in mingw (which might not be quite the right spot according to the function documentation, but close enough), though being missing from the headers has never been an obstacle to libuv before

@santigimeno
Copy link
Member

So, can this be merged?

@santigimeno santigimeno merged commit 31d9165 into libuv:v1.x Aug 14, 2024
17 checks passed
@santigimeno
Copy link
Member

By looking at the comments again it seems this PR is good to go. I'll go ahead and merge so it can make it into the release. Please, let me know if it needs to be reverted

codebytere added a commit to electron/electron that referenced this pull request Jan 23, 2025
codebytere added a commit to electron/electron that referenced this pull request Jan 28, 2025
codebytere added a commit to electron/electron that referenced this pull request Jan 28, 2025
jkleinsc pushed a commit to electron/electron that referenced this pull request Jan 29, 2025
* chore: bump node in DEPS to v22.13.1

* chore: fixup GN build file

* nodejs/node#55529
* nodejs/node#55798
* nodejs/node#55530

* module: simplify --inspect-brk handling

nodejs/node#55679

* src: fix outdated js2c.cc references

nodejs/node#56133

* crypto: include openssl/rand.h explicitly

nodejs/node#55425

* build: use variable for crypto dep path

nodejs/node#55928

* crypto: fix RSA_PKCS1_PADDING error message

nodejs/node#55629

* build: use variable for simdutf path

nodejs/node#56196

* test,crypto: make crypto tests work with BoringSSL

nodejs/node#55491

* fix: suppress clang -Wdeprecated-declarations in libuv

libuv/libuv#4486

* deps: update libuv to 1.49.1

nodejs/node#55114

* test: make test-node-output-v8-warning more flexible

nodejs/node#55401

* [v22.x] Revert "v8: enable maglev on supported architectures"

nodejs/node#54384

* fix: potential WIN32_LEAN_AND_MEAN redefinition

c-ares/c-ares#869

* deps: update nghttp2 to 1.64.0

nodejs/node#55559

* src: provide workaround for container-overflow

nodejs/node#55591

* build: use variable for simdutf path

nodejs/node#56196

* chore: fixup patch indices

* fixup! module: simplify --inspect-brk handling

* lib: fix fs.readdir recursive async

nodejs/node#56041

* lib: avoid excluding symlinks in recursive fs.readdir with filetypes

nodejs/node#55714

This doesn't currently play well with ASAR - this should be fixed in a follow up

* test: disable CJS permission test for config.main

This has diverged as a result of our revert of
src,lb: reducing C++ calls of esm legacy main resolve

* fixup! lib: fix fs.readdir recursive async

* deps: update libuv to 1.49.1

nodejs/node#55114

---------

Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com>
Co-authored-by: Shelley Vohr <[email protected]>
codebytere added a commit to electron/electron that referenced this pull request Feb 3, 2025
codebytere added a commit to electron/electron that referenced this pull request Feb 10, 2025
codebytere added a commit to electron/electron that referenced this pull request Feb 10, 2025
codebytere added a commit to electron/electron that referenced this pull request Feb 14, 2025
codebytere added a commit to electron/electron that referenced this pull request Feb 14, 2025
* chore: bump node in DEPS to v22.13.0

* chore: bump node in DEPS to v22.13.1

* src: move evp stuff to ncrypto

nodejs/node#54911

* crypto: add Date fields for validTo and validFrom

nodejs/node#54159

* module: fix discrepancy between .ts and .js

nodejs/node#54461

* esm: do not interpret "main" as a URL

nodejs/node#55003

* src: modernize likely/unlikely hints

nodejs/node#55155

* chore: update patch indices

* crypto: add validFromDate and validToDate fields to X509Certificate

nodejs/node#54159

* chore: fixup perfetto patch

* fix: clang warning in simdjson

* src: add receiver to fast api callback methods

nodejs/node#54408

* chore: fixup revert patch

* fixup! esm: do not interpret "main" as a URL

* fixup! crypto: add Date fields for validTo and validFrom

* fix: move ArrayBuffer test patch

* src: fixup Error.stackTraceLimit during snapshot building

nodejs/node#55121

* fix: bad rebase

* chore: fixup amaro

* chore: address feedback from review

* src: revert filesystem::path changes

nodejs/node#55015

* chore: fixup GN build file

* nodejs/node#55529
* nodejs/node#55798
* nodejs/node#55530

* module: simplify --inspect-brk handling

nodejs/node#55679

* src: fix outdated js2c.cc references

nodejs/node#56133

* crypto: include openssl/rand.h explicitly

nodejs/node#55425

* build: use variable for crypto dep path

nodejs/node#55928

* crypto: fix RSA_PKCS1_PADDING error message

nodejs/node#55629

* build: use variable for simdutf path

nodejs/node#56196

* test,crypto: make crypto tests work with BoringSSL

nodejs/node#55491

* fix: suppress clang -Wdeprecated-declarations in libuv

libuv/libuv#4486

* deps: update libuv to 1.49.1

nodejs/node#55114

* test: make test-node-output-v8-warning more flexible

nodejs/node#55401

* [v22.x] Revert "v8: enable maglev on supported architectures"

nodejs/node#54384

* fix: potential WIN32_LEAN_AND_MEAN redefinition

c-ares/c-ares#869

* deps: update nghttp2 to 1.64.0

nodejs/node#55559

* src: provide workaround for container-overflow

nodejs/node#55591

* build: use variable for simdutf path

nodejs/node#56196

* chore: fixup patch indices

* fixup! module: simplify --inspect-brk handling

* lib: fix fs.readdir recursive async

nodejs/node#56041

* lib: avoid excluding symlinks in recursive fs.readdir with filetypes

nodejs/node#55714

This doesn't currently play well with ASAR - this should be fixed in a follow up

* test: disable CJS permission test for config.main

This has diverged as a result of our revert of
src,lb: reducing C++ calls of esm legacy main resolve

* fixup! lib: fix fs.readdir recursive async

* deps: update libuv to 1.49.1

nodejs/node#55114

---------

Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com>
Co-authored-by: Shelley Vohr <[email protected]>
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.

5 participants