Support for Address Manipulation.
More...
|
file | address.h |
| Information Required to Manipulate Physical Addresses.
|
|
Support for Address Manipulation.
This handler encapsulates functionality which abstracts address manipulation in a portable manner.
◆ _Addresses_Add_offset()
Adds offset to an address.
This function is used to add an offset to a base address. It returns the resulting address. This address is typically converted to an access type before being used further.
- Parameters
-
base | The base address to add the offset to. |
offset | The offset to add to base. |
- Returns
- This method returns the resulting address.
◆ _Addresses_Align_down()
Aligns address to nearest multiple of alignment, truncating.
This function returns the given address aligned to the given alignment. If the address already is aligned, or if alignment is 0, the address is returned as is. The returned address is less than or equal to the given address.
- Parameters
-
address | The address to align to the given alignment. |
alignment | The desired alignment for the address. It must be a power of two. |
- Returns
- Returns the aligned address.
◆ _Addresses_Align_up()
Aligns address to nearest multiple of alignment, rounding up.
This function returns the given address aligned to the given alignment. If the address already is aligned, or if alignment is 0, the address is returned as is. The returned address is greater than or equal to the given address.
- Parameters
-
address | The address to align to the given alignment. |
alignment | The desired alignment for the address. It must be a power of two. |
- Returns
- Returns the aligned address.
◆ _Addresses_Is_aligned()
Checks if address is aligned.
This function returns true if the given address is correctly aligned for this processor and false otherwise. Proper alignment is based on correctness and efficiency.
- Parameters
-
address | The address being checked for alignment. |
- Return values
-
true | The address is aligned. |
false | The address is not aligned. |
◆ _Addresses_Is_in_range()
RTEMS_INLINE_ROUTINE bool _Addresses_Is_in_range |
( |
const void * |
address, |
|
|
const void * |
base, |
|
|
const void * |
limit |
|
) |
| |
Checks if address is in range.
This function returns true if the given address is within the memory range specified and false otherwise. base is the address of the first byte in the memory range and limit is the address of the last byte in the memory range. The base address is assumed to be lower than the limit address.
- Parameters
-
address | The address to check if it is in the given range. |
base | The lowest address of the range to check against. |
limit | The highest address of the range to check against. |
- Return values
-
true | The address is within the memory range specified |
false | The address is not within the memory range specified. |
◆ _Addresses_Subtract()
Subtracts two addresses.
This function is used to subtract two addresses. It returns the resulting offset.
- Parameters
-
left | The address on the left hand side of the subtraction. |
right | The address on the right hand side of the subtraction. |
- Returns
- This method returns the resulting address.
◆ _Addresses_Subtract_offset()
Subtracts offset from an address.
This function is used to subtract an offset from a base address. It returns the resulting address. This address is typically converted to an access type before being used further.
- Parameters
-
base | The base address to subtract the offset from. |
offset | The offset to subtract from base. |
- Returns
- This method returns the resulting address.