| /* | 
 |  * Copyright (C) 2003 Bernardo Innocenti <bernie@develer.com> | 
 |  * Based on former asm-ppc/div64.h and asm-m68knommu/div64.h | 
 |  * | 
 |  * Optimization for constant divisors on 32-bit machines: | 
 |  * Copyright (C) 2006-2015 Nicolas Pitre | 
 |  * | 
 |  * The semantics of do_div() are: | 
 |  * | 
 |  * uint32_t do_div(uint64_t *n, uint32_t base) | 
 |  * { | 
 |  * 	uint32_t remainder = *n % base; | 
 |  * 	*n = *n / base; | 
 |  * 	return remainder; | 
 |  * } | 
 |  * | 
 |  * NOTE: macro parameter n is evaluated multiple times, | 
 |  *       beware of side effects! | 
 |  */ | 
 |  | 
 | #pragma once | 
 |  | 
 | #include <sys/types.h> | 
 |  | 
 | #if BITS_PER_LONG == 64 | 
 |  | 
 | # define do_div(n,base) ({					\ | 
 | 	uint32_t __base = (base);				\ | 
 | 	uint32_t __rem;						\ | 
 | 	__rem = ((uint64_t)(n)) % __base;			\ | 
 | 	(n) = ((uint64_t)(n)) / __base;				\ | 
 | 	__rem;							\ | 
 |  }) | 
 |  | 
 | #else /* BITS_PER_LONG == ?? */ | 
 |  | 
 | # error "BITS_PER_LONG isn't #defined 64" | 
 |  | 
 | #endif /* BITS_PER_LONG */ |