1*13093SRoger.Faulkner@Oracle.COM /* 2*13093SRoger.Faulkner@Oracle.COM * CDDL HEADER START 3*13093SRoger.Faulkner@Oracle.COM * 4*13093SRoger.Faulkner@Oracle.COM * The contents of this file are subject to the terms of the 5*13093SRoger.Faulkner@Oracle.COM * Common Development and Distribution License (the "License"). 6*13093SRoger.Faulkner@Oracle.COM * You may not use this file except in compliance with the License. 7*13093SRoger.Faulkner@Oracle.COM * 8*13093SRoger.Faulkner@Oracle.COM * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*13093SRoger.Faulkner@Oracle.COM * or http://www.opensolaris.org/os/licensing. 10*13093SRoger.Faulkner@Oracle.COM * See the License for the specific language governing permissions 11*13093SRoger.Faulkner@Oracle.COM * and limitations under the License. 12*13093SRoger.Faulkner@Oracle.COM * 13*13093SRoger.Faulkner@Oracle.COM * When distributing Covered Code, include this CDDL HEADER in each 14*13093SRoger.Faulkner@Oracle.COM * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*13093SRoger.Faulkner@Oracle.COM * If applicable, add the following below this CDDL HEADER, with the 16*13093SRoger.Faulkner@Oracle.COM * fields enclosed by brackets "[]" replaced with your own identifying 17*13093SRoger.Faulkner@Oracle.COM * information: Portions Copyright [yyyy] [name of copyright owner] 18*13093SRoger.Faulkner@Oracle.COM * 19*13093SRoger.Faulkner@Oracle.COM * CDDL HEADER END 20*13093SRoger.Faulkner@Oracle.COM */ 21*13093SRoger.Faulkner@Oracle.COM 22*13093SRoger.Faulkner@Oracle.COM /* 23*13093SRoger.Faulkner@Oracle.COM * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. 24*13093SRoger.Faulkner@Oracle.COM */ 25*13093SRoger.Faulkner@Oracle.COM 26*13093SRoger.Faulkner@Oracle.COM #include "lint.h" 27*13093SRoger.Faulkner@Oracle.COM #include <string.h> 28*13093SRoger.Faulkner@Oracle.COM #include <strings.h> 29*13093SRoger.Faulkner@Oracle.COM #include <sys/types.h> 30*13093SRoger.Faulkner@Oracle.COM 31*13093SRoger.Faulkner@Oracle.COM static int fls_impl(uint64_t bits)32*13093SRoger.Faulkner@Oracle.COMfls_impl(uint64_t bits) 33*13093SRoger.Faulkner@Oracle.COM { 34*13093SRoger.Faulkner@Oracle.COM int i = 1; 35*13093SRoger.Faulkner@Oracle.COM uint32_t bits32; 36*13093SRoger.Faulkner@Oracle.COM 37*13093SRoger.Faulkner@Oracle.COM if (bits == 0) 38*13093SRoger.Faulkner@Oracle.COM return (0); 39*13093SRoger.Faulkner@Oracle.COM 40*13093SRoger.Faulkner@Oracle.COM if ((bits32 = (uint32_t)(bits >> 32)) != 0) 41*13093SRoger.Faulkner@Oracle.COM i += 32; 42*13093SRoger.Faulkner@Oracle.COM else 43*13093SRoger.Faulkner@Oracle.COM bits32 = (uint32_t)bits; 44*13093SRoger.Faulkner@Oracle.COM 45*13093SRoger.Faulkner@Oracle.COM if ((bits32 & 0xffff0000) != 0) { 46*13093SRoger.Faulkner@Oracle.COM bits32 >>= 16; 47*13093SRoger.Faulkner@Oracle.COM i += 16; 48*13093SRoger.Faulkner@Oracle.COM } 49*13093SRoger.Faulkner@Oracle.COM if ((bits32 & 0xff00) != 0) { 50*13093SRoger.Faulkner@Oracle.COM bits32 >>= 8; 51*13093SRoger.Faulkner@Oracle.COM i += 8; 52*13093SRoger.Faulkner@Oracle.COM } 53*13093SRoger.Faulkner@Oracle.COM if ((bits32 & 0xf0) != 0) { 54*13093SRoger.Faulkner@Oracle.COM bits32 >>= 4; 55*13093SRoger.Faulkner@Oracle.COM i += 4; 56*13093SRoger.Faulkner@Oracle.COM } 57*13093SRoger.Faulkner@Oracle.COM if ((bits32 & 0xc) != 0) { 58*13093SRoger.Faulkner@Oracle.COM bits32 >>= 2; 59*13093SRoger.Faulkner@Oracle.COM i += 2; 60*13093SRoger.Faulkner@Oracle.COM } 61*13093SRoger.Faulkner@Oracle.COM if ((bits32 & 0x2) != 0) 62*13093SRoger.Faulkner@Oracle.COM i += 1; 63*13093SRoger.Faulkner@Oracle.COM 64*13093SRoger.Faulkner@Oracle.COM return (i); 65*13093SRoger.Faulkner@Oracle.COM } 66*13093SRoger.Faulkner@Oracle.COM 67*13093SRoger.Faulkner@Oracle.COM int fls(int bits)68*13093SRoger.Faulkner@Oracle.COMfls(int bits) 69*13093SRoger.Faulkner@Oracle.COM { 70*13093SRoger.Faulkner@Oracle.COM return (fls_impl((uint64_t)(uint_t)bits)); 71*13093SRoger.Faulkner@Oracle.COM } 72*13093SRoger.Faulkner@Oracle.COM 73*13093SRoger.Faulkner@Oracle.COM int flsl(long bits)74*13093SRoger.Faulkner@Oracle.COMflsl(long bits) 75*13093SRoger.Faulkner@Oracle.COM { 76*13093SRoger.Faulkner@Oracle.COM return (fls_impl((uint64_t)(ulong_t)bits)); 77*13093SRoger.Faulkner@Oracle.COM } 78*13093SRoger.Faulkner@Oracle.COM 79*13093SRoger.Faulkner@Oracle.COM int flsll(long long bits)80*13093SRoger.Faulkner@Oracle.COMflsll(long long bits) 81*13093SRoger.Faulkner@Oracle.COM { 82*13093SRoger.Faulkner@Oracle.COM return (fls_impl((uint64_t)(u_longlong_t)bits)); 83*13093SRoger.Faulkner@Oracle.COM } 84