mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-17 05:52:44 +01:00
native/backtrace: improve print capabilitys and test
This commit is contained in:
parent
9f51daeb53
commit
37627ce2b8
@ -16,20 +16,44 @@
|
||||
#include <execinfo.h>
|
||||
#include <stddef.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "backtrace.h"
|
||||
|
||||
void backtrace_print(void)
|
||||
{
|
||||
void *array[BACKTRACE_SIZE + 1];
|
||||
size_t size;
|
||||
int size;
|
||||
|
||||
size = backtrace(array, BACKTRACE_SIZE + 1);
|
||||
|
||||
/* skip above line's return address and start with 1 */
|
||||
for (size_t i = 1; i < size; i++) {
|
||||
for (int i = 1; i < size; i++) {
|
||||
printf("%p\n", array[i]);
|
||||
}
|
||||
}
|
||||
|
||||
void backtrace_print_symbols(void)
|
||||
{
|
||||
void *array[BACKTRACE_SIZE + 1];
|
||||
int size;
|
||||
|
||||
size = backtrace(array, BACKTRACE_SIZE + 1);
|
||||
|
||||
char ** symbols = backtrace_symbols(array, size);
|
||||
|
||||
/* skip above line's return address and start with 1 */
|
||||
for (int i = 1; i < size; i++) {
|
||||
printf("%s\n", symbols[i]);
|
||||
}
|
||||
free(symbols);
|
||||
}
|
||||
|
||||
int backtrace_len(void)
|
||||
{
|
||||
void *array[BACKTRACE_SIZE + 1];
|
||||
|
||||
return backtrace(array, BACKTRACE_SIZE + 1) - 1;
|
||||
}
|
||||
|
||||
/** @} */
|
||||
|
@ -36,11 +36,23 @@ extern "C" {
|
||||
#endif
|
||||
|
||||
/**
|
||||
* @brief Print the last @ref BACKTRACE_SIZE return addresses from call of this
|
||||
* @brief Print up to the last @ref BACKTRACE_SIZE return addresses from call of this
|
||||
* function
|
||||
*/
|
||||
void backtrace_print(void);
|
||||
|
||||
/**
|
||||
* @brief Print up to the last @ref BACKTRACE_SIZE symbol_names from call of this
|
||||
* function
|
||||
*/
|
||||
void backtrace_print_symbols(void);
|
||||
|
||||
/**
|
||||
* @brief get the number of stack frames that are printed by print or print_symbols
|
||||
*
|
||||
*/
|
||||
int backtrace_len(void);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
@ -24,7 +24,10 @@
|
||||
|
||||
int main(void)
|
||||
{
|
||||
printf("BACKTRACE_SIZE: %u\n", BACKTRACE_SIZE);
|
||||
printf("BACKTRACE_SIZE: %d\n", backtrace_len());
|
||||
printf("\n## backtrace_print: print addresses\n");
|
||||
backtrace_print();
|
||||
printf("\n## backtrace_print_symbols: print symbol information\n");
|
||||
backtrace_print_symbols();
|
||||
return 0;
|
||||
}
|
||||
|
@ -13,8 +13,12 @@ from testrunner import run
|
||||
def testfunc(child):
|
||||
child.expect(r"BACKTRACE_SIZE: (\d+)\r\n")
|
||||
trace_size = int(child.match.group(1))
|
||||
child.expect("backtrace_print:")
|
||||
for i in range(trace_size):
|
||||
child.expect(r"0x[0-9a-f]+")
|
||||
child.expect("backtrace_print_symbols:")
|
||||
for i in range(trace_size):
|
||||
child.expect(r".*")
|
||||
|
||||
print("All tests successful")
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user