-
Notifications
You must be signed in to change notification settings - Fork 254
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
Attempt to fix ARM32 Windows #685
base: master
Are you sure you want to change the base?
Conversation
@bdbai I am curious what use the 32-bit Windows Arm target is being put to? It is a target unmaintained by the OS vendor... as in, the entire OS is unmaintained for that target... and no one has signed up to maintain the target on the Rust end. As for the CONTEXT structure, the std definition provided that you linked to is an uninhabited type (no variants), so it cannot actually be interacted with in the conventional sense... hmm... |
Some examples running Windows ARM32: Surface RT, Windows Phone and Windows 10 IoT Core
In std the CONTEXT structure for ARM is only used in pointer form (like https://github.com/rust-lang/rust/blob/41f2f5c0b7d5fb68685030edc62e66a21cae38ef/library/std/src/sys/pal/windows/c/windows_sys.rs#L65) so we didn't bother to fill up all fields inside but instead treat it as an opaque FFI type. However in backtrace we are actually reading the values inside so the complete definition is required. |
@bdbai Yes, we don't really have support for any of those targets except for their 64-bit versions. But I wasn't really asking you to quote OS names at me, I'm curious what you actually use it for. |
@workingjubilee Personally I am writing UWP apps (https://github.com/YtFlow/YtFlowApp) specifically targeting both desktop and mobile as some users including me are still using Windows Phone. The core part is written in Rust hence needs to cross compile to |
I see! @ChrisDenton You lost the bet, I suppose? @bdbai Do you have a citation for the 32-bit Arm Windows target CONTEXT definition? It is, for perhaps obvious reasons, hard to find on Microsoft's documentation. |
fyi the definitions are migrated from |
Copying these from Windows SDK (10.0.22621.0): //
// Specify the number of breakpoints and watchpoints that the OS
// will track. Architecturally, ARM supports up to 16. In practice,
// however, almost no one implements more than 4 of each.
//
#define ARM_MAX_BREAKPOINTS 8
#define ARM_MAX_WATCHPOINTS 1
//
// Context Frame
//
// This frame has a several purposes: 1) it is used as an argument to
// NtContinue, 2) it is used to constuct a call frame for APC delivery,
// and 3) it is used in the user level thread creation routines.
//
//
// The flags field within this record controls the contents of a CONTEXT
// record.
//
// If the context record is used as an input parameter, then for each
// portion of the context record controlled by a flag whose value is
// set, it is assumed that that portion of the context record contains
// valid context. If the context record is being used to modify a threads
// context, then only that portion of the threads context is modified.
//
// If the context record is used as an output parameter to capture the
// context of a thread, then only those portions of the thread's context
// corresponding to set flags will be returned.
//
// CONTEXT_CONTROL specifies Sp, Lr, Pc, and Cpsr
//
// CONTEXT_INTEGER specifies R0-R12
//
// CONTEXT_FLOATING_POINT specifies Q0-Q15 / D0-D31 / S0-S31
//
// CONTEXT_DEBUG_REGISTERS specifies up to 16 of DBGBVR, DBGBCR, DBGWVR,
// DBGWCR.
//
typedef struct _NEON128 {
ULONGLONG Low;
LONGLONG High;
} NEON128, *PNEON128;
typedef struct DECLSPEC_ALIGN(8) DECLSPEC_NOINITALL _CONTEXT {
//
// Control flags.
//
DWORD ContextFlags;
//
// Integer registers
//
DWORD R0;
DWORD R1;
DWORD R2;
DWORD R3;
DWORD R4;
DWORD R5;
DWORD R6;
DWORD R7;
DWORD R8;
DWORD R9;
DWORD R10;
DWORD R11;
DWORD R12;
//
// Control Registers
//
DWORD Sp;
DWORD Lr;
DWORD Pc;
DWORD Cpsr;
//
// Floating Point/NEON Registers
//
DWORD Fpscr;
DWORD Padding;
union {
NEON128 Q[16];
ULONGLONG D[32];
DWORD S[32];
} DUMMYUNIONNAME;
//
// Debug registers
//
DWORD Bvr[ARM_MAX_BREAKPOINTS];
DWORD Bcr[ARM_MAX_BREAKPOINTS];
DWORD Wvr[ARM_MAX_WATCHPOINTS];
DWORD Wcr[ARM_MAX_WATCHPOINTS];
DWORD Padding2[2];
} CONTEXT, *PCONTEXT; |
src/windows_sys.rs
Outdated
|
||
#[repr(C)] | ||
#[derive(Clone, Copy)] | ||
pub struct CONTEXT_u([u64; 32]); |
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.
This should be an actual union that matches the anon union declaration as exactly as possible. The name is unimportant, so let us call it CONTEXT_FloatRegs
.
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.
Fixed in d468f71
src/windows_sys.rs
Outdated
pub R10: u32, | ||
pub R11: u32, | ||
pub R12: u32, | ||
pub Sp: u32, |
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.
pub Sp: u32, | |
// Control registers | |
pub Sp: u32, |
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.
Fixed in d468f71
src/windows_sys.rs
Outdated
pub Lr: u32, | ||
pub Pc: u32, | ||
pub Cpsr: u32, | ||
pub Fpsrc: u32, |
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.
pub Fpsrc: u32, | |
// Floating-point registers | |
pub Fpsrc: u32, |
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.
Fixed in d468f71
src/windows_sys.rs
Outdated
pub Fpsrc: u32, | ||
pub Padding: u32, | ||
pub u: CONTEXT_u, | ||
pub Bvr: [u32; ARM_MAX_BREAKPOINTS], |
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.
pub Bvr: [u32; ARM_MAX_BREAKPOINTS], | |
// Debug registers | |
pub Bvr: [u32; ARM_MAX_BREAKPOINTS], |
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.
Fixed in d468f71
Thank you. I suppose we will have to think a little on where exactly to put the shim filling, hm. |
d468f71
to
c88b77e
Compare
…sDenton Add UWP (msvc) target support page - Added Platform Support page for `x86_64-uwp-windows-msvc`, `i686-uwp-windows-msvc`, `thumbv7a-uwp-windows-msvc` and `aarch64-uwp-windows-msvc` - Adding myself as a maintainer - Removing the ticks for `thumbv7a-pc-windows-msvc` and `thumbv7a-uwp-windows-msvc` as they do not currently build due to rust-lang#134565 and rust-lang/backtrace-rs#685 - Fixed a few minor issues to let most of the UWP targets compile - Happy new year to all! r? jieyouxu
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 would prefer to see this code in a separate .rs
file that is then pulled in via include!
or include_str!
as necessary.
src/windows_sys.rs
Outdated
cfg_if::cfg_if! { | ||
if #[cfg(target_arch = "arm")] { |
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.
This should not need cfg_if
, though it might require moving the #[cfg(target_arch = "arm")]
onto conflicting structs maybe?
cfg_if::cfg_if! { | |
if #[cfg(target_arch = "arm")] { |
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 just put the cfg guard in windows_sys.rs
for the whole include!
directive. Looks like there's nothing in conflict.
cc @ChrisDenton |
Rollup merge of rust-lang#134996 - bdbai:uwp-support, r=jieyouxu,ChrisDenton Add UWP (msvc) target support page - Added Platform Support page for `x86_64-uwp-windows-msvc`, `i686-uwp-windows-msvc`, `thumbv7a-uwp-windows-msvc` and `aarch64-uwp-windows-msvc` - Adding myself as a maintainer - Removing the ticks for `thumbv7a-pc-windows-msvc` and `thumbv7a-uwp-windows-msvc` as they do not currently build due to rust-lang#134565 and rust-lang/backtrace-rs#685 - Fixed a few minor issues to let most of the UWP targets compile - Happy new year to all! r? jieyouxu
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.
This look right to me, thanks! Sorry for the delay, still catching up from the holidays.
Currently
thumbv7a-pc-windows-msvc
andthumbv7a-pc-windows-msvc
fails to build due to lack of a few symbols generated bywindows-targets
. Asbacktrace
being a dependency of Ruststd
,build-std
feature targeting these platforms also fails. The fix here is definitely not a good idea which is modifying a generated file, but it shows the possibility to have the issue solved at least to unblockbuild-std
on these platforms.This was how I verified it using
1.85.0-nightly (9e136a30a 2024-12-19)
toolchain:which produced the following output:
Any input on better ways to handle this will be appreciated! In Rust std I can see it's solved here https://github.com/rust-lang/rust/blob/8a1f8039a7ded79d3d4fe97b110016d89f2b11e2/src/tools/generate-windows-sys/src/main.rs#L8 . Not sure if we can apply something similar here.
Xref: #572 #634