Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
math_extras_impl.h File Reference

Inline implementation of functions declared in math_extras.h. More...

#include <zephyr/toolchain.h>

Go to the source code of this file.

Macros

#define use_builtin(x)

Functions

static bool u16_add_overflow (uint16_t a, uint16_t b, uint16_t *result)
static bool u32_add_overflow (uint32_t a, uint32_t b, uint32_t *result)
static bool u64_add_overflow (uint64_t a, uint64_t b, uint64_t *result)
static bool size_add_overflow (size_t a, size_t b, size_t *result)
static bool u16_mul_overflow (uint16_t a, uint16_t b, uint16_t *result)
static bool u32_mul_overflow (uint32_t a, uint32_t b, uint32_t *result)
static bool u64_mul_overflow (uint64_t a, uint64_t b, uint64_t *result)
static bool size_mul_overflow (size_t a, size_t b, size_t *result)
static int u32_count_leading_zeros (uint32_t x)
static int u64_count_leading_zeros (uint64_t x)
static int u32_count_trailing_zeros (uint32_t x)
static int u64_count_trailing_zeros (uint64_t x)
static void i128_multiply_i64_i64 (int64_t a, int64_t b, int128_t *result)
 Multiply two signed 64-bit integers and store the result in a 128-bit integer.

Detailed Description

Inline implementation of functions declared in math_extras.h.

Macro Definition Documentation

◆ use_builtin

#define use_builtin ( x)
Value:
#define HAS_BUILTIN(x)
Check if the compiler supports the built-in function x.
Definition toolchain.h:46

Function Documentation

◆ i128_multiply_i64_i64()

void i128_multiply_i64_i64 ( int64_t a,
int64_t b,
int128_t * result )
inlinestatic

Multiply two signed 64-bit integers and store the result in a 128-bit integer.

This function performs a full precision multiplication of two signed 64-bit values. The result is guaranteed to fit in a 128-bit representation without overflow.

Parameters
aMultiplicand.
bMultiplier.
resultPointer to the int128_t structure where the result will be stored.

◆ size_add_overflow()

bool size_add_overflow ( size_t a,
size_t b,
size_t * result )
inlinestatic

◆ size_mul_overflow()

bool size_mul_overflow ( size_t a,
size_t b,
size_t * result )
inlinestatic

◆ u16_add_overflow()

bool u16_add_overflow ( uint16_t a,
uint16_t b,
uint16_t * result )
inlinestatic

◆ u16_mul_overflow()

bool u16_mul_overflow ( uint16_t a,
uint16_t b,
uint16_t * result )
inlinestatic

◆ u32_add_overflow()

bool u32_add_overflow ( uint32_t a,
uint32_t b,
uint32_t * result )
inlinestatic

◆ u32_count_leading_zeros()

int u32_count_leading_zeros ( uint32_t x)
inlinestatic

◆ u32_count_trailing_zeros()

int u32_count_trailing_zeros ( uint32_t x)
inlinestatic

◆ u32_mul_overflow()

bool u32_mul_overflow ( uint32_t a,
uint32_t b,
uint32_t * result )
inlinestatic

◆ u64_add_overflow()

bool u64_add_overflow ( uint64_t a,
uint64_t b,
uint64_t * result )
inlinestatic

◆ u64_count_leading_zeros()

int u64_count_leading_zeros ( uint64_t x)
inlinestatic

◆ u64_count_trailing_zeros()

int u64_count_trailing_zeros ( uint64_t x)
inlinestatic

◆ u64_mul_overflow()

bool u64_mul_overflow ( uint64_t a,
uint64_t b,
uint64_t * result )
inlinestatic