mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 09:14:17 +01:00
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:
parent
95885261f0
commit
b331cde26b
3 changed files with 6 additions and 7 deletions
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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");
|
||||||
|
|
Loading…
Add table
Reference in a new issue