-
Notifications
You must be signed in to change notification settings - Fork 13.2k
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Implement Win64 eh_personality natively. #27210
Conversation
r? @brson (rust_highfive has picked a reviewer for you, use r? to override) |
I am not quite happy about the way |
☔ The latest upstream changes (presumably #27176) made this pull request unmergeable. Please resolve the merge conflicts. |
[libstd implementation](../std/rt/unwind/index.html) for more | ||
The second and third of these functions, `eh_personality` and `rust_eh_unwind_resume`, | ||
are used by the failure mechanisms of the compiler. These are often mapped to GCC's | ||
personality function and libgcc's `_Unwind_Resume` respectively |
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.
Wording of this sentence somehow seems to suggest GCC personality function and _Unwind_Resume
come from two different locations, while in practice they both come from libgcc
.
Nice work @vadimcn! |
// [24:27] = type | ||
// [0:23] = magic | ||
const ETYPE: DWORD = 0b1110_u32 << 28; | ||
const MAGIC: DWORD = 0x525354; // "RST" |
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.
RST
also refers to reStructuredText
. How about we use .rs
here?
const MAGIC: DWORD = 0x2e7273; // ".rs"
Epic patch. |
502a189
to
59d5b19
Compare
Addressed comments and rebased on top of master. r? |
pub mod imp; | ||
#[cfg(not(target_env = "msvc"))] #[path = "gcc.rs"] #[doc(hidden)] | ||
|
||
// x86-pc-windows-gnu and all others |
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.
s/x86/i686/
Works now. r? |
@bors: r+ |
📌 Commit e493027 has been approved by |
⌛ Testing commit e493027 with merge 2c60a05... |
💔 Test failed - auto-linux-64-x-android-t |
Seems legit:
On Sun, Aug 2, 2015 at 12:08 PM, bors notifications@github.com wrote:
|
Fixed. Let's try again? |
@bors: r+ 96d1db2 |
⌛ Testing commit 96d1db2 with merge d99b3c5... |
💔 Test failed - auto-mac-64-opt |
@bors: retry On Mon, Aug 3, 2015 at 10:37 AM, bors notifications@github.com wrote:
|
After this change, the only remaining symbol we are pulling from libgcc on Win64 is `__chkstk_ms` - the stack probing routine.
⌛ Testing commit 96d1db2 with merge ceded6a... |
🎊 |
This commit leverages the runtime support for DWARF exception info added in rust-lang#27210 to enable unwinding by default on 64-bit MSVC. This also additionally adds a few minor fixes here and there in the test harness and such to get `make check` entirely passing on 64-bit MSVC: * The invocation of `maketest.py` now works with spaces/quotes in CC * debuginfo tests are disabled on MSVC * A link error for librustc was hacked around (see rust-lang#27438)
This commit leverages the runtime support for DWARF exception info added in rust-lang#27210 to enable unwinding by default on 64-bit MSVC. This also additionally adds a few minor fixes here and there in the test harness and such to get `make check` entirely passing on 64-bit MSVC: * The invocation of `maketest.py` now works with spaces/quotes in CC * debuginfo tests are disabled on MSVC * A link error for librustc was hacked around (see rust-lang#27438)
After this change, the only remaining symbol we are pulling from libgcc on Win64 is
__chkstk_ms
- the stack probing routine.