mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
4710701405
On macOS using Apple LLVM version 9.0.0 this test would not compile due to clang detecting the buffer overflow. Since this test is all about having a buffer overflow, I tricked clang into not detecting this anymore. This loosely relates to #6473.
50 lines
992 B
C
50 lines
992 B
C
/*
|
|
* Copyright (C) 2016 Kaspar Schleiser <kaspar@schleiser.de>
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup tests
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief ssp test application
|
|
*
|
|
* This test should crash badly when *not* using the ssp module, and panic if
|
|
* using it.
|
|
*
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
*
|
|
* @}
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
void test_func(void)
|
|
{
|
|
char buf[16];
|
|
|
|
/* clang will detect the buffer overflow
|
|
* and throw an error if we use `buf` directly */
|
|
void *buffer_to_confuse_compiler = buf;
|
|
|
|
/* cppcheck-suppress bufferAccessOutOfBounds
|
|
* (reason: deliberately overflowing stack) */
|
|
memset(buffer_to_confuse_compiler, 0, 32);
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
puts("calling stack corruption function");
|
|
|
|
test_func();
|
|
|
|
puts("back to main");
|
|
|
|
return 0;
|
|
}
|