Merge "Fix the stack-protector test for x86/x86-64."

This commit is contained in:
Elliott Hughes 2016-04-02 04:01:54 +00:00 committed by Gerrit Code Review
commit 2152a8ca35
1 changed files with 9 additions and 2 deletions

View File

@ -19,6 +19,13 @@ __attribute__((noinline)) void modify_stack_protector_test() {
char buf[128]; char buf[128];
// We can't use memset here because it's fortified, and we want to test // We can't use memset here because it's fortified, and we want to test
// the line of defense *after* that. // the line of defense *after* that.
char* p = buf; // Without volatile, the generic x86/x86-64 targets don't write to the stack.
while ((p - buf) < static_cast<int>(sizeof(buf) + sizeof(void*))) *p++ = '\0'; volatile char* p = buf;
int size = static_cast<int>(sizeof(buf) + 1);
#if __x86_64__
// The generic x86-64 target leaves an 8-byte gap between `buf` and the stack guard.
// We only need to corrupt one byte though.
size += 8;
#endif
while ((p - buf) < size) *p++ = '\0';
} }