2016-12-04 20:55:33 +01:00
|
|
|
/*
|
|
|
|
* 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>
|
|
|
|
|
2019-11-21 10:47:08 +01:00
|
|
|
__attribute__((weak)) void
|
|
|
|
_prevent_memset_lto(void *const s, int c, const size_t n)
|
|
|
|
{
|
|
|
|
(void) s;
|
|
|
|
(void) c;
|
|
|
|
(void) n;
|
|
|
|
}
|
|
|
|
|
2016-12-04 20:55:33 +01:00
|
|
|
void test_func(void)
|
|
|
|
{
|
|
|
|
char buf[16];
|
|
|
|
|
2017-10-20 11:43:29 +02:00
|
|
|
/* clang will detect the buffer overflow
|
|
|
|
* and throw an error if we use `buf` directly */
|
|
|
|
void *buffer_to_confuse_compiler = buf;
|
|
|
|
|
2016-12-04 20:55:33 +01:00
|
|
|
/* cppcheck-suppress bufferAccessOutOfBounds
|
|
|
|
* (reason: deliberately overflowing stack) */
|
2017-10-20 11:43:29 +02:00
|
|
|
memset(buffer_to_confuse_compiler, 0, 32);
|
2019-11-21 10:47:08 +01:00
|
|
|
|
|
|
|
/* prevent that memset call is optimized out by LTO */
|
|
|
|
_prevent_memset_lto(buf, 0, 32);
|
2016-12-04 20:55:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
puts("calling stack corruption function");
|
|
|
|
|
|
|
|
test_func();
|
|
|
|
|
|
|
|
puts("back to main");
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|