diff options
| author | Jordan Rhee <jordanrh@microsoft.com> | 2018-06-26 09:44:19 -0700 |
|---|---|---|
| committer | Jordan Rhee <jordanrh@microsoft.com> | 2018-09-04 14:54:37 -0700 |
| commit | f7fa67cea13efdacfc82389f6f592bb4bda86a2e (patch) | |
| tree | 733f114a89b99f464534a1cfdc76fda72f512ef7 /src/libstd | |
| parent | 1c2e17f4e3a2070a7f703f51e29c1c388ef703b6 (diff) | |
| download | rust-f7fa67cea13efdacfc82389f6f592bb4bda86a2e.tar.gz rust-f7fa67cea13efdacfc82389f6f592bb4bda86a2e.zip | |
Add target thumbv7a-pc-windows-msvc
Diffstat (limited to 'src/libstd')
| -rw-r--r-- | src/libstd/sys/windows/backtrace/mod.rs | 22 | ||||
| -rw-r--r-- | src/libstd/sys/windows/c.rs | 41 |
2 files changed, 62 insertions, 1 deletions
diff --git a/src/libstd/sys/windows/backtrace/mod.rs b/src/libstd/sys/windows/backtrace/mod.rs index 70de4a6f2b6..cfa9e7b7c25 100644 --- a/src/libstd/sys/windows/backtrace/mod.rs +++ b/src/libstd/sys/windows/backtrace/mod.rs @@ -248,6 +248,17 @@ impl StackFrame for c::STACKFRAME_EX { c::IMAGE_FILE_MACHINE_AMD64 } + #[cfg(target_arch = "arm")] + fn init(&mut self, ctx: &c::CONTEXT) -> c::DWORD { + self.AddrPC.Offset = ctx.Pc as u64; + self.AddrPC.Mode = c::ADDRESS_MODE::AddrModeFlat; + self.AddrStack.Offset = ctx.Sp as u64; + self.AddrStack.Mode = c::ADDRESS_MODE::AddrModeFlat; + self.AddrFrame.Offset = ctx.R11 as u64; + self.AddrFrame.Mode = c::ADDRESS_MODE::AddrModeFlat; + c::IMAGE_FILE_MACHINE_ARMNT + } + #[cfg(target_arch = "aarch64")] fn init(&mut self, ctx: &c::CONTEXT) -> c::DWORD { self.AddrPC.Offset = ctx.Pc as u64; @@ -291,6 +302,17 @@ impl StackFrame for c::STACKFRAME64 { c::IMAGE_FILE_MACHINE_AMD64 } + #[cfg(target_arch = "arm")] + fn init(&mut self, ctx: &c::CONTEXT) -> c::DWORD { + self.AddrPC.Offset = ctx.Pc as u64; + self.AddrPC.Mode = c::ADDRESS_MODE::AddrModeFlat; + self.AddrStack.Offset = ctx.Sp as u64; + self.AddrStack.Mode = c::ADDRESS_MODE::AddrModeFlat; + self.AddrFrame.Offset = ctx.R11 as u64; + self.AddrFrame.Mode = c::ADDRESS_MODE::AddrModeFlat; + c::IMAGE_FILE_MACHINE_ARMNT + } + #[cfg(target_arch = "aarch64")] fn init(&mut self, ctx: &c::CONTEXT) -> c::DWORD { self.AddrPC.Offset = ctx.Pc as u64; diff --git a/src/libstd/sys/windows/c.rs b/src/libstd/sys/windows/c.rs index 4c64322a6dc..dc0eb244155 100644 --- a/src/libstd/sys/windows/c.rs +++ b/src/libstd/sys/windows/c.rs @@ -114,6 +114,11 @@ pub const SECURITY_SQOS_PRESENT: DWORD = 0x00100000; pub const FIONBIO: c_ulong = 0x8004667e; +#[cfg(target_arch = "arm")] +const ARM_MAX_BREAKPOINTS: usize = 8; +#[cfg(target_arch = "arm")] +const ARM_MAX_WATCHPOINTS: usize = 1; + #[repr(C)] #[derive(Copy)] pub struct WIN32_FIND_DATAW { @@ -283,6 +288,9 @@ pub const IMAGE_FILE_MACHINE_AMD64: DWORD = 0x8664; #[cfg(target_arch = "aarch64")] #[cfg(feature = "backtrace")] pub const IMAGE_FILE_MACHINE_ARM64: DWORD = 0xAA64; +#[cfg(target_arch = "arm")] +#[cfg(feature = "backtrace")] +pub const IMAGE_FILE_MACHINE_ARMNT: DWORD = 0x01c4; pub const EXCEPTION_CONTINUE_SEARCH: LONG = 0; pub const EXCEPTION_STACK_OVERFLOW: DWORD = 0xc00000fd; @@ -789,12 +797,43 @@ pub struct FLOATING_SAVE_AREA { _Dummy: [u8; 512] // FIXME: Fill this out } +#[cfg(target_arch = "arm")] +#[repr(C)] +pub struct CONTEXT { + pub ContextFlags: ULONG, + pub R0: ULONG, + pub R1: ULONG, + pub R2: ULONG, + pub R3: ULONG, + pub R4: ULONG, + pub R5: ULONG, + pub R6: ULONG, + pub R7: ULONG, + pub R8: ULONG, + pub R9: ULONG, + pub R10: ULONG, + pub R11: ULONG, + pub R12: ULONG, + pub Sp: ULONG, + pub Lr: ULONG, + pub Pc: ULONG, + pub Cpsr: ULONG, + pub Fpscr: ULONG, + pub Padding: ULONG, + pub D: [u64; 32], + pub Bvr: [ULONG; ARM_MAX_BREAKPOINTS], + pub Bcr: [ULONG; ARM_MAX_BREAKPOINTS], + pub Wvr: [ULONG; ARM_MAX_WATCHPOINTS], + pub Wcr: [ULONG; ARM_MAX_WATCHPOINTS], + pub Padding2: [ULONG; 2] +} + // FIXME(#43348): This structure is used for backtrace only, and a fake // definition is provided here only to allow rustdoc to pass type-check. This // will not appear in the final documentation. This should be also defined for // other architectures supported by Windows such as ARM, and for historical // interest, maybe MIPS and PowerPC as well. -#[cfg(all(rustdoc, not(any(target_arch = "x86_64", target_arch = "x86", target_arch = "aarch64"))))] +#[cfg(all(rustdoc, not(any(target_arch = "x86_64", target_arch = "x86", target_arch = "aarch64", target_arch = "arm"))))] pub enum CONTEXT {} #[cfg(target_arch = "aarch64")] |
