Commonly used includes, types and macros.
Copyright (c) 2009-2018 Microchip Technology Inc. and its subsidiaries.
#include "preprocessor.h"
#include <parts.h>
#include <avr32/io.h>
#include "header_files/uc3d_defines_fix.h"
#include "header_files/uc3l3_l4_defines_fix.h"
#include <stddef.h>
#include <stdlib.h>
#include <stdbool.h>
#include <stdint.h>
#include "interrupt.h"
Data Structures | |
struct | StructCPtr |
Structure of pointers to constant 64-, 32-, 16- and 8-bit unsigned integers. More... | |
struct | StructCVPtr |
Structure of pointers to constant volatile 64-, 32-, 16- and 8-bit unsigned integers. More... | |
struct | StructPtr |
Structure of pointers to 64-, 32-, 16- and 8-bit unsigned integers. More... | |
struct | StructVPtr |
Structure of pointers to volatile 64-, 32-, 16- and 8-bit unsigned integers. More... | |
union | Union16 |
16-bit union. More... | |
union | Union32 |
32-bit union. More... | |
union | Union64 |
64-bit union. More... | |
union | UnionCPtr |
Union of pointers to constant 64-, 32-, 16- and 8-bit unsigned integers. More... | |
union | UnionCVPtr |
Union of pointers to constant volatile 64-, 32-, 16- and 8-bit unsigned integers. More... | |
union | UnionPtr |
Union of pointers to 64-, 32-, 16- and 8-bit unsigned integers. More... | |
union | UnionVPtr |
Union of pointers to volatile 64-, 32-, 16- and 8-bit unsigned integers. More... | |
Macros | |
#define | ADDR_COPY_DST_SRC_16(dst, src) memcpy((&(dst)), (&(src)), sizeof(uint16_t)) |
Address copy from the source to the Destination Memory. More... | |
#define | ADDR_COPY_DST_SRC_64(dst, src) do {dst=src;}while(0) |
#define | Assert(expr) ((void) 0) |
This macro is used to test fatal errors. More... | |
#define | barrier() asm volatile("" ::: "memory") |
Memory barrier. More... | |
#define | CCPU_ENDIAN_TO_LE16(x) |
#define | CCPU_ENDIAN_TO_LE32(x) |
#define | CCPU_ENDIAN_TO_LE64(x) |
#define | CLE16_TO_CPU_ENDIAN(x) CCPU_ENDIAN_TO_LE16(x) |
#define | CLE32_TO_CPU_ENDIAN(x) CCPU_ENDIAN_TO_LE32(x) |
#define | CLE64_TO_CPU_ENDIAN(x) CCPU_ENDIAN_TO_LE64(x) |
#define | CMD_ID_OCTET (0) |
#define | COMPILER_ALIGNED(a) __attribute__((__aligned__(a))) |
Set aligned boundary. More... | |
#define | COMPILER_PACK_RESET() COMPILER_PRAGMA(pack()) |
Set default alignment for subsequent struct and union definitions. More... | |
#define | COMPILER_PACK_SET(alignment) COMPILER_PRAGMA(pack(alignment)) |
Set maximum alignment for subsequent struct and union definitions to alignment. More... | |
#define | COMPILER_PRAGMA(arg) _Pragma(#arg) |
Emit the compiler pragma arg. More... | |
#define | COMPILER_WORD_ALIGNED __attribute__((__aligned__(4))) |
Set word-aligned boundary. More... | |
#define | convert_32_bit_to_byte_array(value, data) memcpy((data), (&(value)), sizeof(uint32_t)) |
#define | convert_64_bit_to_byte_array(value, data) memcpy((data), (&(value)), sizeof(uint64_t)) |
#define | CPU_ENDIAN_TO_LE16(x) swap16(x) |
#define | CPU_ENDIAN_TO_LE32(x) swap32(x) |
#define | CPU_ENDIAN_TO_LE64(x) swap64(x) |
#define | cpu_relax() __asm__ __volatile__("sub pc, pc, -4" ::: "memory", "cc") |
This macro makes the CPU take a small break for a few cycles. This should be used when waiting for an event. It will reduce the internal bus load. More... | |
#define | div_ceil(a, b) (((a) + (b) - 1) / (b)) |
Calculate \( \left\lceil \frac{a}{b} \right\rceil \) using integer arithmetic. More... | |
#define | FLASH_DECLARE(x) const x |
#define | FLASH_EXTERN(x) extern const x |
#define | FUNC_PTR void * |
#define | Get_system_register(reg) sysreg_read(reg) |
#define | LE16_TO_CPU_ENDIAN(x) swap16(x) |
#define | LE32_TO_CPU_ENDIAN(x) swap32(x) |
#define | LE64_TO_CPU_ENDIAN(x) swap64(x) |
#define | Long_call(addr) ((*(void (*)(void))(addr))()) |
Calls the routine at address addr. More... | |
#define | MEMCPY_ENDIAN memcpy_be |
#define | nop() do { __asm__ __volatile__ ("nop"); } while (0) |
#define | PGM_READ_BLOCK(dst, src, len) memcpy((dst), (src), (len)) |
#define | PGM_READ_BYTE(x) *(x) |
#define | PGM_READ_WORD(x) *(x) |
#define | Reset_CPU() |
Resets the CPU by software. More... | |
#define | Set_system_register(reg, val) sysreg_write(reg, val) |
#define | SHORTENUM __attribute__ ((packed)) |
#define | sysreg_write(reg, val) __builtin_mtsr(reg, val) |
Set value of system register. More... | |
#define | UNUSED(v) (void)(v) |
Marking v as a unused parameter or value. More... | |
#define | unused(v) do { (void)(v); } while(0) |
Marking v as a unused parameter or value. More... | |
System Register Access | |
#define | sysreg_read(reg) __builtin_mfsr(reg) |
Get value of system register. More... | |
Tag functions as deprecated | |
Tagging a function as deprecated will produce a warning when and only when the function is called. Usage is to add the DEPRECATED symbol before the function definition. E.g.: DEPRECATED uint8_t some_deprecated_function (void) { ... }
| |
#define | __DEPRECATED__ __attribute__((__deprecated__)) |
Usual Constants | |
#define | DISABLE 0 |
#define | ENABLE 1 |
#define | false 0 |
#define | true 1 |
#define | PASS 0 |
#define | FAIL 1 |
#define | LOW 0 |
#define | HIGH 1 |
Optimization Control | |
#define | is_constant(exp) __builtin_constant_p(exp) |
Determine if an expression evaluates to a constant value. More... | |
Bit-Field Handling | |
#define | Rd_bits(value, mask) ((value) & (mask)) |
Reads the bits of a value specified by a given bit-mask. More... | |
#define | Wr_bits(lvalue, mask, bits) |
Writes the bits of a C lvalue specified by a given bit-mask. More... | |
#define | Tst_bits(value, mask) (Rd_bits(value, mask) != 0) |
Tests the bits of a value specified by a given bit-mask. More... | |
#define | Clr_bits(lvalue, mask) ((lvalue) &= ~(mask)) |
Clears the bits of a C lvalue specified by a given bit-mask. More... | |
#define | Set_bits(lvalue, mask) ((lvalue) |= (mask)) |
Sets the bits of a C lvalue specified by a given bit-mask. More... | |
#define | Tgl_bits(lvalue, mask) ((lvalue) ^= (mask)) |
Toggles the bits of a C lvalue specified by a given bit-mask. More... | |
#define | Rd_bitfield(value, mask) (Rd_bits( value, mask) >> ctz(mask)) |
Reads the bit-field of a value specified by a given bit-mask. More... | |
#define | Wr_bitfield(lvalue, mask, bitfield) (Wr_bits(lvalue, mask, (U32)(bitfield) << ctz(mask))) |
Writes the bit-field of a C lvalue specified by a given bit-mask. More... | |
Zero-Bit Counting | |
Under AVR32-GCC, __builtin_clz and __builtin_ctz behave like macros when applied to constant expressions (values known at compile time), so they are more optimized than the use of the corresponding assembly instructions and they can be used as constant expressions e.g. to initialize objects having static storage duration, and like the corresponding assembly instructions when applied to non-constant expressions (values unknown at compile time), so they are more optimized than an assembly periphrasis. Hence, clz and ctz ensure a possible and optimized behavior for both constant and non-constant expressions. | |
#define | clz(u) ((u) ? __builtin_clz(u) : 32) |
Counts the leading zero bits of the given value considered as a 32-bit integer. More... | |
#define | ctz(u) ((u) ? __builtin_ctz(u) : 32) |
Counts the trailing zero bits of the given value considered as a 32-bit integer. More... | |
Bit Reversing | |
#define | bit_reverse8(u8) ((U8)(bit_reverse32((U8)(u8)) >> 24)) |
Reverses the bits of u8. More... | |
#define | bit_reverse16(u16) ((U16)(bit_reverse32((U16)(u16)) >> 16)) |
Reverses the bits of u16. More... | |
#define | bit_reverse32(u32) |
Reverses the bits of u32. More... | |
#define | bit_reverse64(u64) |
Reverses the bits of u64. More... | |
Alignment | |
#define | Test_align(val, n) (!Tst_bits( val, (n) - 1 ) ) |
Tests alignment of the number val with the n boundary. More... | |
#define | Get_align(val, n) ( Rd_bits( val, (n) - 1 ) ) |
Gets alignment of the number val with respect to the n boundary. More... | |
#define | Set_align(lval, n, alg) ( Wr_bits(lval, (n) - 1, alg) ) |
Sets alignment of the lvalue number lval to alg with respect to the n boundary. More... | |
#define | Align_up(val, n) (((val) + ((n) - 1)) & ~((n) - 1)) |
Aligns the number val with the upper n boundary. More... | |
#define | Align_down(val, n) ( (val) & ~((n) - 1)) |
Aligns the number val with the lower n boundary. More... | |
Mathematics | |
The same considerations as for clz and ctz apply here but AVR32-GCC does not provide built-in functions to access the assembly instructions abs, min and max and it does not produce them by itself in most cases, so two sets of macros are defined here:
| |
#define | Abs(a) (((a) < 0 ) ? -(a) : (a)) |
Takes the absolute value of a. More... | |
#define | Min(a, b) (((a) < (b)) ? (a) : (b)) |
Takes the minimal value of a and b. More... | |
#define | Max(a, b) (((a) > (b)) ? (a) : (b)) |
Takes the maximal value of a and b. More... | |
#define | abs(a) |
Takes the absolute value of a. More... | |
#define | min(a, b) |
Takes the minimal value of a and b. More... | |
#define | max(a, b) |
Takes the maximal value of a and b. More... | |
CPU Status Register Access | |
#define | Is_global_exception_enabled() (!Tst_bits(Get_system_register(AVR32_SR), AVR32_SR_EM_MASK)) |
Tells whether exceptions are globally enabled. More... | |
#define | Disable_global_exception() ({__asm__ __volatile__ ("ssrf\t%0" : : "i" (AVR32_SR_EM_OFFSET));}) |
Disables exceptions globally. More... | |
#define | Enable_global_exception() ({__asm__ __volatile__ ("csrf\t%0" : : "i" (AVR32_SR_EM_OFFSET));}) |
Enables exceptions globally. More... | |
Debug Register Access | |
#define | Get_debug_register(dbgreg) __builtin_mfdr(dbgreg) |
Gets the value of the dbgreg debug register. More... | |
#define | Set_debug_register(dbgreg, value) __builtin_mtdr(dbgreg, value) |
Sets the value of the dbgreg debug register to value. More... | |
Force Assembly Inline Code Section | |
#define | __always_inline inline __attribute__((__always_inline__)) |
MCU Endianism Handling | |
AVR32 is MCU big endianism. | |
#define | MSB(u16) (((U8 *)&(u16))[0]) |
Most significant byte of u16. More... | |
#define | LSB(u16) (((U8 *)&(u16))[1]) |
Least significant byte of u16. More... | |
#define | MSH(u32) (((U16 *)&(u32))[0]) |
Most significant half-word of u32. More... | |
#define | LSH(u32) (((U16 *)&(u32))[1]) |
Least significant half-word of u32. More... | |
#define | MSB0W(u32) (((U8 *)&(u32))[0]) |
Most significant byte of 1st rank of u32. More... | |
#define | MSB1W(u32) (((U8 *)&(u32))[1]) |
Most significant byte of 2nd rank of u32. More... | |
#define | MSB2W(u32) (((U8 *)&(u32))[2]) |
Most significant byte of 3rd rank of u32. More... | |
#define | MSB3W(u32) (((U8 *)&(u32))[3]) |
Most significant byte of 4th rank of u32. More... | |
#define | LSB3W(u32) MSB0W(u32) |
Least significant byte of 4th rank of u32. More... | |
#define | LSB2W(u32) MSB1W(u32) |
Least significant byte of 3rd rank of u32. More... | |
#define | LSB1W(u32) MSB2W(u32) |
Least significant byte of 2nd rank of u32. More... | |
#define | LSB0W(u32) MSB3W(u32) |
Least significant byte of 1st rank of u32. More... | |
#define | MSW(u64) (((U32 *)&(u64))[0]) |
Most significant word of u64. More... | |
#define | LSW(u64) (((U32 *)&(u64))[1]) |
Least significant word of u64. More... | |
#define | MSH0(u64) (((U16 *)&(u64))[0]) |
Most significant half-word of 1st rank of u64. More... | |
#define | MSH1(u64) (((U16 *)&(u64))[1]) |
Most significant half-word of 2nd rank of u64. More... | |
#define | MSH2(u64) (((U16 *)&(u64))[2]) |
Most significant half-word of 3rd rank of u64. More... | |
#define | MSH3(u64) (((U16 *)&(u64))[3]) |
Most significant half-word of 4th rank of u64. More... | |
#define | LSH3(u64) MSH0(u64) |
Least significant half-word of 4th rank of u64. More... | |
#define | LSH2(u64) MSH1(u64) |
Least significant half-word of 3rd rank of u64. More... | |
#define | LSH1(u64) MSH2(u64) |
Least significant half-word of 2nd rank of u64. More... | |
#define | LSH0(u64) MSH3(u64) |
Least significant half-word of 1st rank of u64. More... | |
#define | MSB0D(u64) (((U8 *)&(u64))[0]) |
Most significant byte of 1st rank of u64. More... | |
#define | MSB1D(u64) (((U8 *)&(u64))[1]) |
Most significant byte of 2nd rank of u64. More... | |
#define | MSB2D(u64) (((U8 *)&(u64))[2]) |
Most significant byte of 3rd rank of u64. More... | |
#define | MSB3D(u64) (((U8 *)&(u64))[3]) |
Most significant byte of 4th rank of u64. More... | |
#define | MSB4D(u64) (((U8 *)&(u64))[4]) |
Most significant byte of 5th rank of u64. More... | |
#define | MSB5D(u64) (((U8 *)&(u64))[5]) |
Most significant byte of 6th rank of u64. More... | |
#define | MSB6D(u64) (((U8 *)&(u64))[6]) |
Most significant byte of 7th rank of u64. More... | |
#define | MSB7D(u64) (((U8 *)&(u64))[7]) |
Most significant byte of 8th rank of u64. More... | |
#define | LSB7D(u64) MSB0D(u64) |
Least significant byte of 8th rank of u64. More... | |
#define | LSB6D(u64) MSB1D(u64) |
Least significant byte of 7th rank of u64. More... | |
#define | LSB5D(u64) MSB2D(u64) |
Least significant byte of 6th rank of u64. More... | |
#define | LSB4D(u64) MSB3D(u64) |
Least significant byte of 5th rank of u64. More... | |
#define | LSB3D(u64) MSB4D(u64) |
Least significant byte of 4th rank of u64. More... | |
#define | LSB2D(u64) MSB5D(u64) |
Least significant byte of 3rd rank of u64. More... | |
#define | LSB1D(u64) MSB6D(u64) |
Least significant byte of 2nd rank of u64. More... | |
#define | LSB0D(u64) MSB7D(u64) |
Least significant byte of 1st rank of u64. More... | |
#define | LE16(x) Swap16(x) |
#define | le16_to_cpu(x) swap16(x) |
#define | cpu_to_le16(x) swap16(x) |
#define | LE16_TO_CPU(x) Swap16(x) |
#define | CPU_TO_LE16(x) Swap16(x) |
#define | be16_to_cpu(x) (x) |
#define | cpu_to_be16(x) (x) |
#define | BE16_TO_CPU(x) (x) |
#define | CPU_TO_BE16(x) (x) |
#define | le32_to_cpu(x) swap32(x) |
#define | cpu_to_le32(x) swap32(x) |
#define | LE32_TO_CPU(x) Swap32(x) |
#define | CPU_TO_LE32(x) Swap32(x) |
#define | be32_to_cpu(x) (x) |
#define | cpu_to_be32(x) (x) |
#define | BE32_TO_CPU(x) (x) |
#define | CPU_TO_BE32(x) (x) |
Endianism Conversion | |
The same considerations as for clz and ctz apply here but AVR32-GCC's __builtin_bswap_16 and __builtin_bswap_32 do not behave like macros when applied to constant expressions, so two sets of macros are defined here:
| |
#define | Swap16(u16) |
Toggles the endianism of u16 (by swapping its bytes). More... | |
#define | Swap32(u32) |
Toggles the endianism of u32 (by swapping its bytes). More... | |
#define | Swap64(u64) |
Toggles the endianism of u64 (by swapping its bytes). More... | |
#define | swap16(u16) ((U16)__builtin_bswap_16((U16)(u16))) |
Toggles the endianism of u16 (by swapping its bytes). More... | |
#define | swap32(u32) ((U32)__builtin_bswap_32((U32)(u32))) |
Toggles the endianism of u32 (by swapping its bytes). More... | |
#define | swap64(u64) |
Toggles the endianism of u64 (by swapping its bytes). More... | |
Typedefs | |
Usual Types | |
typedef unsigned char | Bool |
Boolean. More... | |
typedef unsigned char | bool |
Boolean. More... | |
typedef int8_t | S8 |
8-bit signed integer. More... | |
typedef uint8_t | U8 |
8-bit unsigned integer. More... | |
typedef int16_t | S16 |
16-bit signed integer. More... | |
typedef uint16_t | U16 |
16-bit unsigned integer. More... | |
typedef uint16_t | le16_t |
typedef uint16_t | be16_t |
typedef int32_t | S32 |
32-bit signed integer. More... | |
typedef uint32_t | U32 |
32-bit unsigned integer. More... | |
typedef uint32_t | le32_t |
typedef uint32_t | be32_t |
typedef signed long long int | S64 |
64-bit signed integer. More... | |
typedef unsigned long long int | U64 |
64-bit unsigned integer. More... | |
typedef float | F32 |
32-bit floating-point number. More... | |
typedef double | F64 |
64-bit floating-point number. More... | |
typedef uint32_t | iram_size_t |
Status Types | |
typedef bool | Status_bool_t |
Boolean status. More... | |
typedef U8 | Status_t |
8-bit-coded status. More... | |
Functions | |
static void | convert_16_bit_to_byte_address (uint64_t value, uint8_t *data) |
static void | convert_16_bit_to_byte_array (uint16_t value, uint8_t *data) |
static uint16_t | convert_byte_array_to_16_bit (uint8_t *data) |
static uint32_t | convert_byte_array_to_32_bit (uint8_t *data) |
static uint64_t | convert_byte_array_to_64_bit (uint8_t *data) |
static void | convert_spec_16_bit_to_byte_array (uint16_t value, uint8_t *data) |
static void * | memcpy_be (void *s1, const void *s2, char n) |
Logarithmic functions | |
int_fast8_t | ilog2_undefined (void) |
static int_fast8_t | ilog2 (uint32_t x) |
Calculate the base-2 logarithm of a number rounded down to the nearest integer. More... | |
Target Abstraction | |
#define | _GLOBEXT_ extern |
extern storage-class specifier. More... | |
#define | _CONST_TYPE_ const |
const type qualifier. More... | |
#define | _MEM_TYPE_SLOW_ |
Slow memory type. More... | |
#define | _MEM_TYPE_MEDFAST_ |
Fairly fast memory type. More... | |
#define | _MEM_TYPE_FAST_ |
Fast memory type. More... | |
#define | memcmp_ram2ram memcmp |
Target-specific memcmp of RAM to RAM. More... | |
#define | memcmp_code2ram memcmp |
Target-specific memcmp of RAM to NVRAM. More... | |
#define | memcpy_ram2ram memcpy |
Target-specific memcpy from RAM to RAM. More... | |
#define | memcpy_code2ram memcpy |
Target-specific memcpy from NVRAM to RAM. More... | |
#define | LSB0(u32) LSB0W(u32) |
Least significant byte of 1st rank of u32. More... | |
#define | LSB1(u32) LSB1W(u32) |
Least significant byte of 2nd rank of u32. More... | |
#define | LSB2(u32) LSB2W(u32) |
Least significant byte of 3rd rank of u32. More... | |
#define | LSB3(u32) LSB3W(u32) |
Least significant byte of 4th rank of u32. More... | |
#define | MSB3(u32) MSB3W(u32) |
Most significant byte of 4th rank of u32. More... | |
#define | MSB2(u32) MSB2W(u32) |
Most significant byte of 3rd rank of u32. More... | |
#define | MSB1(u32) MSB1W(u32) |
Most significant byte of 2nd rank of u32. More... | |
#define | MSB0(u32) MSB0W(u32) |
Most significant byte of 1st rank of u32. More... | |
typedef U8 | Byte |
8-bit unsigned integer. More... | |
#define __always_inline inline __attribute__((__always_inline__)) |
#define _CONST_TYPE_ const |
const type qualifier.
#define _GLOBEXT_ extern |
extern storage-class specifier.
#define _MEM_TYPE_FAST_ |
Fast memory type.
#define _MEM_TYPE_MEDFAST_ |
Fairly fast memory type.
#define _MEM_TYPE_SLOW_ |
Slow memory type.
#define Abs | ( | a | ) | (((a) < 0 ) ? -(a) : (a)) |
Takes the absolute value of a.
a | Input value. |
#define abs | ( | a | ) |
Takes the absolute value of a.
a | Input value. |
Referenced by is_acc_abs_angle_x(), is_acc_abs_angle_y(), and round0().
#define ADDR_COPY_DST_SRC_16 | ( | dst, | |
src | |||
) | memcpy((&(dst)), (&(src)), sizeof(uint16_t)) |
Address copy from the source to the Destination Memory.
#define ADDR_COPY_DST_SRC_64 | ( | dst, | |
src | |||
) | do {dst=src;}while(0) |
#define Align_down | ( | val, | |
n | |||
) | ( (val) & ~((n) - 1)) |
Aligns the number val with the lower n boundary.
val | Input value. |
n | Boundary. |
Referenced by flashc_memset64(), host_read_p_rxpacket(), host_set_p_txpacket(), host_write_p_txpacket(), usb_read_ep_rxpacket(), usb_set_ep_txpacket(), and usb_write_ep_txpacket().
#define Align_up | ( | val, | |
n | |||
) | (((val) + ((n) - 1)) & ~((n) - 1)) |
Aligns the number val with the upper n boundary.
val | Input value. |
n | Boundary. |
#define Assert | ( | expr | ) | ((void) 0) |
This macro is used to test fatal errors.
The macro tests if the expression is false. If it is, a fatal error is detected and the application hangs up. If TEST_SUITE_DEFINE_ASSERT_MACRO is defined, a unit test version of the macro is used, to allow execution of further tests after a false expression.
expr | Expression to evaluate and supposed to be nonzero. |
Referenced by adc_check_eoc(), adc_check_ovr(), adc_configure(), adc_disable(), adc_enable(), adc_get_latest_value(), adc_get_status(), adc_get_value(), adc_start(), fifo_init(), and flashc_memcpy().
#define be16_to_cpu | ( | x | ) | (x) |
#define BE16_TO_CPU | ( | x | ) | (x) |
#define be32_to_cpu | ( | x | ) | (x) |
#define BE32_TO_CPU | ( | x | ) | (x) |
#define bit_reverse16 | ( | u16 | ) | ((U16)(bit_reverse32((U16)(u16)) >> 16)) |
Reverses the bits of u16.
u16 | U16 of which to reverse the bits. |
#define bit_reverse32 | ( | u32 | ) |
Reverses the bits of u32.
u32 | U32 of which to reverse the bits. |
#define bit_reverse64 | ( | u64 | ) |
Reverses the bits of u64.
u64 | U64 of which to reverse the bits. |
#define bit_reverse8 | ( | u8 | ) | ((U8)(bit_reverse32((U8)(u8)) >> 24)) |
Reverses the bits of u8.
u8 | U8 of which to reverse the bits. |
#define CCPU_ENDIAN_TO_LE16 | ( | x | ) |
#define CCPU_ENDIAN_TO_LE32 | ( | x | ) |
#define CCPU_ENDIAN_TO_LE64 | ( | x | ) |
#define CLE16_TO_CPU_ENDIAN | ( | x | ) | CCPU_ENDIAN_TO_LE16(x) |
#define CLE32_TO_CPU_ENDIAN | ( | x | ) | CCPU_ENDIAN_TO_LE32(x) |
#define CLE64_TO_CPU_ENDIAN | ( | x | ) | CCPU_ENDIAN_TO_LE64(x) |
#define Clr_bits | ( | lvalue, | |
mask | |||
) | ((lvalue) &= ~(mask)) |
Clears the bits of a C lvalue specified by a given bit-mask.
lvalue | C lvalue of which to clear bits. |
mask | Bit-mask indicating bits to clear. |
Referenced by LED_Off().
#define clz | ( | u | ) | ((u) ? __builtin_clz(u) : 32) |
Counts the leading zero bits of the given value considered as a 32-bit integer.
u | Value of which to count the leading zero bits. |
Referenced by _get_interrupt_handler(), flashc_set_bootloader_protected_size(), and ilog2().
#define CMD_ID_OCTET (0) |
#define convert_32_bit_to_byte_array | ( | value, | |
data | |||
) | memcpy((data), (&(value)), sizeof(uint32_t)) |
#define convert_64_bit_to_byte_array | ( | value, | |
data | |||
) | memcpy((data), (&(value)), sizeof(uint64_t)) |
#define CPU_ENDIAN_TO_LE16 | ( | x | ) | swap16(x) |
#define CPU_ENDIAN_TO_LE32 | ( | x | ) | swap32(x) |
#define CPU_ENDIAN_TO_LE64 | ( | x | ) | swap64(x) |
#define cpu_relax | ( | ) | __asm__ __volatile__("sub pc, pc, -4" ::: "memory", "cc") |
This macro makes the CPU take a small break for a few cycles. This should be used when waiting for an event. It will reduce the internal bus load.
"sub pc, pc, -4" (or "sub pc, -2") forces the IF stage to wait until the result of the calculation before it can fetch the next instruction. This makes sure there are nothing stuck in the LS pipe when you start a new iteration and guarantee to flush the pipeline without having any other effect. (A nop doesn't have any effect on the IF stage.)
#define cpu_to_be16 | ( | x | ) | (x) |
#define CPU_TO_BE16 | ( | x | ) | (x) |
#define cpu_to_be32 | ( | x | ) | (x) |
#define CPU_TO_BE32 | ( | x | ) | (x) |
#define cpu_to_le16 | ( | x | ) | swap16(x) |
#define CPU_TO_LE16 | ( | x | ) | Swap16(x) |
#define cpu_to_le32 | ( | x | ) | swap32(x) |
#define CPU_TO_LE32 | ( | x | ) | Swap32(x) |
#define ctz | ( | u | ) | ((u) ? __builtin_ctz(u) : 32) |
Counts the trailing zero bits of the given value considered as a 32-bit integer.
u | Value of which to count the trailing zero bits. |
Referenced by LED_Display_Field(), LED_Display_Mask(), LED_Get_Intensity(), LED_Off(), LED_On(), LED_Set_Intensity(), and LED_Toggle().
#define DISABLE 0 |
#define Disable_global_exception | ( | ) | ({__asm__ __volatile__ ("ssrf\t%0" : : "i" (AVR32_SR_EM_OFFSET));}) |
Disables exceptions globally.
#define div_ceil | ( | a, | |
b | |||
) | (((a) + (b) - 1) / (b)) |
Calculate \( \left\lceil \frac{a}{b} \right\rceil \) using integer arithmetic.
a | An integer |
b | Another integer |
#define ENABLE 1 |
#define Enable_global_exception | ( | ) | ({__asm__ __volatile__ ("csrf\t%0" : : "i" (AVR32_SR_EM_OFFSET));}) |
Enables exceptions globally.
Referenced by _init_startup().
#define FAIL 1 |
Referenced by adc_check_ovr().
#define false 0 |
#define FLASH_DECLARE | ( | x | ) | const x |
#define FLASH_EXTERN | ( | x | ) | extern const x |
#define FUNC_PTR void * |
#define Get_align | ( | val, | |
n | |||
) | ( Rd_bits( val, (n) - 1 ) ) |
Gets alignment of the number val with respect to the n boundary.
val | Input value. |
n | Boundary. |
Referenced by flashc_memset64(), host_read_p_rxpacket(), host_write_p_txpacket(), usb_read_ep_rxpacket(), and usb_write_ep_txpacket().
#define Get_debug_register | ( | dbgreg | ) | __builtin_mfdr(dbgreg) |
Gets the value of the dbgreg debug register.
dbgreg | Address of the debug register of which to get the value. |
#define HIGH 1 |
#define is_constant | ( | exp | ) | __builtin_constant_p(exp) |
Determine if an expression evaluates to a constant value.
exp | Any expression |
Referenced by ilog2().
#define Is_global_exception_enabled | ( | ) | (!Tst_bits(Get_system_register(AVR32_SR), AVR32_SR_EM_MASK)) |
Tells whether exceptions are globally enabled.
1
if exceptions are globally enabled, else 0
. #define LE16 | ( | x | ) | Swap16(x) |
#define le16_to_cpu | ( | x | ) | swap16(x) |
#define LE16_TO_CPU | ( | x | ) | Swap16(x) |
#define LE16_TO_CPU_ENDIAN | ( | x | ) | swap16(x) |
#define le32_to_cpu | ( | x | ) | swap32(x) |
#define LE32_TO_CPU | ( | x | ) | Swap32(x) |
#define LE32_TO_CPU_ENDIAN | ( | x | ) | swap32(x) |
#define LE64_TO_CPU_ENDIAN | ( | x | ) | swap64(x) |
#define Long_call | ( | addr | ) | ((*(void (*)(void))(addr))()) |
Calls the routine at address addr.
It generates a long call opcode.
For example, `Long_call(0x80000000)' generates a software reset on a UC3 if it is invoked from the CPU supervisor mode.
addr | Address of the routine to call. |
#define LOW 0 |
#define LSB | ( | u16 | ) | (((U8 *)&(u16))[1]) |
Least significant byte of u16.
Least significant byte of 1st rank of u32.
Referenced by cdc_get_line_coding(), and cdc_set_line_coding().
#define LSB0D | ( | u64 | ) | MSB7D(u64) |
Least significant byte of 1st rank of u64.
Least significant byte of 2nd rank of u32.
Referenced by cdc_get_line_coding(), and cdc_set_line_coding().
#define LSB1D | ( | u64 | ) | MSB6D(u64) |
Least significant byte of 2nd rank of u64.
Least significant byte of 3rd rank of u32.
Referenced by cdc_get_line_coding(), and cdc_set_line_coding().
#define LSB2D | ( | u64 | ) | MSB5D(u64) |
Least significant byte of 3rd rank of u64.
Least significant byte of 4th rank of u32.
Referenced by cdc_get_line_coding(), and cdc_set_line_coding().
#define LSB3D | ( | u64 | ) | MSB4D(u64) |
Least significant byte of 4th rank of u64.
#define LSB4D | ( | u64 | ) | MSB3D(u64) |
Least significant byte of 5th rank of u64.
#define LSB5D | ( | u64 | ) | MSB2D(u64) |
Least significant byte of 6th rank of u64.
#define LSB6D | ( | u64 | ) | MSB1D(u64) |
Least significant byte of 7th rank of u64.
#define LSB7D | ( | u64 | ) | MSB0D(u64) |
Least significant byte of 8th rank of u64.
#define LSH0 | ( | u64 | ) | MSH3(u64) |
Least significant half-word of 1st rank of u64.
#define LSH1 | ( | u64 | ) | MSH2(u64) |
Least significant half-word of 2nd rank of u64.
#define LSH2 | ( | u64 | ) | MSH1(u64) |
Least significant half-word of 3rd rank of u64.
#define LSH3 | ( | u64 | ) | MSH0(u64) |
Least significant half-word of 4th rank of u64.
#define LSW | ( | u64 | ) | (((U32 *)&(u64))[1]) |
Least significant word of u64.
#define Max | ( | a, | |
b | |||
) | (((a) > (b)) ? (a) : (b)) |
Takes the maximal value of a and b.
a | Input value. |
b | Input value. |
#define max | ( | a, | |
b | |||
) |
Takes the maximal value of a and b.
a | Input value. |
b | Input value. |
Referenced by flashc_set_bootloader_protected_size().
#define memcmp_code2ram memcmp |
Target-specific memcmp of RAM to NVRAM.
#define memcmp_ram2ram memcmp |
Target-specific memcmp of RAM to RAM.
#define memcpy_code2ram memcpy |
Target-specific memcpy from NVRAM to RAM.
#define MEMCPY_ENDIAN memcpy_be |
#define memcpy_ram2ram memcpy |
Target-specific memcpy from RAM to RAM.
#define Min | ( | a, | |
b | |||
) | (((a) < (b)) ? (a) : (b)) |
Takes the minimal value of a and b.
a | Input value. |
b | Input value. |
#define min | ( | a, | |
b | |||
) |
Takes the minimal value of a and b.
a | Input value. |
b | Input value. |
Referenced by flashc_erase_gp_fuse_bitfield(), flashc_memset64(), flashc_read_gp_fuse_bitfield(), flashc_set_bootloader_protected_size(), flashc_set_gp_fuse_bitfield(), flashc_write_gp_fuse_bitfield(), host_check_class(), host_read_p_rxpacket(), host_set_p_txpacket(), host_write_p_txpacket(), usb_read_ep_rxpacket(), usb_set_ep_txpacket(), and usb_write_ep_txpacket().
#define MSB | ( | u16 | ) | (((U8 *)&(u16))[0]) |
Most significant byte of u16.
#define MSB0D | ( | u64 | ) | (((U8 *)&(u64))[0]) |
Most significant byte of 1st rank of u64.
#define MSB1D | ( | u64 | ) | (((U8 *)&(u64))[1]) |
Most significant byte of 2nd rank of u64.
#define MSB2D | ( | u64 | ) | (((U8 *)&(u64))[2]) |
Most significant byte of 3rd rank of u64.
#define MSB3D | ( | u64 | ) | (((U8 *)&(u64))[3]) |
Most significant byte of 4th rank of u64.
#define MSB4D | ( | u64 | ) | (((U8 *)&(u64))[4]) |
Most significant byte of 5th rank of u64.
#define MSB5D | ( | u64 | ) | (((U8 *)&(u64))[5]) |
Most significant byte of 6th rank of u64.
#define MSB6D | ( | u64 | ) | (((U8 *)&(u64))[6]) |
Most significant byte of 7th rank of u64.
#define MSB7D | ( | u64 | ) | (((U8 *)&(u64))[7]) |
Most significant byte of 8th rank of u64.
#define MSH0 | ( | u64 | ) | (((U16 *)&(u64))[0]) |
Most significant half-word of 1st rank of u64.
#define MSH1 | ( | u64 | ) | (((U16 *)&(u64))[1]) |
Most significant half-word of 2nd rank of u64.
#define MSH2 | ( | u64 | ) | (((U16 *)&(u64))[2]) |
Most significant half-word of 3rd rank of u64.
#define MSH3 | ( | u64 | ) | (((U16 *)&(u64))[3]) |
Most significant half-word of 4th rank of u64.
#define MSW | ( | u64 | ) | (((U32 *)&(u64))[0]) |
Most significant word of u64.
#define nop | ( | ) | do { __asm__ __volatile__ ("nop"); } while (0) |
#define PASS 0 |
#define PGM_READ_BLOCK | ( | dst, | |
src, | |||
len | |||
) | memcpy((dst), (src), (len)) |
#define PGM_READ_BYTE | ( | x | ) | *(x) |
#define PGM_READ_WORD | ( | x | ) | *(x) |
Reads the bit-field of a value specified by a given bit-mask.
value | Value to read a bit-field from. |
mask | Bit-mask indicating the bit-field to read. |
Referenced by LED_Read_Display_Field().
#define Rd_bits | ( | value, | |
mask | |||
) | ((value) & (mask)) |
Reads the bits of a value specified by a given bit-mask.
value | Value to read bits from. |
mask | Bit-mask indicating bits to read. |
Referenced by LED_Read_Display_Mask().
#define Reset_CPU | ( | ) |
Resets the CPU by software.
#define Set_align | ( | lval, | |
n, | |||
alg | |||
) | ( Wr_bits(lval, (n) - 1, alg) ) |
Sets alignment of the lvalue number lval to alg with respect to the n boundary.
lval | Input/output lvalue. |
n | Boundary. |
alg | Alignment. |
#define Set_bits | ( | lvalue, | |
mask | |||
) | ((lvalue) |= (mask)) |
Sets the bits of a C lvalue specified by a given bit-mask.
lvalue | C lvalue of which to set bits. |
mask | Bit-mask indicating bits to set. |
Referenced by LED_On(), usb_device_task_init(), and usb_set_feature().
#define Set_debug_register | ( | dbgreg, | |
value | |||
) | __builtin_mtdr(dbgreg, value) |
Sets the value of the dbgreg debug register to value.
dbgreg | Address of the debug register of which to set the value. |
value | Value to set the dbgreg debug register to. |
#define SHORTENUM __attribute__ ((packed)) |
#define Swap16 | ( | u16 | ) |
Toggles the endianism of u16 (by swapping its bytes).
u16 | U16 of which to toggle the endianism. |
Toggles the endianism of u16 (by swapping its bytes).
u16 | U16 of which to toggle the endianism. |
#define Swap32 | ( | u32 | ) |
Toggles the endianism of u32 (by swapping its bytes).
u32 | U32 of which to toggle the endianism. |
Toggles the endianism of u32 (by swapping its bytes).
u32 | U32 of which to toggle the endianism. |
#define Swap64 | ( | u64 | ) |
Toggles the endianism of u64 (by swapping its bytes).
u64 | U64 of which to toggle the endianism. |
#define swap64 | ( | u64 | ) |
Toggles the endianism of u64 (by swapping its bytes).
u64 | U64 of which to toggle the endianism. |
#define Test_align | ( | val, | |
n | |||
) | (!Tst_bits( val, (n) - 1 ) ) |
Tests alignment of the number val with the n boundary.
val | Input value. |
n | Boundary. |
1
if the number val is aligned with the n boundary, else 0
. Referenced by flashc_memset64(), host_read_p_rxpacket(), host_set_p_txpacket(), host_write_p_txpacket(), usb_read_ep_rxpacket(), usb_set_ep_txpacket(), and usb_write_ep_txpacket().
#define Tgl_bits | ( | lvalue, | |
mask | |||
) | ((lvalue) ^= (mask)) |
Toggles the bits of a C lvalue specified by a given bit-mask.
lvalue | C lvalue of which to toggle bits. |
mask | Bit-mask indicating bits to toggle. |
Referenced by LED_Toggle().
#define true 1 |
#define Tst_bits | ( | value, | |
mask | |||
) | (Rd_bits(value, mask) != 0) |
Tests the bits of a value specified by a given bit-mask.
value | Value of which to test bits. |
mask | Bit-mask indicating bits to test. |
1
if at least one of the tested bits is set, else 0
. Referenced by LED_Test().
#define Wr_bitfield | ( | lvalue, | |
mask, | |||
bitfield | |||
) | (Wr_bits(lvalue, mask, (U32)(bitfield) << ctz(mask))) |
Writes the bit-field of a C lvalue specified by a given bit-mask.
lvalue | C lvalue to write a bit-field to. |
mask | Bit-mask indicating the bit-field to write. |
bitfield | Bit-field to write. |
Referenced by usb_set_feature().
#define Wr_bits | ( | lvalue, | |
mask, | |||
bits | |||
) |
Writes the bits of a C lvalue specified by a given bit-mask.
lvalue | C lvalue to write bits to. |
mask | Bit-mask indicating bits to write. |
bits | Bits to write. |
Referenced by LED_Display_Mask().
typedef uint16_t be16_t |
typedef uint32_t be32_t |
typedef unsigned char Bool |
Boolean.
typedef unsigned char bool |
Boolean.
typedef float F32 |
32-bit floating-point number.
typedef double F64 |
64-bit floating-point number.
typedef uint32_t iram_size_t |
typedef uint16_t le16_t |
typedef uint32_t le32_t |
typedef int16_t S16 |
16-bit signed integer.
typedef int32_t S32 |
32-bit signed integer.
typedef signed long long int S64 |
64-bit signed integer.
typedef int8_t S8 |
8-bit signed integer.
typedef bool Status_bool_t |
Boolean status.
typedef uint16_t U16 |
16-bit unsigned integer.
typedef uint32_t U32 |
32-bit unsigned integer.
typedef unsigned long long int U64 |
64-bit unsigned integer.
typedef uint8_t U8 |
8-bit unsigned integer.
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
References u8.
|
inlinestatic |
References u8.
|
inlinestatic |
|
inlinestatic |
Calculate the base-2 logarithm of a number rounded down to the nearest integer.
x | A 32-bit value |
References clz, ilog2_undefined(), and is_constant.
int_fast8_t ilog2_undefined | ( | void | ) |
|
inlinestatic |