lkm: self-test working now (certain options, which ones TBD, crash kernel).

This commit is contained in:
Daniel Pouzzner
2020-08-21 01:28:03 -05:00
parent 34fd53b4fc
commit 554879da00
2 changed files with 16 additions and 6 deletions

View File

@@ -113,6 +113,11 @@ _Pragma("GCC diagnostic ignored \"-Wunused-function\"");
#include <stdio.h> #include <stdio.h>
#endif #endif
#ifdef WOLFSSL_LINUXKM
#undef printf
#define printf(...) ({})
#endif
/* enable way for customer to override test/bench printf */ /* enable way for customer to override test/bench printf */
#ifdef XPRINTF #ifdef XPRINTF
#undef printf #undef printf
@@ -444,6 +449,9 @@ static THREAD_RETURN err_sys(const char* msg, int es)
static int err_sys(const char* msg, int es) static int err_sys(const char* msg, int es)
#endif #endif
{ {
(void)msg;
(void)es;
printf("%s error = %d\n", msg, es); printf("%s error = %d\n", msg, es);
EXIT_TEST(-1); EXIT_TEST(-1);
@@ -28839,7 +28847,7 @@ static void *my_Realloc_cb(void *ptr, size_t size)
static int memcb_test(void) static int memcb_test(void)
{ {
int ret = 0; int ret = 0;
#ifndef WOLFSSL_NO_MALLOC #if !defined(WOLFSSL_NO_MALLOC) && !defined(WOLFSSL_LINUXKM)
byte* b = NULL; byte* b = NULL;
#endif #endif
wolfSSL_Malloc_cb mc; wolfSSL_Malloc_cb mc;
@@ -28850,7 +28858,7 @@ static int memcb_test(void)
if (wolfSSL_GetAllocators(&mc, &fc, &rc) != 0) if (wolfSSL_GetAllocators(&mc, &fc, &rc) != 0)
return -12800; return -12800;
#ifndef WOLFSSL_NO_MALLOC #if !defined(WOLFSSL_NO_MALLOC) && !defined(WOLFSSL_LINUXKM)
/* test realloc */ /* test realloc */
b = (byte*)XREALLOC(b, 1024, NULL, DYNAMIC_TYPE_TMP_BUFFER); b = (byte*)XREALLOC(b, 1024, NULL, DYNAMIC_TYPE_TMP_BUFFER);
if (b == NULL) { if (b == NULL) {
@@ -28878,7 +28886,7 @@ static int memcb_test(void)
ret = -12803; ret = -12803;
#endif /* !WOLFSSL_NO_MALLOC */ #endif /* !WOLFSSL_NO_MALLOC */
#ifndef WOLFSSL_NO_MALLOC #if !defined(WOLFSSL_NO_MALLOC) && !defined(WOLFSSL_LINUXKM)
exit_memcb: exit_memcb:
#endif #endif

View File

@@ -27,13 +27,15 @@ static int wolfssl_init(void)
#ifndef NO_CRYPT_TEST #ifndef NO_CRYPT_TEST
ret = wolfcrypt_test(NULL); ret = wolfcrypt_test(NULL);
if (ret != WOLFSSL_SUCCESS) { if (ret < 0) {
pr_err("wolfcrypt_test() failed: %s", wc_GetErrorString(ret)); pr_err("wolfcrypt_test() failed with code %d", ret);
return -ENOTRECOVERABLE; return -ENOTRECOVERABLE;
} }
pr_info("wolfSSL " LIBWOLFSSL_VERSION_STRING " self-test passed. See https://www.wolfssl.com/ for information.\n");
#else
pr_info("wolfSSL " LIBWOLFSSL_VERSION_STRING " loaded. See https://www.wolfssl.com/ for information.\n");
#endif #endif
pr_info("wolfSSL " LIBWOLFSSL_VERSION_STRING " loaded. See https://www.wolfssl.com/ for information.\n");
pr_info("Copyright (C) 2006-2020 wolfSSL Inc. All Rights Reserved.\n"); pr_info("Copyright (C) 2006-2020 wolfSSL Inc. All Rights Reserved.\n");
return 0; return 0;