MDEV-34921 MemorySanitizer reports errors for non-debug builds

my_b_encr_write(): Initialize also block_length, and at the same time
last_block_length, so that all 128 bits can be initialized with fewer
writes. This fixes an error that was caught in the test
encryption.tempfiles_encrypted.

test_my_safe_print_str(): Skip a test that would attempt to
display uninitialized data in the test unit.stacktrace.
Previously, our CI did not build unit tests with MemorySanitizer.

handle_delayed_insert(): Remove a redundant call to pthread_exit(0),
which would for some reason cause MemorySanitizer in clang-19 to
report a stack overflow in a RelWithDebInfo build. This fixes a
failure of several tests.

Reviewed by: Vladislav Vaintroub
This commit is contained in:
Marko Mäkelä 2024-09-13 14:34:08 +03:00
parent 95885261f0
commit b331cde26b
3 changed files with 6 additions and 7 deletions

View file

@ -175,8 +175,8 @@ static int my_b_encr_write(IO_CACHE *info, const uchar *Buffer, size_t Count)
DBUG_RETURN(info->error= -1); DBUG_RETURN(info->error= -1);
} }
crypt_data->counter= 0; crypt_data->counter= 0;
crypt_data->block_length= 0;
IF_DBUG(crypt_data->block_length= 0,); crypt_data->last_block_length= 0;
} }
do do

View file

@ -3498,7 +3498,6 @@ pthread_handler_t handle_delayed_insert(void *arg)
DBUG_LEAVE; DBUG_LEAVE;
} }
my_thread_end(); my_thread_end();
pthread_exit(0);
return 0; return 0;
} }

View file

@ -30,7 +30,7 @@ void test_my_safe_print_str()
memcpy(b_bss, "LEGAL", 6); memcpy(b_bss, "LEGAL", 6);
#ifdef HAVE_STACKTRACE #ifdef HAVE_STACKTRACE
#ifndef __SANITIZE_ADDRESS__ # if !defined __SANITIZE_ADDRESS__ && !__has_feature(memory_sanitizer)
fprintf(stderr, "\n===== stack =====\n"); fprintf(stderr, "\n===== stack =====\n");
my_safe_print_str(b_stack, 65535); my_safe_print_str(b_stack, 65535);
fprintf(stderr, "\n===== heap =====\n"); fprintf(stderr, "\n===== heap =====\n");
@ -40,7 +40,7 @@ void test_my_safe_print_str()
fprintf(stderr, "\n===== data =====\n"); fprintf(stderr, "\n===== data =====\n");
my_safe_print_str("LEGAL", 65535); my_safe_print_str("LEGAL", 65535);
fprintf(stderr, "\n===== Above is a junk, but it is expected. =====\n"); fprintf(stderr, "\n===== Above is a junk, but it is expected. =====\n");
#endif /*__SANITIZE_ADDRESS__*/ # endif
fprintf(stderr, "\n===== Nornal length test =====\n"); fprintf(stderr, "\n===== Nornal length test =====\n");
my_safe_print_str("LEGAL", 5); my_safe_print_str("LEGAL", 5);
fprintf(stderr, "\n===== NULL =====\n"); fprintf(stderr, "\n===== NULL =====\n");