/* * Copyright (c) 2025 Robert Clausecker * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include /* Avoid triggering undefined behavior if x == ~0. */ static_assert(UCHAR_WIDTH < UINT_WIDTH, "stdc_trailing_ones_uc needs UCHAR_WIDTH < UINT_WIDTH"); unsigned int stdc_trailing_ones_uc(unsigned char x) { return (__builtin_ctz(~x)); } /* Avoid triggering undefined behavior if x == ~0. */ static_assert(USHRT_WIDTH < UINT_WIDTH, "stdc_trailing_ones_uc needs USHRT_WIDTH < UINT_WIDTH"); unsigned int stdc_trailing_ones_us(unsigned short x) { return (__builtin_ctz(~x)); } unsigned int stdc_trailing_ones_ui(unsigned int x) { if (x == ~0U) return (UINT_WIDTH); return (__builtin_ctz(~x)); } unsigned int stdc_trailing_ones_ul(unsigned long x) { if (x == ~0UL) return (ULONG_WIDTH); return (__builtin_ctzl(~x)); } unsigned int stdc_trailing_ones_ull(unsigned long long x) { if (x == ~0ULL) return (ULLONG_WIDTH); return (__builtin_ctzll(~x)); }