Fix segfault on probestack with dynamic alloca.
This commit is contained in:
parent
28daccd915
commit
56293ad7c7
@ -64,6 +64,8 @@ pub unsafe extern fn __rust_probestack() {
|
|||||||
// bytes pushed on the stack orginally with our return address. Using
|
// bytes pushed on the stack orginally with our return address. Using
|
||||||
// `8(%rsp)` simulates us testing the stack pointer in the caller's
|
// `8(%rsp)` simulates us testing the stack pointer in the caller's
|
||||||
// context.
|
// context.
|
||||||
|
cmp $$0x1000,%r11
|
||||||
|
jna 3f
|
||||||
2:
|
2:
|
||||||
sub $$0x1000,%rsp
|
sub $$0x1000,%rsp
|
||||||
test %rsp,8(%rsp)
|
test %rsp,8(%rsp)
|
||||||
@ -71,6 +73,7 @@ pub unsafe extern fn __rust_probestack() {
|
|||||||
cmp $$0x1000,%r11
|
cmp $$0x1000,%r11
|
||||||
ja 2b
|
ja 2b
|
||||||
|
|
||||||
|
3:
|
||||||
// Finish up the last remaining stack space requested, getting the last
|
// Finish up the last remaining stack space requested, getting the last
|
||||||
// bits out of r11
|
// bits out of r11
|
||||||
sub %r11,%rsp
|
sub %r11,%rsp
|
||||||
@ -98,6 +101,9 @@ pub unsafe extern fn __rust_probestack() {
|
|||||||
asm!("
|
asm!("
|
||||||
push %ecx
|
push %ecx
|
||||||
mov %eax,%ecx
|
mov %eax,%ecx
|
||||||
|
|
||||||
|
cmp $$0x1000,%ecx
|
||||||
|
jna 3f
|
||||||
2:
|
2:
|
||||||
sub $$0x1000,%esp
|
sub $$0x1000,%esp
|
||||||
test %esp,8(%esp)
|
test %esp,8(%esp)
|
||||||
@ -105,6 +111,7 @@ pub unsafe extern fn __rust_probestack() {
|
|||||||
cmp $$0x1000,%ecx
|
cmp $$0x1000,%ecx
|
||||||
ja 2b
|
ja 2b
|
||||||
|
|
||||||
|
3:
|
||||||
sub %ecx,%esp
|
sub %ecx,%esp
|
||||||
test %esp,8(%esp)
|
test %esp,8(%esp)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user