powerpc/security: Fix debugfs data leak on 32-bit
"powerpc_security_features" is "unsigned long", i.e. 32-bit or 64-bit,
depending on the platform (PPC_FSL_BOOK3E or PPC_BOOK3S_64).  Hence
casting its address to "u64 *", and calling debugfs_create_x64() is
wrong, and leaks 32-bit of nearby data to userspace on 32-bit platforms.
While all currently defined SEC_FTR_* security feature flags fit in
32-bit, they all have "ULL" suffixes to make them 64-bit constants.
Hence fix the leak by changing the type of "powerpc_security_features"
(and the parameter types of its accessors) to "u64".  This also allows
to drop the cast.
Fixes: 398af57112 ("powerpc/security: Show powerpc_security_features in debugfs")
Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20191021142309.28105-1-geert+renesas@glider.be
			
			
This commit is contained in:
		
				
					committed by
					
						
						Michael Ellerman
					
				
			
			
				
	
			
			
			
						parent
						
							16f6b67cf0
						
					
				
				
					commit
					3b05a1e517
				
			@@ -16,7 +16,7 @@
 | 
			
		||||
#include <asm/setup.h>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
unsigned long powerpc_security_features __read_mostly = SEC_FTR_DEFAULT;
 | 
			
		||||
u64 powerpc_security_features __read_mostly = SEC_FTR_DEFAULT;
 | 
			
		||||
 | 
			
		||||
enum count_cache_flush_type {
 | 
			
		||||
	COUNT_CACHE_FLUSH_NONE	= 0x1,
 | 
			
		||||
@@ -108,7 +108,7 @@ device_initcall(barrier_nospec_debugfs_init);
 | 
			
		||||
static __init int security_feature_debugfs_init(void)
 | 
			
		||||
{
 | 
			
		||||
	debugfs_create_x64("security_features", 0400, powerpc_debugfs_root,
 | 
			
		||||
			   (u64 *)&powerpc_security_features);
 | 
			
		||||
			   &powerpc_security_features);
 | 
			
		||||
	return 0;
 | 
			
		||||
}
 | 
			
		||||
device_initcall(security_feature_debugfs_init);
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user