19 lines
		
	
	
	
		
			291 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			19 lines
		
	
	
	
		
			291 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
|   | #include <linux/kernel.h>
 | ||
|  | #include <linux/gcd.h>
 | ||
|  | #include <linux/module.h>
 | ||
|  | 
 | ||
|  | /* Greatest common divisor */ | ||
|  | unsigned long gcd(unsigned long a, unsigned long b) | ||
|  | { | ||
|  | 	unsigned long r; | ||
|  | 
 | ||
|  | 	if (a < b) | ||
|  | 		swap(a, b); | ||
|  | 	while ((r = a % b) != 0) { | ||
|  | 		a = b; | ||
|  | 		b = r; | ||
|  | 	} | ||
|  | 	return b; | ||
|  | } | ||
|  | EXPORT_SYMBOL_GPL(gcd); |