xref: /dflybsd-src/contrib/gcc-4.7/libgcc/udivmodsi4.c (revision 04febcfb30580676d3e95f58a16c5137ee478b32)
1*e4b17023SJohn Marino /* Copyright (C) 2000 Free Software Foundation, Inc.
2*e4b17023SJohn Marino 
3*e4b17023SJohn Marino This file is part of GCC.
4*e4b17023SJohn Marino 
5*e4b17023SJohn Marino GCC is free software; you can redistribute it and/or modify it under
6*e4b17023SJohn Marino the terms of the GNU General Public License as published by the Free
7*e4b17023SJohn Marino Software Foundation; either version 3, or (at your option) any later
8*e4b17023SJohn Marino version.
9*e4b17023SJohn Marino 
10*e4b17023SJohn Marino GCC is distributed in the hope that it will be useful, but WITHOUT ANY
11*e4b17023SJohn Marino WARRANTY; without even the implied warranty of MERCHANTABILITY or
12*e4b17023SJohn Marino FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
13*e4b17023SJohn Marino for more details.
14*e4b17023SJohn Marino 
15*e4b17023SJohn Marino Under Section 7 of GPL version 3, you are granted additional
16*e4b17023SJohn Marino permissions described in the GCC Runtime Library Exception, version
17*e4b17023SJohn Marino 3.1, as published by the Free Software Foundation.
18*e4b17023SJohn Marino 
19*e4b17023SJohn Marino You should have received a copy of the GNU General Public License and
20*e4b17023SJohn Marino a copy of the GCC Runtime Library Exception along with this program;
21*e4b17023SJohn Marino see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
22*e4b17023SJohn Marino <http://www.gnu.org/licenses/>.  */
23*e4b17023SJohn Marino 
24*e4b17023SJohn Marino unsigned long
udivmodsi4(unsigned long num,unsigned long den,int modwanted)25*e4b17023SJohn Marino udivmodsi4(unsigned long num, unsigned long den, int modwanted)
26*e4b17023SJohn Marino {
27*e4b17023SJohn Marino   unsigned long bit = 1;
28*e4b17023SJohn Marino   unsigned long res = 0;
29*e4b17023SJohn Marino 
30*e4b17023SJohn Marino   while (den < num && bit && !(den & (1L<<31)))
31*e4b17023SJohn Marino     {
32*e4b17023SJohn Marino       den <<=1;
33*e4b17023SJohn Marino       bit <<=1;
34*e4b17023SJohn Marino     }
35*e4b17023SJohn Marino   while (bit)
36*e4b17023SJohn Marino     {
37*e4b17023SJohn Marino       if (num >= den)
38*e4b17023SJohn Marino 	{
39*e4b17023SJohn Marino 	  num -= den;
40*e4b17023SJohn Marino 	  res |= bit;
41*e4b17023SJohn Marino 	}
42*e4b17023SJohn Marino       bit >>=1;
43*e4b17023SJohn Marino       den >>=1;
44*e4b17023SJohn Marino     }
45*e4b17023SJohn Marino   if (modwanted) return num;
46*e4b17023SJohn Marino   return res;
47*e4b17023SJohn Marino }
48