forked from mirrors/linux
		
	 d8fd5a1e78
			
		
	
	
		d8fd5a1e78
		
	
	
	
	
		
			
			The kasan-enabled.h header relies on static keys, so make sure
to include the header to avoid compilation errors (with JUMP_LABEL=n).
It fixes the following:
./include/linux/kasan-enabled.h:9:1: warning: data definition has no type or storage class
    9 | DECLARE_STATIC_KEY_FALSE(kasan_flag_enabled);
      | ^~~~~~~~~~~~~~~~~~~~~~~~
error: type defaults to 'int' in declaration of 'DECLARE_STATIC_KEY_FALSE' [-Werror=implicit-int]
Fixes: f9b5e46f40 ("kasan: split kasan_*enabled() functions into a separate header")
Cc: Peter Collingbourne <pcc@google.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Will Deacon <will@kernel.org>
Acked-by: Andrey Konovalov <andreyknvl@gmail.com>
Signed-off-by: Joey Gouly <joey.gouly@arm.com>
Link: https://lore.kernel.org/r/20220301154518.19456-1-joey.gouly@arm.com
Signed-off-by: Will Deacon <will@kernel.org>
		
	
			
		
			
				
	
	
		
			35 lines
		
	
	
	
		
			639 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
	
		
			639 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _LINUX_KASAN_ENABLED_H
 | |
| #define _LINUX_KASAN_ENABLED_H
 | |
| 
 | |
| #include <linux/static_key.h>
 | |
| 
 | |
| #ifdef CONFIG_KASAN_HW_TAGS
 | |
| 
 | |
| DECLARE_STATIC_KEY_FALSE(kasan_flag_enabled);
 | |
| 
 | |
| static __always_inline bool kasan_enabled(void)
 | |
| {
 | |
| 	return static_branch_likely(&kasan_flag_enabled);
 | |
| }
 | |
| 
 | |
| static inline bool kasan_hw_tags_enabled(void)
 | |
| {
 | |
| 	return kasan_enabled();
 | |
| }
 | |
| 
 | |
| #else /* CONFIG_KASAN_HW_TAGS */
 | |
| 
 | |
| static inline bool kasan_enabled(void)
 | |
| {
 | |
| 	return IS_ENABLED(CONFIG_KASAN);
 | |
| }
 | |
| 
 | |
| static inline bool kasan_hw_tags_enabled(void)
 | |
| {
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| #endif /* CONFIG_KASAN_HW_TAGS */
 | |
| 
 | |
| #endif /* LINUX_KASAN_ENABLED_H */
 |