Blame view

lib/int_sqrt.c 688 Bytes
81f7e3824   Eric Lee   Initial Release, ...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
  // SPDX-License-Identifier: GPL-2.0
  /*
   * Copyright (C) 2013 Davidlohr Bueso <davidlohr.bueso@hp.com>
   *
   *  Based on the shift-and-subtract algorithm for computing integer
   *  square root from Guy L. Steele.
   */
  
  #include <linux/kernel.h>
  #include <linux/export.h>
  
  /**
   * int_sqrt - rough approximation to sqrt
   * @x: integer of which to calculate the sqrt
   *
   * A very rough approximation to the sqrt() function.
   */
  unsigned long int_sqrt(unsigned long x)
  {
  	unsigned long b, m, y = 0;
  
  	if (x <= 1)
  		return x;
  
  	m = 1UL << (BITS_PER_LONG - 2);
  	while (m != 0) {
  		b = y + m;
  		y >>= 1;
  
  		if (x >= b) {
  			x -= b;
  			y += m;
  		}
  		m >>= 2;
  	}
  
  	return y;
  }
  EXPORT_SYMBOL(int_sqrt);