1*9663SMark.Logan@Sun.COM /**
2*9663SMark.Logan@Sun.COM * compat.c - Tweaks for Windows compatibility
3*9663SMark.Logan@Sun.COM *
4*9663SMark.Logan@Sun.COM * Copyright (c) 2002 Richard Russon
5*9663SMark.Logan@Sun.COM * Copyright (c) 2002-2004 Anton Altaparmakov
6*9663SMark.Logan@Sun.COM *
7*9663SMark.Logan@Sun.COM * This program/include file is free software; you can redistribute it and/or
8*9663SMark.Logan@Sun.COM * modify it under the terms of the GNU General Public License as published
9*9663SMark.Logan@Sun.COM * by the Free Software Foundation; either version 2 of the License, or
10*9663SMark.Logan@Sun.COM * (at your option) any later version.
11*9663SMark.Logan@Sun.COM *
12*9663SMark.Logan@Sun.COM * This program/include file is distributed in the hope that it will be
13*9663SMark.Logan@Sun.COM * useful, but WITHOUT ANY WARRANTY; without even the implied warranty
14*9663SMark.Logan@Sun.COM * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15*9663SMark.Logan@Sun.COM * GNU General Public License for more details.
16*9663SMark.Logan@Sun.COM *
17*9663SMark.Logan@Sun.COM * You should have received a copy of the GNU General Public License
18*9663SMark.Logan@Sun.COM * along with this program (in the main directory of the Linux-NTFS
19*9663SMark.Logan@Sun.COM * distribution in the file COPYING); if not, write to the Free Software
20*9663SMark.Logan@Sun.COM * Foundation,Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21*9663SMark.Logan@Sun.COM */
22*9663SMark.Logan@Sun.COM
23*9663SMark.Logan@Sun.COM #ifdef WINDOWS
24*9663SMark.Logan@Sun.COM
25*9663SMark.Logan@Sun.COM #ifdef HAVE_CONFIG_H
26*9663SMark.Logan@Sun.COM #include "config.h"
27*9663SMark.Logan@Sun.COM #endif
28*9663SMark.Logan@Sun.COM
29*9663SMark.Logan@Sun.COM #include "compat.h"
30*9663SMark.Logan@Sun.COM
31*9663SMark.Logan@Sun.COM /* TODO: Add check for FFS in the configure script... (AIA) */
32*9663SMark.Logan@Sun.COM
33*9663SMark.Logan@Sun.COM #ifndef HAVE_FFS
34*9663SMark.Logan@Sun.COM /**
35*9663SMark.Logan@Sun.COM * ffs - Find the first set bit in an int
36*9663SMark.Logan@Sun.COM * @x:
37*9663SMark.Logan@Sun.COM *
38*9663SMark.Logan@Sun.COM * Description...
39*9663SMark.Logan@Sun.COM *
40*9663SMark.Logan@Sun.COM * Returns:
41*9663SMark.Logan@Sun.COM */
ffs(int x)42*9663SMark.Logan@Sun.COM int ffs(int x)
43*9663SMark.Logan@Sun.COM {
44*9663SMark.Logan@Sun.COM int r = 1;
45*9663SMark.Logan@Sun.COM
46*9663SMark.Logan@Sun.COM if (!x)
47*9663SMark.Logan@Sun.COM return 0;
48*9663SMark.Logan@Sun.COM if (!(x & 0xffff)) {
49*9663SMark.Logan@Sun.COM x >>= 16;
50*9663SMark.Logan@Sun.COM r += 16;
51*9663SMark.Logan@Sun.COM }
52*9663SMark.Logan@Sun.COM if (!(x & 0xff)) {
53*9663SMark.Logan@Sun.COM x >>= 8;
54*9663SMark.Logan@Sun.COM r += 8;
55*9663SMark.Logan@Sun.COM }
56*9663SMark.Logan@Sun.COM if (!(x & 0xf)) {
57*9663SMark.Logan@Sun.COM x >>= 4;
58*9663SMark.Logan@Sun.COM r += 4;
59*9663SMark.Logan@Sun.COM }
60*9663SMark.Logan@Sun.COM if (!(x & 3)) {
61*9663SMark.Logan@Sun.COM x >>= 2;
62*9663SMark.Logan@Sun.COM r += 2;
63*9663SMark.Logan@Sun.COM }
64*9663SMark.Logan@Sun.COM if (!(x & 1)) {
65*9663SMark.Logan@Sun.COM x >>= 1;
66*9663SMark.Logan@Sun.COM r += 1;
67*9663SMark.Logan@Sun.COM }
68*9663SMark.Logan@Sun.COM return r;
69*9663SMark.Logan@Sun.COM }
70*9663SMark.Logan@Sun.COM #endif /* HAVE_FFS */
71*9663SMark.Logan@Sun.COM
72*9663SMark.Logan@Sun.COM #endif /* WINDOWS */
73*9663SMark.Logan@Sun.COM
74