mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-25 16:47:37 +08:00
802a6ed2ca
1. RT_FIELD_PREP: prepare a bitfield element. 2. RT_FIELD_GET: extract a bitfield element. 3. rt_offsetof: member offset of a struct 4. rt_upper_32_bits: high 32 bits of value. 5. rt_lower_32_bits: lower 32 bits of value. 6. rt_upper_16_bits: high 16 bits of value. 7. rt_lower_16_bits: lower 16 bits of value. 8. rt_max_t: fix type of max(...). 9. rt_ilog2: integer logarithm base 2. Signed-off-by: GuEe-GUI <2991707448@qq.com>
60 lines
1.2 KiB
C
60 lines
1.2 KiB
C
/*
|
|
* Copyright (c) 2006-2021, RT-Thread Development Team
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2024-06-21 Zhangyan first version
|
|
*/
|
|
|
|
#include <rthw.h>
|
|
#include <rtthread.h>
|
|
#include <board.h>
|
|
|
|
#ifdef RT_USING_CPU_FFS
|
|
/**
|
|
* This function finds the first bit set (beginning with the least significant bit)
|
|
* in value and return the index of that bit.
|
|
*
|
|
* Bits are numbered starting at 1 (the least significant bit). A return value of
|
|
* zero from any of these functions means that the argument was zero.
|
|
*
|
|
* @return return the index of the first bit set. If value is 0, then this function
|
|
* shall return 0.
|
|
*/
|
|
int __rt_ffs(int value)
|
|
{
|
|
#ifdef __GNUC__
|
|
return __builtin_ffs(value);
|
|
#else
|
|
__asm__ volatile (
|
|
"rbit w1, %w0\n"
|
|
"cmp %w0, 0\n"
|
|
"clz w1, w1\n"
|
|
"csinc %w0, wzr, w1, eq\n"
|
|
: "=r"(value)
|
|
: "0"(value)
|
|
);
|
|
return value;
|
|
#endif
|
|
}
|
|
|
|
unsigned long __rt_ffsl(unsigned long value)
|
|
{
|
|
#ifdef __GNUC__
|
|
return __builtin_ffsl(value);
|
|
#else
|
|
if (!value)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
__asm__ volatile ("rbit %0, %0" : "+r" (value));
|
|
|
|
return __rt_clz(value);
|
|
#endif
|
|
}
|
|
|
|
#endif /* RT_USING_CPU_FFS */
|