diff options
| author | Yinan Liu <[email protected]> | 2022-01-18 14:52:41 +0800 | 
|---|---|---|
| committer | Steven Rostedt <[email protected]> | 2022-01-18 10:17:18 -0500 | 
| commit | 35140d399db2b67153fc53b51a97ddb8ba3b5956 (patch) | |
| tree | a404a8ce8c3219084ba315eb8bdb16254878f776 | |
| parent | f37c3bbc635994eda203a6da4ba0f9d05165a8d6 (diff) | |
script/sorttable: Fix some initialization problems
elf_mcount_loc and mcount_sort_thread definitions are not
initialized immediately within the function, which can cause
the judgment logic to use uninitialized values when the
initialization logic of subsequent code fails.
Link: https://lkml.kernel.org/r/[email protected]
Link: https://lkml.kernel.org/r/[email protected]
Fixes: 72b3942a173c ("scripts: ftrace - move the sort-processing in ftrace_init")
Tested-by: Nathan Chancellor <[email protected]>
Reviewed-by: Nathan Chancellor <[email protected]>
Signed-off-by: Yinan Liu <[email protected]>
Signed-off-by: Steven Rostedt <[email protected]>
| -rw-r--r-- | scripts/sorttable.h | 5 | 
1 files changed, 3 insertions, 2 deletions
| diff --git a/scripts/sorttable.h b/scripts/sorttable.h index 1e8b77928fa4..deb7c1d3e979 100644 --- a/scripts/sorttable.h +++ b/scripts/sorttable.h @@ -199,6 +199,8 @@ static int compare_extable(const void *a, const void *b)  	return 0;  }  #ifdef MCOUNT_SORT_ENABLED +pthread_t mcount_sort_thread; +  struct elf_mcount_loc {  	Elf_Ehdr *ehdr;  	Elf_Shdr *init_data_sec; @@ -282,10 +284,9 @@ static int do_sort(Elf_Ehdr *ehdr,  	unsigned int shnum;  	unsigned int shstrndx;  #ifdef MCOUNT_SORT_ENABLED -	struct elf_mcount_loc mstruct; +	struct elf_mcount_loc mstruct = {0};  	uint_t _start_mcount_loc = 0;  	uint_t _stop_mcount_loc = 0; -	pthread_t mcount_sort_thread;  #endif  #if defined(SORTTABLE_64) && defined(UNWINDER_ORC_ENABLED)  	unsigned int orc_ip_size = 0; |