trace: Share common implementation for TEST_FAIL and TEST_ALLOC_FAIL
Get rid of more or less duplicated implementation of backtrace matching for the two testing failure cases. Signed-off-by: Benjamin Berg <benjamin.berg@intel.com>
This commit is contained in:
parent
7d901dc7e7
commit
5545d995b3
2 changed files with 24 additions and 113 deletions
|
@ -667,8 +667,8 @@ int os_exec(const char *program, const char *arg, int wait_completion);
|
||||||
|
|
||||||
|
|
||||||
#if defined(WPA_TRACE_BFD) && defined(CONFIG_TESTING_OPTIONS)
|
#if defined(WPA_TRACE_BFD) && defined(CONFIG_TESTING_OPTIONS)
|
||||||
#define TEST_FAIL() testing_test_fail()
|
#define TEST_FAIL() testing_test_fail(false)
|
||||||
int testing_test_fail(void);
|
int testing_test_fail(bool is_alloc);
|
||||||
int testing_set_fail_pattern(bool is_alloc, char *patterns);
|
int testing_set_fail_pattern(bool is_alloc, char *patterns);
|
||||||
int testing_get_fail_pattern(bool is_alloc, char *buf, size_t buflen);
|
int testing_get_fail_pattern(bool is_alloc, char *buf, size_t buflen);
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -540,10 +540,10 @@ void * os_memdup(const void *src, size_t len)
|
||||||
#ifdef WPA_TRACE
|
#ifdef WPA_TRACE
|
||||||
|
|
||||||
#if defined(WPA_TRACE_BFD) && defined(CONFIG_TESTING_OPTIONS)
|
#if defined(WPA_TRACE_BFD) && defined(CONFIG_TESTING_OPTIONS)
|
||||||
static char wpa_trace_fail_func[256] = { 0 };
|
static char wpa_trace_fail_func[2][256] = { "", "" };
|
||||||
static unsigned int wpa_trace_fail_after;
|
static unsigned int wpa_trace_fail_after[2];
|
||||||
|
|
||||||
static int testing_fail_alloc(void)
|
int testing_test_fail(bool is_alloc)
|
||||||
{
|
{
|
||||||
const char *ignore_list[] = {
|
const char *ignore_list[] = {
|
||||||
__func__, "os_malloc", "os_zalloc", "os_calloc", "os_realloc",
|
__func__, "os_malloc", "os_zalloc", "os_calloc", "os_realloc",
|
||||||
|
@ -554,7 +554,9 @@ static int testing_fail_alloc(void)
|
||||||
char *pos, *next;
|
char *pos, *next;
|
||||||
int match;
|
int match;
|
||||||
|
|
||||||
if (!wpa_trace_fail_after)
|
is_alloc = !!is_alloc;
|
||||||
|
|
||||||
|
if (!wpa_trace_fail_after[is_alloc])
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
res = wpa_trace_calling_func(func, WPA_TRACE_LEN);
|
res = wpa_trace_calling_func(func, WPA_TRACE_LEN);
|
||||||
|
@ -566,7 +568,7 @@ static int testing_fail_alloc(void)
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
pos = wpa_trace_fail_func;
|
pos = wpa_trace_fail_func[is_alloc];
|
||||||
|
|
||||||
match = 0;
|
match = 0;
|
||||||
while (i < res) {
|
while (i < res) {
|
||||||
|
@ -606,82 +608,10 @@ static int testing_fail_alloc(void)
|
||||||
if (!match)
|
if (!match)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
wpa_trace_fail_after--;
|
wpa_trace_fail_after[is_alloc]--;
|
||||||
if (wpa_trace_fail_after == 0) {
|
if (wpa_trace_fail_after[is_alloc] == 0) {
|
||||||
wpa_printf(MSG_INFO, "TESTING: fail allocation at %s",
|
|
||||||
wpa_trace_fail_func);
|
|
||||||
for (i = 0; i < res; i++)
|
|
||||||
wpa_printf(MSG_INFO, "backtrace[%d] = %s",
|
|
||||||
(int) i, func[i]);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static char wpa_trace_test_fail_func[256] = { 0 };
|
|
||||||
static unsigned int wpa_trace_test_fail_after;
|
|
||||||
|
|
||||||
int testing_test_fail(void)
|
|
||||||
{
|
|
||||||
const char *func[WPA_TRACE_LEN];
|
|
||||||
size_t i, res, len;
|
|
||||||
char *pos, *next;
|
|
||||||
int match;
|
|
||||||
|
|
||||||
if (!wpa_trace_test_fail_after)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
res = wpa_trace_calling_func(func, WPA_TRACE_LEN);
|
|
||||||
i = 0;
|
|
||||||
if (i < res && os_strcmp(func[i], __func__) == 0)
|
|
||||||
i++;
|
|
||||||
|
|
||||||
pos = wpa_trace_test_fail_func;
|
|
||||||
|
|
||||||
match = 0;
|
|
||||||
while (i < res) {
|
|
||||||
int allow_skip = 1;
|
|
||||||
int maybe = 0;
|
|
||||||
|
|
||||||
if (*pos == '=') {
|
|
||||||
allow_skip = 0;
|
|
||||||
pos++;
|
|
||||||
} else if (*pos == '?') {
|
|
||||||
maybe = 1;
|
|
||||||
pos++;
|
|
||||||
}
|
|
||||||
next = os_strchr(pos, ';');
|
|
||||||
if (next)
|
|
||||||
len = next - pos;
|
|
||||||
else
|
|
||||||
len = os_strlen(pos);
|
|
||||||
if (os_memcmp(pos, func[i], len) != 0) {
|
|
||||||
if (maybe && next) {
|
|
||||||
pos = next + 1;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (allow_skip) {
|
|
||||||
i++;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (!next) {
|
|
||||||
match = 1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
pos = next + 1;
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
if (!match)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
wpa_trace_test_fail_after--;
|
|
||||||
if (wpa_trace_test_fail_after == 0) {
|
|
||||||
wpa_printf(MSG_INFO, "TESTING: fail at %s",
|
wpa_printf(MSG_INFO, "TESTING: fail at %s",
|
||||||
wpa_trace_test_fail_func);
|
wpa_trace_fail_func[is_alloc]);
|
||||||
for (i = 0; i < res; i++)
|
for (i = 0; i < res; i++)
|
||||||
wpa_printf(MSG_INFO, "backtrace[%d] = %s",
|
wpa_printf(MSG_INFO, "backtrace[%d] = %s",
|
||||||
(int) i, func[i]);
|
(int) i, func[i]);
|
||||||
|
@ -697,26 +627,15 @@ int testing_set_fail_pattern(bool is_alloc, char *patterns)
|
||||||
#ifdef WPA_TRACE_BFD
|
#ifdef WPA_TRACE_BFD
|
||||||
char *pos;
|
char *pos;
|
||||||
|
|
||||||
if (is_alloc) {
|
is_alloc = !!is_alloc;
|
||||||
wpa_trace_fail_after = atoi(patterns);
|
wpa_trace_fail_after[is_alloc] = atoi(patterns);
|
||||||
pos = os_strchr(patterns, ':');
|
pos = os_strchr(patterns, ':');
|
||||||
if (pos) {
|
if (pos) {
|
||||||
pos++;
|
pos++;
|
||||||
os_strlcpy(wpa_trace_fail_func, pos,
|
os_strlcpy(wpa_trace_fail_func[is_alloc], pos,
|
||||||
sizeof(wpa_trace_fail_func));
|
sizeof(wpa_trace_fail_func[is_alloc]));
|
||||||
} else {
|
} else {
|
||||||
wpa_trace_fail_after = 0;
|
wpa_trace_fail_after[is_alloc] = 0;
|
||||||
}
|
|
||||||
} else {
|
|
||||||
wpa_trace_test_fail_after = atoi(patterns);
|
|
||||||
pos = os_strchr(patterns, ':');
|
|
||||||
if (pos) {
|
|
||||||
pos++;
|
|
||||||
os_strlcpy(wpa_trace_test_fail_func, pos,
|
|
||||||
sizeof(wpa_trace_test_fail_func));
|
|
||||||
} else {
|
|
||||||
wpa_trace_test_fail_after = 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -729,29 +648,21 @@ int testing_set_fail_pattern(bool is_alloc, char *patterns)
|
||||||
int testing_get_fail_pattern(bool is_alloc, char *buf, size_t buflen)
|
int testing_get_fail_pattern(bool is_alloc, char *buf, size_t buflen)
|
||||||
{
|
{
|
||||||
#ifdef WPA_TRACE_BFD
|
#ifdef WPA_TRACE_BFD
|
||||||
if (is_alloc)
|
is_alloc = !!is_alloc;
|
||||||
return os_snprintf(buf, buflen, "%u:%s", wpa_trace_fail_after,
|
return os_snprintf(buf, buflen, "%u:%s", wpa_trace_fail_after[is_alloc],
|
||||||
wpa_trace_fail_func);
|
wpa_trace_fail_func[is_alloc]);
|
||||||
return os_snprintf(buf, buflen, "%u:%s", wpa_trace_test_fail_after,
|
|
||||||
wpa_trace_test_fail_func);
|
|
||||||
#else /* WPA_TRACE_BFD */
|
#else /* WPA_TRACE_BFD */
|
||||||
return -1;
|
return -1;
|
||||||
#endif /* WPA_TRACE_BFD */
|
#endif /* WPA_TRACE_BFD */
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
static inline int testing_fail_alloc(void)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void * os_malloc(size_t size)
|
void * os_malloc(size_t size)
|
||||||
{
|
{
|
||||||
struct os_alloc_trace *a;
|
struct os_alloc_trace *a;
|
||||||
|
|
||||||
if (testing_fail_alloc())
|
if (testing_test_fail(true))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
a = malloc(sizeof(*a) + size);
|
a = malloc(sizeof(*a) + size);
|
||||||
|
|
Loading…
Reference in a new issue