Handling unaligned accesses that leads to a 'Usage Fault' or 'Hard Fault' exception
Technical Note 58203
Architectures:
ARM
Component:
general
Updated:
10/3/2017 1:13 PM
Introduction
This technical note describes actions to take when an unaligned access leads to a ‘Usage Fault’ or ‘Hard Fault’ exception.
This technical note applies to devices based on the ARMv6 (excluding ARMv6-M), ARMv7-M, and ARMv8-M architectures. For other architectures, especially the ARMv6-M, see the heading ‘Other architectures’ below.
Discussion
These are two different suggestions for avoiding exceptions:
- Let the application clear the 'UNALIGN_TRP' bit (or avoid setting the bit), in the Configuration and Control register.
This makes the device accept unaligned accesses. When the device is set up in this manner, the IAR C/C++ Compiler™ can generate more efficient code. The runtime library is built to take advantage of this.
- Compile the application with the option --no_unaligned_access.
The first suggestion makes the device accept unaligned accesses. When the device is set up in this manner, the IAR C/C++ Compiler™ can generate more efficient code. The runtime library is built to take advantage of this.
This suggestion is applicable when the 'UNALIGN_TRP' bit is set by the application. In this situation, the linker will redirect affected library functions to function variants that handle the unaligned accesses. These variants are less efficient.
Other architectures
This technical note isn’t applicable to devices based on the ARMv4, ARMv5, and ARMv6-M architectures.
- Examples of the ARMv6-M architecture are Cortex-M0, Cortex-M0+ and Cortex-M1.
- Examples of the ARMv4 and ARMv5 architectures are ARM7TDMI and ARM926S.
Conclusion
Devices based on the ARMv6, ARMv7-M, and ARMv8-M architectures can take advantage of this technical note. (Examples of ARMv7-M architectures are Cortex-M3, Cortex-M4 and Cortex-M7)
More information can be found in your hardware documentation, for example, ‘4.3.9. System Handler Control and State Register’ in ‘Cortex-M3 Devices Generic User Guide’ and ‘4.3.6. Configuration and Control Register’ in ‘Cortex-M0 Devices Generic User Guide’.
All product names are trademarks or registered trademarks of their respective owners.