00001 /* 00002 * Copyright (c) 2006 Ondrej Palkovsky 00003 * All rights reserved. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions 00007 * are met: 00008 * 00009 * - Redistributions of source code must retain the above copyright 00010 * notice, this list of conditions and the following disclaimer. 00011 * - Redistributions in binary form must reproduce the above copyright 00012 * notice, this list of conditions and the following disclaimer in the 00013 * documentation and/or other materials provided with the distribution. 00014 * - The name of the author may not be used to endorse or promote products 00015 * derived from this software without specific prior written permission. 00016 * 00017 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 00018 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 00019 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 00020 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 00021 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 00022 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 00023 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 00024 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 00025 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 00026 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00027 */ 00028 00035 #ifndef LIBC_BITOPS_H_ 00036 #define LIBC_BITOPS_H_ 00037 00038 #include <sys/types.h> 00039 00040 00045 static inline unsigned int fnzb32(uint32_t arg) 00046 { 00047 unsigned int n = 0; 00048 00049 if (arg >> 16) { 00050 arg >>= 16; 00051 n += 16; 00052 } 00053 00054 if (arg >> 8) { 00055 arg >>= 8; 00056 n += 8; 00057 } 00058 00059 if (arg >> 4) { 00060 arg >>= 4; 00061 n += 4; 00062 } 00063 00064 if (arg >> 2) { 00065 arg >>= 2; 00066 n += 2; 00067 } 00068 00069 if (arg >> 1) { 00070 arg >>= 1; 00071 n += 1; 00072 } 00073 00074 return n; 00075 } 00076 00077 static inline unsigned int fnzb64(uint64_t arg) 00078 { 00079 unsigned int n = 0; 00080 00081 if (arg >> 32) { 00082 arg >>= 32; 00083 n += 32; 00084 } 00085 00086 return (n + fnzb32((uint32_t) arg)); 00087 } 00088 00089 static inline unsigned int fnzb(size_t arg) 00090 { 00091 return fnzb64(arg); 00092 } 00093 00094 #endif 00095