1*d790b16bSRobert Clausecker.\" 2*d790b16bSRobert Clausecker.\" Copyright (c) 2025 Robert Clausecker <fuz@FreeBSD.org> 3*d790b16bSRobert Clausecker.\" 4*d790b16bSRobert Clausecker.\" SPDX-License-Identifier: BSD-2-Clause 5*d790b16bSRobert Clausecker.\" 6*d790b16bSRobert Clausecker.Dd November 9, 2025 7*d790b16bSRobert Clausecker.Dt STDC_BIT_WIDTH 3 8*d790b16bSRobert Clausecker.Os 9*d790b16bSRobert Clausecker.Sh NAME 10*d790b16bSRobert Clausecker.Nm stdc_bit_width 11*d790b16bSRobert Clausecker.Nd find the first trailing one in an intege 12*d790b16bSRobert Clausecker.Sh SYNOPSIS 13*d790b16bSRobert Clausecker.Lb libc 14*d790b16bSRobert Clausecker.In stdbit.h 15*d790b16bSRobert Clausecker.Ft unsigned int 16*d790b16bSRobert Clausecker.Fn stdc_bit_width_uc "unsigned char value" 17*d790b16bSRobert Clausecker.Ft unsigned int 18*d790b16bSRobert Clausecker.Fn stdc_bit_width_us "unsigned short value" 19*d790b16bSRobert Clausecker.Ft unsigned int 20*d790b16bSRobert Clausecker.Fn stdc_bit_width_ui "unsigned int value" 21*d790b16bSRobert Clausecker.Ft unsigned int 22*d790b16bSRobert Clausecker.Fn stdc_bit_width_ul "unsigned long value" 23*d790b16bSRobert Clausecker.Ft unsigned int 24*d790b16bSRobert Clausecker.Fn stdc_bit_width_ull "unsigned long long value" 25*d790b16bSRobert Clausecker.Ft unsigned int 26*d790b16bSRobert Clausecker.Fn stdc_bit_width "value" 27*d790b16bSRobert Clausecker.Sh DESCRIPTION 28*d790b16bSRobert ClauseckerThe 29*d790b16bSRobert Clausecker.Nm stdc_bit_width_ Ns Em type Ns () 30*d790b16bSRobert Clauseckerfamily of functions returns the number of bits needed to represent 31*d790b16bSRobert Clausecker.Fa value , 32*d790b16bSRobert Clauseckerwhere 33*d790b16bSRobert Clausecker.Fa value 34*d790b16bSRobert Clauseckeris of type 35*d790b16bSRobert Clausecker.Va unsigned char , 36*d790b16bSRobert Clausecker.Va unsigned short , 37*d790b16bSRobert Clausecker.Va unsigned int , 38*d790b16bSRobert Clausecker.Va unsigned long , 39*d790b16bSRobert Clauseckeror 40*d790b16bSRobert Clausecker.Va unsigned long long 41*d790b16bSRobert Clauseckerfor 42*d790b16bSRobert Clausecker.Em type 43*d790b16bSRobert Clauseckerbeing 44*d790b16bSRobert Clausecker.Sy uc , 45*d790b16bSRobert Clausecker.Sy us , 46*d790b16bSRobert Clausecker.Sy ui , 47*d790b16bSRobert Clausecker.Sy ul , 48*d790b16bSRobert Clauseckeror 49*d790b16bSRobert Clausecker.Sy ull 50*d790b16bSRobert Clauseckerrespectively. 51*d790b16bSRobert ClauseckerThe 52*d790b16bSRobert Clausecker.Fn stdc_bit_width "value" 53*d790b16bSRobert Clauseckertype-generic macro picks the appropriate 54*d790b16bSRobert Clausecker.Nm stdc_bit_width_ Ns Em type Ns () 55*d790b16bSRobert Clauseckerfunction based on the type of 56*d790b16bSRobert Clausecker.Fa value . 57*d790b16bSRobert Clausecker.Pp 58*d790b16bSRobert ClauseckerFunctions 59*d790b16bSRobert Clausecker.Fn stdc_bit_width_ui , 60*d790b16bSRobert Clausecker.Fn stdc_bit_width_ul , 61*d790b16bSRobert Clauseckerand 62*d790b16bSRobert Clausecker.Fn stdc_bit_width_ull 63*d790b16bSRobert Clauseckerare identical to 64*d790b16bSRobert Clausecker.Bx 4.3 65*d790b16bSRobert Clauseckerfunctions 66*d790b16bSRobert Clausecker.Xr fls 3 , 67*d790b16bSRobert Clausecker.Xr flsl 3 , 68*d790b16bSRobert Clauseckerand 69*d790b16bSRobert Clausecker.Xr flsll 3 70*d790b16bSRobert Clauseckerrespectively, except for operating on unsigned instead of signed values. 71*d790b16bSRobert Clausecker.Sh RETURN VALUES 72*d790b16bSRobert ClauseckerReturns the least number of bits needed to represent 73*d790b16bSRobert Clausecker.Fa value . 74*d790b16bSRobert ClauseckerIf 75*d790b16bSRobert Clausecker.Fa value 76*d790b16bSRobert Clauseckeris zero, the return value is zero. 77*d790b16bSRobert ClauseckerOtherwise it is 78*d790b16bSRobert Clausecker.EQ 79*d790b16bSRobert Clausecker1 + \(lf log sub 2 italic value \(rf . 80*d790b16bSRobert Clausecker.EN 81*d790b16bSRobert Clausecker.Sh SEE ALSO 82*d790b16bSRobert Clausecker.Xr bit_fls 3 , 83*d790b16bSRobert Clausecker.Xr fls 3 , 84*d790b16bSRobert Clausecker.Xr flsl 3 , 85*d790b16bSRobert Clausecker.Xr flsll 3 , 86*d790b16bSRobert Clausecker.Xr stdbit 3 , 87*d790b16bSRobert Clausecker.Xr stdc_count_leading_zeros 3 , 88*d790b16bSRobert Clausecker.Xr stdc_first_leading_one 3 89*d790b16bSRobert Clausecker.Sh STANDARDS 90*d790b16bSRobert ClauseckerThe 91*d790b16bSRobert Clausecker.Nm stdc_bit_width_ Ns Em type Ns () 92*d790b16bSRobert Clauseckerfamily of functions and the 93*d790b16bSRobert Clausecker.Fn stdc_bit_width 94*d790b16bSRobert Clauseckertype-generic macro conform to 95*d790b16bSRobert Clausecker.St -isoC-2023 . 96*d790b16bSRobert Clausecker.Sh HISTORY 97*d790b16bSRobert ClauseckerThe 98*d790b16bSRobert Clausecker.Nm stdc_bit_width_ Ns Em type Ns () 99*d790b16bSRobert Clauseckerfamily of functions and the 100*d790b16bSRobert Clausecker.Fn stdc_bit_width 101*d790b16bSRobert Clauseckertype-generic macro were added in 102*d790b16bSRobert Clausecker.Fx 15.1. 103*d790b16bSRobert Clausecker.Sh AUTHOR 104*d790b16bSRobert Clausecker.An Robert Clausecker Aq Mt fuz@FreeBSD.org 105