# Arm<sup>®</sup> Compiler

Version 6.10

**Migration and Compatibility Guide** 



# **Arm® Compiler**

#### **Migration and Compatibility Guide**

Copyright © 2014-2018 Arm Limited or its affiliates. All rights reserved.

**Release Information** 

#### **Document History**

| Issue   | Date                                                 | Confidentiality  | Change                                                            |  |
|---------|------------------------------------------------------|------------------|-------------------------------------------------------------------|--|
| А       | 14 March 2014                                        | Non-Confidential | Arm Compiler v6.00 Release                                        |  |
| В       | 15 December 2014                                     | Non-Confidential | Arm Compiler v6.01 Release                                        |  |
| С       | 30 June 2015                                         | Non-Confidential | Arm Compiler v6.02 Release                                        |  |
| D       | 18 November 2015                                     | Non-Confidential | Arm Compiler v6.3 Release                                         |  |
| Е       | 24 February 2016                                     | Non-Confidential | Arm Compiler v6.4 Release                                         |  |
| F       | 29 June 2016                                         | Non-Confidential | Arm Compiler v6.5 Release                                         |  |
| G       | 04 November 2016                                     | Non-Confidential | tial Arm Compiler v6.6 Release                                    |  |
| 0607-00 | -00 05 April 2017 Non-Confidential Arm Comp changed. |                  | Arm Compiler v6.7 Release. Document numbering scheme has changed. |  |
| 0608-00 | 30 July 2017                                         | Non-Confidential | Arm Compiler v6.8 Release.                                        |  |
| 0609-00 | 25 October 2017                                      | Non-Confidential | Arm Compiler v6.9 Release.                                        |  |
| 0610-00 | 14 March 2018                                        | Non-Confidential | Arm Compiler v6.10 Release.                                       |  |

#### **Non-Confidential Proprietary Notice**

This document is protected by copyright and other related rights and the practice or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of Arm. **No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.** 

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether implementations infringe any third party patents.

THIS DOCUMENT IS PROVIDED "AS IS". ARM PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, Arm makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of, third party patents, copyrights, trade secrets, or other rights.

This document may include technical inaccuracies or typographical errors.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

This document consists solely of commercial items. You shall be responsible for ensuring that any use, duplication or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to Arm's customers is not intended to create or refer to any partnership relationship with any other company. Arm may make changes to this document at any time and without notice.

If any of the provisions contained in these terms conflict with any of the provisions of any click through or signed written agreement covering this document with Arm, then the click through or signed written agreement prevails over and supersedes the conflicting provisions of these terms. This document may be translated into other languages for convenience, and you agree that if

there is any conflict between the English version of this document and any translation, the terms of the English version of the Agreement shall prevail.

The Arm corporate logo and words marked with <sup>®</sup> or <sup>TM</sup> are registered trademarks or trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners. Please follow Arm's trademark usage guidelines at *http://www.arm.com/company/policies/trademarks*.

Copyright © 2014–2018 Arm Limited (or its affiliates). All rights reserved.

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

LES-PRE-20349

#### **Confidentiality Status**

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by Arm and the party that Arm delivered this document to.

Unrestricted Access is an Arm internal classification.

#### **Product Status**

The information in this document is Final, that is for a developed product.

#### Web Address

http://www.arm.com

# Contents Arm<sup>®</sup> Compiler Migration and Compatibility Guide

|           | Pref | ace                                                                                                |         |
|-----------|------|----------------------------------------------------------------------------------------------------|---------|
|           |      | About this book                                                                                    | 10      |
| Chapter 1 | Con  | figuration and Support Information                                                                 |         |
|           | 1.1  | Support level definitions                                                                          | 1-13    |
|           | 1.2  | Compiler configuration information                                                                 | 1-17    |
| Chapter 2 | Migi | rating from Arm <sup>®</sup> Compiler 5 to Arm <sup>®</sup> Compiler 6                             |         |
|           | 2.1  | Migration overview                                                                                 | 2-19    |
|           | 2.2  | Toolchain differences                                                                              | 2-20    |
|           | 2.3  | Default differences                                                                                | 2-21    |
|           | 2.4  | Optimization differences                                                                           | 2-23    |
|           | 2.5  | Diagnostic messages                                                                                | 2-25    |
|           | 2.6  | Migration example                                                                                  | 2-27    |
| Chapter 3 | Migi | rating from armcc to armclang                                                                      |         |
|           | 3.1  | Migration of compiler command-line options from Arm <sup>®</sup> Compiler 5 to Arm <sup>®</sup> Co | ompiler |
|           |      | 6                                                                                                  | 3-30    |
|           | 3.2  | Command-line options for preprocessing assembly source code                                        | 3-37    |
|           | 3.3  | Inline assembly with Arm <sup>®</sup> Compiler 6                                                   | 3-38    |
|           | 3.4  | Migrating architecture and processor names for command-line options                                | 3-40    |
|           | 3.5  | Preprocessing a scatter file                                                                       | 3-46    |
|           |      |                                                                                                    |         |

| Chapter 4  | Com   | piler Source Code Compatibility                                                             |              |
|------------|-------|---------------------------------------------------------------------------------------------|--------------|
|            | 4.1   | Language extension compatibility: keywords                                                  | 4-48         |
|            | 4.2   | Language extension compatibility: attributes                                                | 4-51         |
|            | 4.3   | Language extension compatibility: pragmas                                                   | 4-53         |
|            | 4.4   | Language extension compatibility: intrinsics                                                | 4-56         |
|            | 4.5   | Diagnostics for pragma compatibility                                                        | 4-60         |
|            | 4.6   | C and C++ implementation compatibility                                                      | 4-62         |
|            | 4.7   | Compatibility of C++ objects                                                                | 4-64         |
| Chapter 5  | Migra | ating from armasm to the armclang integrated assembler                                      |              |
|            | 5.1   | Migration of assembler command-line options from armasm to the armclan                      | g integrated |
|            |       | assembler                                                                                   | 5-67         |
|            | 5.2   | Overview of differences between armasm and GNU syntax assembly code                         | 5-72         |
|            | 5.3   | Comments                                                                                    | 5-74         |
|            | 5.4   | Labels                                                                                      | 5-75         |
|            | 5.5   | Numeric local labels                                                                        | 5-76         |
|            | 5.6   | Functions                                                                                   | 5-78         |
|            | 5.7   | Sections                                                                                    | 5-79         |
|            | 5.8   | Symbol naming rules                                                                         | 5-81         |
|            | 5.9   | Numeric literals                                                                            | 5-82         |
|            | 5.10  | Operators                                                                                   | 5-83         |
|            | 5.11  | Alignment                                                                                   | 5-84         |
|            | 5.12  | PC-relative addressing                                                                      | 5-85         |
|            | 5.13  | A32 and T32 instruction substitutions                                                       | 5-86         |
|            | 5.14  | A32 and T32 pseudo-instructions                                                             | 5-88         |
|            | 5.15  | Conditional directives                                                                      | 5-89         |
|            | 5.16  | Data definition directives                                                                  | 5-90         |
|            | 5.17  | Instruction set directives                                                                  | 5-92         |
|            | 5.18  | Miscellaneous directives                                                                    | 5-93         |
|            | 5.19  | Symbol definition directives                                                                | 5-95         |
|            | 5.20  | Migration of armasm macros to integrated assembler macros                                   | 5-96         |
| Chapter 6  | Char  | nges Between Different Versions of Arm® Compiler 6                                          |              |
|            | 6.1   | Summary of changes between Arm <sup>®</sup> Compiler 6.9 and Arm <sup>®</sup> Compiler 6.10 | 6-106        |
|            | 6.2   | Summary of changes between Arm <sup>®</sup> Compiler 6.8 and Arm <sup>®</sup> Compiler 6.9  | 6-107        |
|            | 6.3   | Summary of changes between Arm <sup>®</sup> Compiler 6.7 and Arm <sup>®</sup> Compiler 6.8  | 6-108        |
|            | 6.4   | Summary of changes between Arm <sup>®</sup> Compiler 6.6 and Arm <sup>®</sup> Compiler 6.7  | 6-110        |
|            | 6.5   | Summary of changes between Arm <sup>®</sup> Compiler 6.5 and Arm <sup>®</sup> Compiler 6.6  |              |
|            | 6.6   | Compiling with -mexecute-only generates an empty .text section                              | 6-114        |
| Appendix A | Code  | e examples                                                                                  |              |
|            | A.1   | Example startup code for Arm <sup>®</sup> Compiler 5 project                                | Appx-A-118   |
|            | A.2   | Example startup code for Arm <sup>®</sup> Compiler 6 project                                | Appx-A-120   |
| Appendix B | Licer | ises                                                                                        |              |
|            | B.1   | Apache License                                                                              | Аррх-В-123   |

# List of Figures **Arm<sup>®</sup> Compiler Migration and Compatibility Guide**

| Figure 1-1 | Integration boundaries in Arm Compiler 6. | 1-15 |
|------------|-------------------------------------------|------|
|------------|-------------------------------------------|------|

# List of Tables Arm<sup>®</sup> Compiler Migration and Compatibility Guide

| Table 1-1 | FlexNet versions                                                                      | . 1-17 |
|-----------|---------------------------------------------------------------------------------------|--------|
| Table 2-1 | List of compilation tools                                                             | . 2-20 |
| Table 2-2 | Differences in defaults                                                               | . 2-21 |
| Table 2-3 | Optimization settings                                                                 | . 2-23 |
| Table 2-4 | Command-line changes                                                                  | 2-27   |
| Table 3-1 | Comparison of compiler command-line options in Arm Compiler 5 and Arm Compiler 6      | . 3-30 |
| Table 3-2 | Architecture selection in Arm Compiler 5 and Arm Compiler 6                           | . 3-40 |
| Table 3-3 | Processor selection in Arm Compiler 5 and Arm Compiler 6                              | . 3-41 |
| Table 4-1 | Keyword language extensions in Arm Compiler 5 and Arm Compiler 6                      | . 4-48 |
| Table 4-2 | Migrating thepacked keyword                                                           | . 4-50 |
| Table 4-3 | Support fordeclspec attributes                                                        | . 4-51 |
| Table 4-4 | Migratingattribute((at(address))) and zero-initializedattribute((section("name"))) 52 | 4-     |
| Table 4-5 | Pragma language extensions that must be replaced                                      | . 4-53 |
| Table 4-6 | Compiler intrinsic support in Arm Compiler 6                                          | . 4-56 |
| Table 4-7 | Pragma diagnostics                                                                    | . 4-60 |
| Table 4-8 | C and C++ implementation detail differences                                           | 4-62   |
| Table 5-1 | Comparison of command-line options in armasm and the armclang integrated assembler .  | . 5-67 |
| Table 5-2 | Operator translation                                                                  | . 5-83 |
| Table 5-3 | A32 and T32 instruction substitutions supported by armasm                             | . 5-86 |
| Table 5-4 | A32 and T32 pseudo-instruction migration                                              | . 5-88 |
| Table 5-5 | Conditional directive translation                                                     | 5-89   |
| Table 5-6 | Data definition directives translation                                                | . 5-90 |
|           |                                                                                       |        |

| Table 5-7  | Instruction set directives translation                                                | 5-92  |
|------------|---------------------------------------------------------------------------------------|-------|
| Table 5-8  | Miscellaneous directives translation                                                  | 5-93  |
| Table 5-9  | Symbol definition directives translation                                              | 5-95  |
| Table 5-10 | Comparison of macro directive features provided by armasm and the armclang integrated |       |
|            | assembler                                                                             | 5-96  |
| Table 5-11 | NOT EQUALS assertion                                                                  | 5-98  |
| Table 5-12 | Unsigned integer division macro                                                       | 5-99  |
| Table 5-13 | Assembly-time diagnostics macro                                                       | 5-101 |
| Table 5-14 | Conditional loop macro                                                                | 5-102 |
|            |                                                                                       |       |

# Preface

This preface introduces the Arm<sup>®</sup> Compiler Migration and Compatibility Guide.

It contains the following:

• *About this book* on page 10.

# About this book

The Arm<sup>®</sup> Compiler Migration and Compatibility Guide provides migration and compatibility information for users moving from older versions of Arm Compiler to Arm Compiler 6.

#### Using this book

This book is organized into the following chapters:

#### **Chapter 1 Configuration and Support Information**

Summarizes the support levels, and locales and FlexNet versions supported by the Arm compilation tools.

#### Chapter 2 Migrating from Arm<sup>®</sup> Compiler 5 to Arm<sup>®</sup> Compiler 6

Provides an overview of the differences between Arm Compiler 5 and Arm Compiler 6.

#### Chapter 3 Migrating from armcc to armclang

Compares Arm Compiler 6 command-line options to older versions of Arm Compiler.

#### Chapter 4 Compiler Source Code Compatibility

Provides details of source code compatibility between Arm Compiler 6 and older armcc compiler versions.

#### Chapter 5 Migrating from armasm to the armclang integrated assembler

Describes how to migrate assembly code from armasm syntax to GNU syntax (used by armclang).

### Chapter 6 Changes Between Different Versions of Arm® Compiler 6

Describes the changes that affect migration and compatibility between different versions of Arm Compiler 6.

### Appendix A Code examples

Provides source code examples for Arm Compiler 5 and Arm Compiler 6.

### **Appendix B Licenses**

Describes the Apache license.

# Glossary

The Arm<sup>®</sup> Glossary is a list of terms used in Arm documentation, together with definitions for those terms. The Arm Glossary does not contain terms that are industry standard unless the Arm meaning differs from the generally accepted meaning.

See the Arm® Glossary for more information.

### **Typographic conventions**

#### italic

Introduces special terminology, denotes cross-references, and citations.

#### bold

Highlights interface elements, such as menu names. Denotes signal names. Also used for terms in descriptive lists, where appropriate.

#### monospace

Denotes text that you can enter at the keyboard, such as commands, file and program names, and source code.

#### <u>mono</u>space

Denotes a permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name.

#### monospace italic

Denotes arguments to monospace text where the argument is to be replaced by a specific value.

#### monospace bold

Denotes language keywords when used outside example code.

#### <and>

Encloses replaceable terms for assembler syntax where they appear in code or code fragments. For example:

MRC p15, 0, <Rd>, <CRn>, <CRm>, <Opcode\_2>

#### SMALL CAPITALS

Used in body text for a few terms that have specific technical meanings, that are defined in the *Arm*<sup>®</sup> *Glossary*. For example, IMPLEMENTATION DEFINED, IMPLEMENTATION SPECIFIC, UNKNOWN, and UNPREDICTABLE.

### Feedback

#### Feedback on this product

If you have any comments or suggestions about this product, contact your supplier and give:

- The product name.
- The product revision or version.
- An explanation with as much information as you can provide. Include symptoms and diagnostic
  procedures if appropriate.

#### Feedback on content

If you have comments on content then send an e-mail to errata@arm.com. Give:

- The title Arm Compiler Migration and Compatibility Guide.
- The number 100068\_0610\_00\_en.
- If applicable, the page number(s) to which your comments refer.
- A concise explanation of your comments.

Arm also welcomes general suggestions for additions and improvements.

\_\_\_\_\_ Note \_\_\_\_\_

Arm tests the PDF only in Adobe Acrobat and Acrobat Reader, and cannot guarantee the quality of the represented document when used with any other PDF reader.

# Other information

- Arm<sup>®</sup> Developer.
- Arm<sup>®</sup> Information Center.
- Arm<sup>®</sup> Technical Support Knowledge Articles.
- Technical Support.
- Arm<sup>®</sup> Glossary.

# Chapter 1 Configuration and Support Information

Summarizes the support levels, and locales and FlexNet versions supported by the Arm compilation tools.

It contains the following sections:

- 1.1 Support level definitions on page 1-13.
- *1.2 Compiler configuration information* on page 1-17.

# 1.1 Support level definitions

This describes the levels of support for various Arm Compiler 6 features.

Arm Compiler 6 is built on Clang and LLVM technology. Therefore it has more functionality than the set of product features described in the documentation. The following definitions clarify the levels of support and guarantees on functionality that are expected from these features.

Arm welcomes feedback regarding the use of all Arm Compiler 6 features, and endeavors to support users to a level that is appropriate for that feature. You can contact support at *https://developer.arm.com/support*.

# Identification in the documentation

All features that are documented in the Arm Compiler 6 documentation are product features, except where explicitly stated. The limitations of non-product features are explicitly stated.

# **Product features**

Product features are suitable for use in a production environment. The functionality is well-tested, and is expected to be stable across feature and update releases.

- Arm endeavors to give advance notice of significant functionality changes to product features.
- If you have a support and maintenance contract, Arm provides full support for use of all product features.
- Arm welcomes feedback on product features.
- Any issues with product features that Arm encounters or is made aware of are considered for fixing in future versions of Arm Compiler.

In addition to fully supported product features, some product features are only alpha or beta quality.

### **Beta product features**

Beta product features are implementation complete, but have not been sufficiently tested to be regarded as suitable for use in production environments.

Beta product features are indicated with [BETA].

- Arm endeavors to document known limitations on beta product features.
- Beta product features are expected to eventually become product features in a future release of Arm Compiler 6.
- Arm encourages the use of beta product features, and welcomes feedback on them.
- Any issues with beta product features that Arm encounters or is made aware of are considered for fixing in future versions of Arm Compiler.

### Alpha product features

Alpha product features are not implementation complete, and are subject to change in future releases, therefore the stability level is lower than in beta product features.

Alpha product features are indicated with [ALPHA].

- Arm endeavors to document known limitations of alpha product features.
- Arm encourages the use of alpha product features, and welcomes feedback on them.
- Any issues with alpha product features that Arm encounters or is made aware of are considered for fixing in future versions of Arm Compiler.

### **Community features**

Arm Compiler 6 is built on LLVM technology and preserves the functionality of that technology where possible. This means that there are additional features available in Arm Compiler that are not listed in the documentation. These additional features are known as community features. For information on these community features, see the *documentation for the Clang/LLVM project*.

Where community features are referenced in the documentation, they are indicated with [COMMUNITY].

- Arm makes no claims about the quality level or the degree of functionality of these features, except when explicitly stated in this documentation.
- Functionality might change significantly between feature releases.
- Arm makes no guarantees that community features will remain functional across update releases, although changes are expected to be unlikely.

Some community features might become product features in the future, but Arm provides no roadmap for this. Arm is interested in understanding your use of these features, and welcomes feedback on them. Arm supports customers using these features on a best-effort basis, unless the features are unsupported. Arm accepts defect reports on these features, but does not guarantee that these issues will be fixed in future releases.

# Guidance on use of community features

There are several factors to consider when assessing the likelihood of a community feature being functional:

• The following figure shows the structure of the Arm Compiler 6 toolchain:

#### 1 Configuration and Support Information 1.1 Support level definitions



### Figure 1-1 Integration boundaries in Arm Compiler 6.

The dashed boxes are toolchain components, and any interaction between these components is an integration boundary. Community features that span an integration boundary might have significant limitations in functionality. The exception to this is if the interaction is codified in one of the standards supported by Arm Compiler 6. See *Application Binary Interface (ABI) for the Arm*<sup>®</sup> *Architecture*. Community features that do not span integration boundaries are more likely to work as expected.

- Features primarily used when targeting hosted environments such as Linux or BSD might have significant limitations, or might not be applicable, when targeting bare-metal environments.
- The Clang implementations of compiler features, particularly those that have been present for a long time in other toolchains, are likely to be mature. The functionality of new features, such as support

for new language features, is likely to be less mature and therefore more likely to have limited functionality.

# **Unsupported features**

With both the product and community feature categories, specific features and use-cases are known not to function correctly, or are not intended for use with Arm Compiler 6.

Limitations of product features are stated in the documentation. Arm cannot provide an exhaustive list of unsupported features or use-cases for community features. The known limitations on community features are listed in *Community features* on page 1-13.

# List of known unsupported features

The following is an incomplete list of unsupported features, and might change over time:

- The Clang option -stdlib=libstdc++ is not supported.
- C++ static initialization of local variables is not thread-safe when linked against the standard C++ libraries. For thread-safety, you must provide your own implementation of thread-safe functions as described in *Standard C++ library implementation definition*.

\_\_\_\_\_ Note \_\_\_\_\_

This restriction does not apply to the [ALPHA]-supported multithreaded C++ libraries.

- Use of C11 library features is unsupported.
- Any community feature that exclusively pertains to non-Arm architectures is not supported.
- Compilation for targets that implement architectures older than Armv7 or Armv6-M is not supported.
- The **long double** data type is not supported for AArch64 state because of limitations in the current Arm C library.
- Complex numbers are not supported because of limitations in the current Arm C library.

#### 1 Configuration and Support Information 1.2 Compiler configuration information

# 1.2 Compiler configuration information

Summarizes the locales and FlexNet versions supported by the Arm compilation tools.

#### FlexNet versions in the compilation tools

Different versions of Arm Compiler support different versions of FlexNet.

The FlexNet versions in the compilation tools are:

#### Table 1-1 FlexNet versions

| Compilation tools version   | Windows   | Linux     |
|-----------------------------|-----------|-----------|
| Arm Compiler 6.7 and later  | 11.14.1.0 | 11.14.1.0 |
| Arm Compiler 6.01 and later | 11.12.1.0 | 11.12.1.0 |
| Arm Compiler 6.00           | 11.10.1.0 | 11.10.1.0 |

# Locale support in the compilation tools

Arm Compiler only supports the English locale.

**Related information** Arm DS-5 License Management Guide

# Chapter 2 Migrating from Arm<sup>®</sup> Compiler 5 to Arm<sup>®</sup> Compiler 6

Provides an overview of the differences between Arm Compiler 5 and Arm Compiler 6.

It contains the following sections:

- 2.1 Migration overview on page 2-19.
- 2.2 Toolchain differences on page 2-20.
- 2.3 Default differences on page 2-21.
- 2.4 Optimization differences on page 2-23.
- 2.5 Diagnostic messages on page 2-25.
- 2.6 Migration example on page 2-27.

# 2.1 Migration overview

Migrating from Arm Compiler 5 to Arm Compiler 6 requires the use of new command-line options and might also require changes to existing source files.

Arm Compiler 6 is based on the modern LLVM compiler framework. Arm Compiler 5 is not based on the LLVM compiler framework. Therefore migrating your project and source files from Arm Compiler 5 to Arm Compiler 6 requires you to be aware of:

- Differences in the command-line options when invoking the compiler.
- Differences in the adherence to language standards.
- Differences in compiler specific keywords, attributes, and pragmas.
- Differences in optimization and diagnostic behavior of the compiler.

Even though these differences exist between Arm Compiler 5 and Arm Compiler 6, it is possible to migrate your projects from Arm Compiler 5 to Arm Compiler 6 by modifying your command-line arguments and by changing your source code if required.

Arm Compiler 5 does not support processors based on Armv8 and later architectures. Migrating to Arm Compiler 6 enables you to generate highly efficient code for processors based on Armv8 and later architectures.

# **Related information**

Migrating projects from Arm Compiler 5 to Arm Compiler 6

# 2.2 Toolchain differences

Arm Compiler 5 and Arm Compiler 6 share many of the same compilation tools. However, the main difference between the two toolchains is the compiler tool armclang, which is based on Clang and LLVM.

The table lists the individual compilation tools and the toolchain they apply to.

# Table 2-1 List of compilation tools

| Arm Compiler 5 | Arm Compiler 6                                                         | Function                                                                                                                                                      |  |
|----------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| armcc          | armclang                                                               | Compiles C and C++ language source files, including inline assembly.                                                                                          |  |
| armcc          | armclang                                                               | Preprocessor.                                                                                                                                                 |  |
| armasm         | armasm                                                                 | Assembles assembly language source files written in armasm syntax.                                                                                            |  |
| Not available  | armclang. This is also<br>called the armclang<br>integrated assembler. | Assembles assembly language source files written in GNU assembly syntax.                                                                                      |  |
| fromelf        | fromelf                                                                | Converts Arm ELF images to binary formats and can also generate textual information about the input image, such as its disassembly and its code and dat size. |  |
| armlink        | armlink                                                                | Combines the contents of one or more object files with selected parts of one or more object libraries to produce an executable program.                       |  |
| armar          | armar                                                                  | Enables sets of ELF object files to be collected together and maintained in archives or libraries.                                                            |  |

Arm Compiler 6 uses the compiler tool armclang instead of armcc. The command-line options for armclang are different to the command-line options for armcc. These differences are described in 3.1 Migration of compiler command-line options from Arm<sup>®</sup> Compiler 5 to Arm<sup>®</sup> Compiler 6 on page 3-30.

Arm Compiler 6 provides armasm, which you can use use to assemble your existing assembly language source files that are written in armasm syntax. Arm recommends you write new assembly code using the GNU assembly syntax, which you can assemble using the armclang integrated assembler. You can also migrate existing assembly language source files from armasm syntax to GNU syntax, and then assemble them using the armclang integrated assembler. For more information see *Chapter 5 Migrating from armasm to the armclang integrated assembler* on page 5-66.

# **Related information**

Migrating projects from Arm Compiler 5 to Arm Compiler 6

# 2.3 Default differences

Some compiler and assembler options are different between Arm Compiler 5 and Arm Compiler 6, or have different default values.

The following table lists these differences.

# Table 2-2 Differences in defaults

| Arm Compiler 5                     | Arm Compiler 6      | Notes                                                                                                                                                                                                                                                                                                                                                                                                 | Further information                                                                                                     |
|------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| hide_all                           | -fvisibility=hidden | These defaults are similar but<br>-fvisibility=hidden does not affect extern<br>declarations or symbol references. In Arm Compiler<br>6, symbols in the final image are hidden if the<br>reference or the definition is hidden. Therefore the<br>visibility of the reference alone does not determine<br>the visibility of the symbol, as it does in Arm<br>Compiler 5.                               | hide_all                                                                                                                |
| apcs=/hardfp<br>orapcs=/<br>softfp | -mfloat-abi=softfp  | The default floating-point linkage in Arm Compiler<br>5 depends on the specified processor. If the<br>processor has floating-point hardware, then Arm<br>Compiler 5 uses hard floating-point linkage. If the<br>processor does not have floating-point hardware,<br>then Arm Compiler 5 uses soft floating-point<br>linkage. In Arm Compiler 6, the default is always<br>soft floating-point linkage. | apcs for Arm® Compiler<br>5.<br>-mfLoat-abi for Arm®<br>Compiler 6                                                      |
| image.axf                          | a.out               | Default name for the executable image if none of -o,<br>-c, -E, or -S are specified on the command-line.                                                                                                                                                                                                                                                                                              | -o for Arm <sup>®</sup> Compiler 5.<br>-o for Arm <sup>®</sup> Compiler 6.                                              |
| enum_is_int is<br>off by default   | -fno-short-enums    | enum_is_int is off by default in Arm Compiler<br>5, so the smallest data type that can hold the<br>enumerator values is usedfno-short-enums is<br>the default in Arm Compiler 6, so the size of the<br>enumeration type is at least 32 bits.                                                                                                                                                          | enum_is_int<br>-fno-short-enums                                                                                         |
| -02                                | -00                 | Arm Compiler 5 uses high optimization by default.<br>Arm Compiler 6 uses minimum optimization by<br>default.                                                                                                                                                                                                                                                                                          | -0 for Arm <sup>®</sup> Compiler 5.<br>-0 for Arm <sup>®</sup> Compiler 6.<br>Optimization differences<br>on page 2-23. |
| apcs=/<br>nointerwork              | apcs=/interwork     | In Arm Compiler 5, armasm does not specify by<br>default that code in the input file can safely<br>interwork between A32 and T32. In Arm Compiler<br>6, armasm specifies interworking by default for<br>AArch32 targets that support A32 and T32<br>instruction sets.                                                                                                                                 | apcs for Arm <sup>®</sup> Compiler<br>5.<br>apcs for Arm <sup>®</sup> Compiler<br>6.                                    |

# Table 2-2 Differences in defaults (continued)

| Arm Compiler 5 | Arm Compiler 6 | Notes                                                                                                       | Further information  |
|----------------|----------------|-------------------------------------------------------------------------------------------------------------|----------------------|
| C++03          | C++14          | You can override the default source language with<br>cpp11 in Arm Compiler 5, or -std in Arm<br>Compiler 6. | cpp<br>cpp11<br>-std |
| C90            | C11            | You can override the default source language with<br>c99 in Arm Compiler 5, or -std in Arm<br>Compiler 6.   | c90<br>c99<br>-std   |

# 2.4 Optimization differences

Arm Compiler 6 provides more performance optimization settings than are present in Arm Compiler 5. However, the optimizations that are performed at each optimization level might differ between the two toolchains.

The table compares the optimization settings and functions in Arm Compiler 5 and Arm Compiler 6.

### Table 2-3 Optimization settings

| Description                                                | Arm Compiler 5                                                                                 | Arm Compiler 6                                                                                |
|------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| Optimization levels for performance.                       | <ul> <li>-Otime -00</li> <li>-Otime -01</li> <li>-Otime -02</li> <li>-Otime -03</li> </ul>     | <ul> <li>-00</li> <li>-01</li> <li>-02</li> <li>-03</li> <li>-0fast</li> <li>-0max</li> </ul> |
| Optimization levels for code size.                         | <ul> <li>-Ospace -00</li> <li>-Ospace -01</li> <li>-Ospace -02</li> <li>-Ospace -03</li> </ul> | • -0s<br>• -0z                                                                                |
| Default                                                    | -Ospace -O2                                                                                    | -00                                                                                           |
| Best trade-off between image size, performance, and debug. | -Ospace -O2                                                                                    | -01                                                                                           |
| Highest optimization for performance                       | -Otime -O3                                                                                     | -Omax                                                                                         |
| Highest optimization for code size                         | -Ospace -O3                                                                                    | -0z                                                                                           |

Arm Compiler 6 provides an aggressive optimization setting, -Omax, which automatically enables a feature called Link Time Optimization. For more information, see *-flto*.

When using -Omax, armclang can perform link time optimizations that were not possible in Arm Compiler 5. These link time optimizations can expose latent bugs in the final image. Therefore, an image built with Arm Compiler 5 might have a different behavior to the image built with Arm Compiler 6.

For example, unused variables without the volatile keyword might be removed when using -Omax in Arm Compiler 6. If the unused variable is actually a volatile variable that requires the volatile keyword, then the removal of the variable can cause the generated image to behave unexpectedly. Since Arm Compiler 5 does not have this aggressive optimization setting, it might not have removed the unused variable, and the resulting image might behave as expected, and therefore the error in the code would be more difficult to detect.

----- Note -----

If the main() function has no arguments (no argc and argv), then Arm Compiler 5 applies a particular optimization at all optimization levels including -00. Arm Compiler 6 applies this optimization only for optimization levels other than -00.

When main() is compiled with Arm Compiler 6 at any optimization level except -O0, the compiler defines the symbol \_\_ARM\_use\_no\_argv if main() does not have input arguments. This symbol enables the linker to select an optimized library that does not include code to handle input arguments to main().

When main() is compiled with Arm Compiler 6 at -00, the compiler does not define the symbol \_\_\_\_\_ARM\_use\_no\_argv. Therefore, the linker selects a default library that includes code to handle input arguments to main(). This library contains semihosting code.

If your main() function does not have arguments and you are compiling at -O0 with Arm Compiler 6, you can select the optimized library by manually defining the symbol \_\_ARM\_use\_no\_argv using inline assembly:

\_\_asm(".global \_\_ARM\_use\_no\_argv\n\t");

Also note that:

- Semihosting code can cause a HardFault on systems that are unable to handle semihosting code. To avoid this HardFault, you must define one or both of:
  - \_\_use\_no\_semihosting
  - \_\_\_ARM\_use\_no\_argv
- If you define <u>\_\_use\_no\_semihosting</u> without <u>\_\_ARM\_use\_no\_argv</u>, then the library code to handle argc and argv requires you to retarget these functions:

  - \_sys\_exit()
  - \_sys\_command\_string()

#### **Related information**

-flto armclang option -O armclang option Effect of the volatile keyword on compiler optimization Optimizing across modules with link time optimization

# 2.5 Diagnostic messages

In general, armclang provides more precise and detailed diagnostic messages compared to armcc. Therefore you can expect to see more information about your code when using Arm Compiler 6, which can help you understand and fix your source more quickly.

armclang and armcc differ in the quality of diagnostic information they provide about your code. The following sections demonstrate some of the differences.

# Assignment in condition

The following code is an example of armclang providing more precise information about your code. The error in this example is that the assignment operator, =, must be changed to the equality operator, ==.

```
main.cpp:
#include <stdio.h>
int main()
{
    int a = 0, b = 0;
    if (a = b)
    {
        printf("Right\n");
    }
    else
    {
        printf("Wrong\n");
    }
    return 0;
}
```

Compiling this example with Arm Compiler 5 gives the message:

```
"main.cpp", line 6: Warning: #1293-D: assignment in condition if (a = b)
```

Compiling this example with Arm Compiler 6 gives the message:

armclang highlights the error in the code, and also suggests two different ways to resolve the error. The warning messages highlight the specific part which requires attention from the user.

When using armclang, it is possible to enable or disable specific warning messages. In the example above, you can enable this warning message using the -Wparentheses option, or disable it using the -Wno-parentheses option.

### Automatic macro expansion

- Note

Another very useful feature of diagnostic messages in Arm Compiler 6, is the inclusion of notes about macro expansion. These notes provide useful context to help you understand diagnostic messages resulting from automatic macro expansion.

Consider the following code:

- Note

```
main.cpp:
#include <stdio.h>
#define LOG(PREFIX, MESSAGE) fprintf(stderr, "%s: %s", PREFIX, MESSAGE)
#define LOG_WARNING(MESSAGE) LOG("Warning", MESSAGE)
int main(void)
{
   LOG_WARNING(123);
}
```

The macro LOG\_WARNING has been called with an integer argument. However, expanding the two macros, you can see that the fprintf function expects a string. When the macros are close together in the code it is easy to spot these errors. These errors are not easy to spot if they are defined in different part of the source code, or in other external libraries.

Compiling this example with Arm Compiler 5 armcc main.cpp gives the message:

```
main.cpp", line 8: Warning: #181-D: argument is incompatible with corresponding format
string conversion
LOG_WARNING(123);
```

Compiling this example with Arm Compiler 6 armclang --target=arm-arm-none-eabi - march=armv8-a gives the message:

For more information, see 4.5 Diagnostics for pragma compatibility on page 4-60.

When starting the migration from Arm Compiler 5 to Arm Compiler 6, you can expect additional diagnostic messages because armclang does not recognize some of the pragmas, keywords, and attributes that were specific to armcc. When you replace the pragmas, keywords, and attributes from Arm Compiler 5 with their Arm Compiler 6 equivalents, the majority of these diagnostic messages disappear. You might require additional code changes if there is no direct equivalent for Arm Compiler 6. For more information see *Chapter 4 Compiler Source Code Compatibility* on page 4-47.

# 2.6 Migration example

This topic shows you the process of migrating an example code from Arm Compiler 5 to Arm Compiler 6.

\_\_\_\_\_ Note \_\_\_\_\_

This topic includes descriptions of [COMMUNITY] features. See Support level definitions on page 1-13.

#### **Compiling with Arm® Compiler 5**

For an example startup code that builds with Arm Compiler 5, see *Example startup code for Arm*<sup>®</sup> *Compiler 5 project* on page Appx-A-118.

To compile this example with Arm Compiler 5, enter:

armcc startup\_ac5.c --cpu=7-A -c

This command generates a compiled object file for the Armv7-A architecture.

#### Compiling with Arm® Compiler 6

Try to compile the startup\_ac5.c example with Arm Compiler 6. The first step in the migration is to use the new compiler tool, armclang, and use the correct command-line options for armclang.

To compile this example with Arm Compiler 6, enter:

armclang --target=arm-arm-none-eabi startup\_ac5.c -march=7-A -c -01 -std=c90

The following table shows the differences in the command-line options between Arm Compiler 5 and Arm Compiler 6:

#### Table 2-4 Command-line changes

| Description                | Arm Compiler 5                                        | Arm Compiler 6                                                                                                                    |
|----------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Tool                       | armcc                                                 | armclang                                                                                                                          |
| Specifying an architecture | cpu=7-A                                               | <ul> <li>-march=armv7-a</li> <li>target is a mandatory option for armclang.</li> </ul>                                            |
| Optimization               | The default optimization is -02.                      | The default optimization is -00. To get similar optimizations as the Arm Compiler 5 default, use -01.                             |
| Source language mode       | The default source language mode for .c files is c90. | The default source language mode for .c<br>files is gnu11 [COMMUNITY]. To<br>compile for c90 in Arm Compiler 6, use -<br>std=c90. |

Arm Compiler 6 generates the following errors and warnings when trying to compile the example startup\_ac5.c file in c90 mode:

The following section describes how to modify the source file to fix these errors and warnings.

#### Modifying the source code for Arm® Compiler 6

You must make the following changes to the source code to compile with armclang.

• The return type of function main function cannot be void in standard C. Replace the following line:

```
__declspec(noreturn) void main(void)
```

With:

```
__declspec(noreturn) int main(void)
```

• The intrinsic \_\_enable\_irq() is not supported in Arm Compiler 6. You must replace the intrinsic with an inline assembler equivalent. Replace the following line:

\_\_enable\_irq();

With:

```
__asm("CPSIE i");
```

The #pragma import is not supported in Arm Compiler 6. You must replace the pragma with an equivalent directive using inline assembler. Replace the following line:

#pragma import(\_\_use\_no\_semihosting)

With:

```
__asm(".global __use_no_semihosting");
```

In certain situations, armclang might remove infinite loops that do not have side-effects. You must
use the volatile keyword to tell armclang not to remove such code. Replace the following line:

while(1);

With:

while(1) \_\_asm volatile("");

# Chapter 3 Migrating from armcc to armclang

Compares Arm Compiler 6 command-line options to older versions of Arm Compiler.

It contains the following sections:

- 3.1 Migration of compiler command-line options from Arm<sup>®</sup> Compiler 5 to Arm<sup>®</sup> Compiler 6 on page 3-30.
- 3.2 Command-line options for preprocessing assembly source code on page 3-37.
- 3.3 Inline assembly with Arm<sup>®</sup> Compiler 6 on page 3-38.
- 3.4 Migrating architecture and processor names for command-line options on page 3-40.
- *3.5 Preprocessing a scatter file* on page 3-46.

# 3.1 Migration of compiler command-line options from Arm<sup>®</sup> Compiler 5 to Arm<sup>®</sup> Compiler 6

Arm Compiler 6 provides many command-line options, including most Clang command-line options and several Arm-specific options.

\_\_\_\_\_ Note \_\_\_\_

This topic includes descriptions of [COMMUNITY] features. See Support level definitions on page 1-13.

The following table describes the most common Arm Compiler 5 command-line options, and shows the equivalent options for Arm Compiler 6.

More information about command-line options is available:

- The *armclang Reference Guide* provides more information about the supported command-line options. The options described are fully supported, unless the level of support is indicated.
- For a full list of Clang command-line options, see the Clang and LLVM documentation.

| Arm Compiler 5 option                                          | Arm Compiler 6 option                                   | Description                                                                                                                                                                                                                      |  |
|----------------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| allow_fpreg_for_nonfpdata,<br><br>no_allow_fpreg_for_nonfpdata | -mimplicit-float,-<br>mno-implicit-float<br>[COMMUNITY] | Enables or disables the use of VFP and SIMD registers and data transfer instructions for non-VFP and non-SIMD data.                                                                                                              |  |
| apcs=/nointerwork                                              | No equivalent.                                          | Disables interworking between A32 and T32 code. Interworking is always enabled in Arm Compiler 6.                                                                                                                                |  |
| apcs=/ropi<br>apcs=/noropi                                     | -fropi<br>-fno-ropi                                     | Enables or disables the generation of Read-Only Position-<br>Independent (ROPI) code.                                                                                                                                            |  |
| apcs=/rwpi<br>apcs=/norwpi                                     | -frwpi<br>-fno-rwpi                                     | Enables or disables the generation of Read/Write Position-<br>Independent (RWPI) code.                                                                                                                                           |  |
| arm                                                            | -marm                                                   | Targets the A32 instruction set. The compiler is permitted to generate both A32 and T32 code, but recognizes that A32 code is preferred.                                                                                         |  |
| arm_only                                                       | No equivalent.                                          | Enforces A32 instructions only. The compiler does not generate T32 instructions.                                                                                                                                                 |  |
| asm                                                            | -save-temps                                             | Instructs the compiler to generate intermediate assembly files a well as object files.                                                                                                                                           |  |
| -c                                                             | -c                                                      | Performs the compilation step, but not the link step.                                                                                                                                                                            |  |
| c90                                                            | -xc -std=c90                                            | Enables the compilation of C90 source code.<br>-xc is a positional argument and only affects subsequent input files on the command-line. It is also only required if the input files do not have the appropriate file extension. |  |

| Arm Compiler 5 option | Arm Compiler 6<br>option | Description                                                                                                                                                                         |
|-----------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| c90gnu                | -xc -std=gnu90           | Enables the compilation of C90 source code with additional GNU extensions.                                                                                                          |
|                       |                          | -xc is a positional argument and only affects subsequent input files on the command-line. It is also only required if the input files do not have the appropriate file extension.   |
| c99                   | -xc -std=c99             | Enables the compilation of C99 source code.                                                                                                                                         |
|                       |                          | -xc is a positional argument and only affects subsequent input files on the command-line. It is also only required if the input files do not have the appropriate file extension.   |
| c99gnu                | -xc -std=gnu99           | Enables the compilation of C99 source code with additional GNU extensions.                                                                                                          |
|                       |                          | -xc is a positional argument and only affects subsequent input files on the command-line. It is also only required if the input files do not have the appropriate file extension.   |
| срр                   | -xc++ -std=c++03         | Enables the compilation of C++03 source code.                                                                                                                                       |
|                       |                          | -xc++ is a positional argument and only affects subsequent input files on the command-line. It is also only required if the input files do not have the appropriate file extension. |
|                       |                          | The default C++ language standard is different between Arm<br>Compiler 5 and Arm Compiler 6.                                                                                        |
| cppgnu                | -xc++ -std=gnu++03       | Enables the compilation of C++03 source code with additional GNU extensions.                                                                                                        |
|                       |                          | -xc++ is a positional argument and only affects subsequent input files on the command-line. It is also only required if the input files do not have the appropriate file extension. |
|                       |                          | The default C++ language standard is different between Arm<br>Compiler 5 and Arm Compiler 6.                                                                                        |
| cpp11                 | -xc++ -std=c++11         | Enables the compilation of C++11 source code.                                                                                                                                       |
|                       |                          | -xc++ is a positional argument and only affects subsequent input files on the command-line. It is also only required if the input files do not have the appropriate file extension. |
|                       |                          | The default C++ language standard is different between Arm<br>Compiler 5 and Arm Compiler 6.                                                                                        |
| cpp11gnu              | -xc++ -std=gnu++11       | Enables the compilation of C++11 source code with additional GNU extensions.                                                                                                        |
|                       |                          | -xc++ is a positional argument and only affects subsequent input files on the command-line. It is also only required if the input files do not have the appropriate file extension. |
|                       |                          | The default C++ language standard is different between Arm<br>Compiler 5 and Arm Compiler 6.                                                                                        |

| Arm Compiler 5 option      | Arm Compiler 6 option                                                | Description                                                                                                                                                                                      |  |
|----------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| cpp_compat                 | No equivalent.                                                       | Compiles C++ code to maximize binary compatibility.                                                                                                                                              |  |
| cpu=8-A.32                 | target=arm-arm-<br>none-eabi -<br>march=armv8-a                      | Targets Armv8-A and AArch32 state.                                                                                                                                                               |  |
| cpu 8-A.64                 | target=aarch64-<br>arm-none-eabi                                     | Targets Armv8-A and AArch64 state. (Implies -march=armv8-<br>a if -mcpu is not specified.)                                                                                                       |  |
| cpu=7-A                    | target=arm-arm-<br>none-eabi -<br>march=armv7-a                      | Targets the Armv7-A architecture.                                                                                                                                                                |  |
| cpu=Cortex-M4              | target=arm-arm-<br>none-eabi -<br>mcpu=cortex-m4                     | Targets the Cortex <sup>®</sup> -M4 processor.                                                                                                                                                   |  |
| cpu=Cortex-A15             | target=arm-arm-<br>none-eabi -<br>mcpu=cortex-a15                    | Targets the Cortex-A15 processor.                                                                                                                                                                |  |
| -D                         | -D                                                                   | Defines a preprocessing macro.                                                                                                                                                                   |  |
| depend                     | -MF                                                                  | Specifies a filename for the makefile dependency rules.                                                                                                                                          |  |
| depend_dir                 | No equivalent. Use -MF to specify each dependency file individually. | Specifies the directory for dependency output files.                                                                                                                                             |  |
| depend_format=unix_escaped |                                                                      | Dependency file entries use UNIX-style path separators and escapes spaces with $\$ . This is the default in Arm Compiler 6.                                                                      |  |
| depend_target              | -MT                                                                  | Changes the target name for the makefile dependency rule.                                                                                                                                        |  |
| diag_error                 | -Werror                                                              | Turn compiler warnings into errors.                                                                                                                                                              |  |
| diag_suppress= <i>foo</i>  | -Wno <i>-foo</i>                                                     | Suppress warning message <i>foo</i> . The error or warning codes might be different between Arm Compiler 5 and Arm Compiler 6.                                                                   |  |
| -E                         | -E                                                                   | Executes only the preprocessor step.                                                                                                                                                             |  |
| enum_is_int                | -fno-short-enums,-<br>fshort-enums                                   | Sets the minimum size of an enumeration type.<br>By default Arm Compiler 5 does not set a minimum size. By<br>default Arm Compiler 6 uses -fno-short-enums to set the<br>minimum size to 32-bit. |  |
| forceline                  | No equivalent.                                                       | Forces aggressive inlining of functions. Arm Compiler 6<br>automatically decides whether to inline functions depending on<br>the optimization level.                                             |  |
| fpmode=std                 | -ffp-mode=std                                                        | Provides IEEE-compliant code with no IEEE exceptions, NaNs, and Infinities. Denormals are sign preserving. This is the default.                                                                  |  |
| fpmode=fast                | -ffp-mode=fast                                                       | Similar to the default behavior, but also performs aggressive floating-point optimizations and therefore it is not IEEE-compliant.                                                               |  |

| Arm Compiler 5 option                                                                                                                                                    | Arm Compiler 6 option                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| fpmode=ieee_full                                                                                                                                                         | -ffp-mode=full                              | Provides full IEEE support, including exceptions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| fpmode=ieee_fixed<br>fpmode=ieee_no_fenv                                                                                                                                 | There are no supported equivalent options.  | There might be community features that provide these IEEE floating-point modes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| fpu<br>For examplefpu=fpv5_d16                                                                                                                                           | -mfpu<br>For example -<br>mfpu=fpv5-d16     | Specifies the target FPU architecture.         Note         fpu=none checks the source code for floating-point operations, and if any are found it produces an error.        mfpu=none prevents the compiler from using hardware-base floating-point functions. If the compiler encounters floating-point types in the source code, it uses software-based floating-point library functions.         The option values might be different. For example fpv5_d16 Arm Compiler 5 is equivalent to fpv5-d16 in Arm Compiler and targets the FPv5-D16 floating-point extension. |  |
| -I                                                                                                                                                                       | -I                                          | Adds the specified directories to the list of places that are searched to find included files.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| ignore_missing_headers                                                                                                                                                   | -MG                                         | Prints dependency lines for header files even if the header files are missing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| inline                                                                                                                                                                   | Default at -02 and -03.                     | There is no equivalent of theinline option. Arm Compiler 6 automatically decides whether to inline functions at optimization levels -02 and -03.                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| -J                                                                                                                                                                       | -isystem                                    | Adds the specified directories to the list of places that are searched to find included system header files.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| -L                                                                                                                                                                       | -Xlinker                                    | Specifies command-line options to pass to the linker when a link step is being performed after compilation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| library_interface=armcc                                                                                                                                                  | This is the default.                        | Arm Compiler 6 by default uses the Arm standard C library.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| <ul> <li>library_interface=<i>lib</i></li> <li>Where <i>lib</i> is one of:</li> <li>aeabi_clib</li> <li>aeabi_clib90</li> <li>aeabi_clib99</li> </ul>                    | -nostdlib -<br>nostdlibinc -fno-<br>builtin | Specifies that the compiler output works with any ISO C library<br>compliant with the Arm Embedded Application Binary Interface<br>(AEABI).                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| <ul> <li>library_interface=<i>lib</i></li> <li>Where <i>lib</i> is not one of:</li> <li>aeabi_clib</li> <li>aeabi_clib90</li> <li>aeabi_clib99</li> <li>armcc</li> </ul> | No equivalent.                              | Arm Compiler 6 assumes the use of an AEABI compliant library.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |

| Arm Compiler 5 option          | Arm Compiler 6<br>option               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|--------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| licretry                       | No equivalent.                         | There is no equivalent of thelicretry option. The Arm<br>Compiler 6 tools automatically retry failed attempts to obtain a<br>license.                                                                                                                                                                                                                                                                                                                                                     |  |
| list_macros                    | -E -dM                                 | List all the macros that are defined at the end of the translation<br>unit, including the predefined macros.                                                                                                                                                                                                                                                                                                                                                                              |  |
| littleend                      | -mlittle-endian                        | Generates code for little-endian data.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| lower_ropi,no_lower_ropi       | -fropi-lowering,-<br>fno-ropi-lowering | Enables or disables less restrictive C when generating Read-Only<br>Position-Independent (ROPI) code.<br>Note —<br>In Arm Compiler 5, whenacps=/ropi is specified,<br>lower_ropi is not switched on by default. In Arm Compiler 6,<br>when -fropi is specified, -fropi-lowering is switched on<br>by default.                                                                                                                                                                             |  |
| lower_rwpi,no_lower_rwpi       | -frwpi-lowering,-<br>fno-rwpi-lowering | Enables or disables less restrictive C when generating Read-Write Position-Independent (RWPI) code.                                                                                                                                                                                                                                                                                                                                                                                       |  |
| -M                             | -M                                     | Instructs the compiler to produce a list of makefile dependency lines suitable for use by a make utility.                                                                                                                                                                                                                                                                                                                                                                                 |  |
| md                             | -MD                                    | Creates makefile dependency files, including the system header<br>files. In Arm Compiler 5, this is equivalent tomd<br>depend_system_headers.                                                                                                                                                                                                                                                                                                                                             |  |
| md<br>no_depend_system_headers | -MMD                                   | Creates makefile dependency files, without the system header files.                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| mm                             | -MM                                    | Creates a single makefile dependency file, without the system header files. In Arm Compiler 5, this is equivalent to -M no_depend_system_headers.                                                                                                                                                                                                                                                                                                                                         |  |
| no_exceptions                  | -fno-exceptions                        | Disables the generation of code needed to support C++ exceptions.                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| no_hide_all                    | -<br>fvisibility=default               | Sets the default visibility of ELF symbols to the specified option,<br>unless overridden in the source with the<br>attribute((visibility("visibility_type")))<br>attribute. The default is -fvisibility=hidden.<br>Note<br>The behavior of armclang -fvisibility=hidden is different<br>from that of the armcchide-all option. With armclang<br>-fvisibility=hidden, extern declarations are visible, and<br>all other symbols are hidden. With armcchide-all, all<br>symbols are hidden. |  |
| -0                             | -0                                     | Specifies the name of the output file.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |

| Arm Compiler 5 option | Arm Compiler 6 option | Description                                                                                                                                                                                                       |  |
|-----------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| -Onum                 | -0num                 | Specifies the level of optimization to be used when compiling source files.                                                                                                                                       |  |
|                       |                       | The default for Arm Compiler 5 is -02. The default for Arm Compiler 6 is -00. For debug view in Arm Compiler 6, Arm recommends -01 rather than -00 for best trade-off between image size, performance, and debug. |  |
| -Ospace               | -0z / -0s             | Performs optimizations to reduce image size at the expense of a possible increase in execution time.                                                                                                              |  |
| -Otime                | This is the default.  | Performs optimizations to reduce execution time at the expense of a possible increase in image size.                                                                                                              |  |
|                       |                       | There is no equivalent of the -Otime option. Arm Compiler 6 optimizes for execution time by default, unless you specify the -Os or -Oz options.                                                                   |  |
| phony_targets         | -MP                   | Emits dummy makefile rules.                                                                                                                                                                                       |  |
| preinclude            | -include              | Include the source code of a specified file at the beginning of th compilation.                                                                                                                                   |  |
| relaxed_ref_def       | -fcommon              | Places zero-initialized definitions in a common block.                                                                                                                                                            |  |
| -S                    | -S                    | Outputs the disassembly of the machine code generated by the compiler.                                                                                                                                            |  |
|                       |                       | The output from this option differs between releases. Older Arm<br>Compiler versions produce output with armasm syntax while<br>Arm Compiler 6 produces output with GNU syntax.                                   |  |
| show_cmdline          | -v                    | Shows how the compiler processes the command-line. The commands are shown normalized, and the contents of any via files are expanded.                                                                             |  |
| split_ldm             | -fno-ldm-stm          | Disables the generation of LDM and STM instructions.                                                                                                                                                              |  |
|                       |                       | Note that while the armccsplit_ldm option limits the size<br>of generated LDM/STM instructions, the armclang -fno-<br>ldm-stm option disables the generation of LDM and STM<br>instructions altogether.           |  |
| split_sections        | -ffunction-sections   | Generates one ELF section for each function in the source file.                                                                                                                                                   |  |
|                       |                       | In Arm Compiler 6, -ffunction-sections is the default.<br>Therefore, the merging of identical constants cannot be done by<br>armclang. Instead, the merging is done by armlink.                                   |  |
| strict                | -pedantic-errors      | Generate errors if code violates strict ISO C and ISO C++.                                                                                                                                                        |  |
| strict_warnings       | -pedantic             | Generate warnings if code violates strict ISO C and ISO C++.                                                                                                                                                      |  |
| thumb                 | -mthumb               | Targets the T32 instruction set.                                                                                                                                                                                  |  |

| Arm Compiler 5 option                           | Arm Compiler 6 option                                    | Description                                                                                                                           |  |
|-------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|
| <pre>no_unaligned_access,unaligned_access</pre> | -mno-unaligned-<br>access,<br>-munaligned-access         | Enables or disables unaligned accesses to data on Arm processors.                                                                     |  |
| use_frame_pointer,<br>no_use_frame_pointer      | -fno-omit-frame-<br>pointer,<br>-fomit-frame-<br>pointer | Controls whether a register is reserved for storing the stack frame pointer.                                                          |  |
| vectorize<br>no_vectorize                       | -fvectorize<br>-fno-vectorize                            | Enables or disables the generation of Advanced SIMD vector instructions directly from C or C++ code.                                  |  |
| via                                             | @file                                                    | Reads an additional list of compiler options from a file.                                                                             |  |
| vla                                             | No equivalent.                                           | Support for variable length arrays. Arm Compiler 6 automatica supports variable length arrays in accordance to the language standard. |  |
| vsn                                             | version                                                  | Displays version information and license details. In Arm<br>Compiler 6 you can also usevsn.                                           |  |
| wchar16,wchar32                                 | -fshort-wchar,-fno-<br>short-wchar                       | Sets the size of wchar_t type.<br>The default for Arm Compiler 5 iswchar16. The default for<br>Arm Compiler 6 is -fno-short-wchar.    |  |

| Table 3-1 Comparison of compiler command-line options in Arm Compiler 5 and | Arm Compiler 6 (continued) |
|-----------------------------------------------------------------------------|----------------------------|
|-----------------------------------------------------------------------------|----------------------------|

# **Related information**

armclang Command-line Options Compiler-specific Function, Variable, and Type Attributes Merging identical constants The LLVM Compiler Infrastructure Project

## 3.2 Command-line options for preprocessing assembly source code

The functionality of the --cpreproc and --cpreproc\_opts command-line options in the version of armasm supplied with Arm Compiler 6 is different from the options used in earlier versions of armasm to preprocess assembly source code.

If you are using armasm to assemble source code that requires the use of the preprocessor, you must use both the --cpreproc and --cpreproc\_opts options together. Also:

- As a minimum, you must include the armclang options --target and either -mcpu or -march in -- cpreproc\_opts.
- The input assembly source must have an upper-case extension .S.

If you have existing source files, which require preprocessing, and that have the lower-case extension .s, then to avoid having to rename the files:

- 1. Perform the pre-processing step manually using the armclang -x assembler-with-cpp option.
- 2. Assemble the preprocessed file without using the --cpreproc and --cpreproc\_opts options.

### Example using armclang -x

This example shows the use of the armclang -x option.

```
armclang --target=aarch64-arm-none-eabi -march=armv8-a -x assembler-with-cpp -E test.s -o
test_preproc.s
armasm --cpu=8-A.64 test_preproc.s
```

### Example using armasm --cpreproc\_opts

The options to the preprocessor in this example are --cpreproc\_opts=--target=arm-arm-none-eabi,-mcpu=cortex-a9,-D,DEF1,-D,DEF2.

armasm --cpu=cortex-a9 --cpreproc --cpreproc\_opts=--target=arm-arm-none-eabi,-mcpu=cortexa9,-D,DEF1,-D,DEF2 -I /path/to/includes1 -I /path/to/includes2 input.S

---- Note ----

Ensure that you specify compatible architectures in the armclang options --target, -mcpu or -march, and the armasm --cpu option.

#### **Related information**

-cpreproc assembler option
-cpreproc\_opts assembler option
Specifying a target architecture, processor, and instruction set
-march armclang option
-target armclang option
-target armclang option
-x armclang option
Preprocessing assembly code

## 3.3 Inline assembly with Arm<sup>®</sup> Compiler 6

Inline assembly in Arm Compiler 6 must be written in GNU assembly syntax. Inline assembly in Arm Compiler 5 is written in armasm syntax. If you have inline assembly written in armasm syntax, you must modify this to use GNU assembly syntax.

In Arm Compiler 5:

- You can use C variable names directly inside inline assembly statements.
- You do not have direct access to physical registers. You must use C or C++ variables names as operands, and the compiler maps them to physical register. You must set the value of these variables before you read them within an inline assembly statement.
- If you use register names in inline assembly code, they are treated as C or C++ variables. They do not necessarily relate to the physical register of the same name. If the register name is not declared as a C or C++ variable, the compiler generates a warning.

In Arm Compiler 6:

- You cannot use C or C++ variable names directly inside inline assembly statements. You can map the physical registers to C or C++ variable names using operand mapping and constraints.
- You have direct access to physical registers. There is no need to set the value of the registers before you read them within inline assembly statements.
- If you use register names in inline assembly code, they are the physical register of the same name.

In Arm Compiler 6 you cannot use C variable names directly within inline assembly. However, the GNU assembly syntax in Arm Compiler 6 provides a way for mapping input and output operands to C variable names.

Arm Compiler 5 optimizes inline assembly, but Arm Compiler 6 emits it exactly as written.

For more information on writing inline assembly using \_\_asm in armclang, see \_\_asm.

For more information on GNU assembly syntax, see 5.2 Overview of differences between armasm and GNU syntax assembly code on page 5-72.

## Inline assembly example in Arm® Compiler 5

The example below shows inline assembly code in Arm Compiler 5.

```
foo.c:
int add(int i, int j)
{
    int res;
    __asm
    (
        "ADD res, i, j \t\n"
        "SUB res, i, res \t\n"
    );
    return res;
}
```

The example below shows an alternative syntax for inline assembly code in Arm Compiler 5.

```
foo.c:
int add(int i, int j)
{
    int res;
    ___asm
    {
        ADD res, i, j
        SUB res, i, res
    }
    return res;
}
```

Compile foo.c using armcc:

```
armcc foo.c -c -S -o foo.s
```

Arm Compiler 5 converts the example inline assembly code to:

```
foo.s:

add PROC

ADD r1,r0,r1

SUB r0,r0,r1

BX lr

ENDP
```

## Inline assembly example in Arm® Compiler 6

The example below shows the equivalent inline assembly code in Arm Compiler 6.

```
foo.c:
int add(int i, int j)
{
    int res = 0;
    _asm
    (
        "ADD %[result], %[input_i], %[input_j] \t\n"
        "SUB %[result], %[input_i], %[result] \t\n"
        : [result] "=&r" (res)
        : [input_i] "r" (i), [input_j] "r" (j)
    );
    return res;
}
```

Compile foo.c using armclang with optimization level -O1:

armclang foo.c --target=arm-arm-none-eabi -march=armv8-a -O1 -c -S -o foo.s

Arm Compiler 6 converts the example inline assembly code to:

— Note -

Arm Compiler 6 supports inline assembly using the \_\_asm or asm keywords. However the asm keyword is accepted only when:

- Used within C++ language source files.
- Used within C language source files without strict ISO C Standard compliance. For example, asm is accepted when using -std=gnu11.

## **Related information**

armclang Inline Assembler How to Use Inline Assembly Language in C Code Constraints for asm Operands Constraint Modifier Characters

## 3.4 Migrating architecture and processor names for command-line options

There are minor differences between the architecture and processor names that Arm Compiler 6 recognizes, and the names that Arm Compiler 5 recognizes. Within Arm Compiler 6, there are differences in the architecture and processor names that armclang recognizes and the names that armasm, armlink, and fromelf recognize. This topic shows the differences in the architecture and processor names for the different tools in Arm Compiler 5 and Arm Compiler 6.

The tables show the documented --cpu options in Arm Compiler 5 and their corresponding options for migrating your Arm Compiler 5 command-line options to Arm Compiler 6.

\_\_\_\_\_ Note \_\_\_\_\_

The tables assume the default floating-point unit derived from the --cpu option in Arm Compiler 5. However, in Arm Compiler 6, armclang selects different defaults for floating-point unit (VFP) and Advanced SIMD. Therefore, the tables also show how to use the armclang -mfloat-abi and -mfpu options to be compatible with the default floating-point unit in Arm Compiler 5. The tables do not provide an exhaustive list.

| armcc, armlink, armasm,<br>and fromelf option in Arm<br>Compiler 5 | armclang option in Arm<br>Compiler 6         | armlink, armasm, and<br>fromelf option in Arm<br>Compiler 6 | Architecture description |
|--------------------------------------------------------------------|----------------------------------------------|-------------------------------------------------------------|--------------------------|
| cpu=4                                                              | Not supported                                | Not supported                                               | Armv4                    |
| cpu=4T                                                             | Not supported                                | Not supported                                               | Armv4T                   |
| cpu=5T                                                             | Not supported                                | Not supported                                               | Armv5T                   |
| cpu=5TE                                                            | Not supported                                | Not supported                                               | Armv5TE                  |
| cpu=5TEJ                                                           | Not supported                                | Not supported                                               | Armv5TEJ                 |
| cpu=6                                                              | Not supported                                | Not supported                                               | Generic Armv6            |
| cpu=6-K                                                            | Not supported                                | Not supported                                               | Armv6-K                  |
| cpu=6-Z                                                            | Not supported                                | Not supported                                               | Armv6-Z                  |
| cpu=6T2                                                            | Not supported                                | Not supported                                               | Armv6T2                  |
| cpu=6-M                                                            | target=arm-arm-none-<br>eabi -march=armv6-m  | cpu=6S-M                                                    | Armv6-M                  |
| cpu=6S-M                                                           | target=arm-arm-none-<br>eabi -march=armv6s-m | cpu=6S-M                                                    | Armv6S-M                 |

### Table 3-2 Architecture selection in Arm Compiler 5 and Arm Compiler 6

| armcc, armlink, armasm,<br>and fromelf option in Arm<br>Compiler 5 | armclang option in Arm<br>Compiler 6                              | armlink, armasm, and<br>fromelf option in Arm<br>Compiler 6 | Architecture description                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cpu=7-A<br>cpu=7-A.security                                        | target=arm-arm-none-<br>eabi -march=armv7-a -<br>mfloat-abi=soft  | cpu=7-A.security                                            | Armv7-A without VFP and<br>Advanced SIMD.<br>In Arm Compiler 5, security<br>extension is not enabled with<br>cpu=7-A but is enabled with<br>cpu=7-A.security. In<br>Arm Compiler 6, armclang<br>always enables the Armv7-A<br>TrustZone security extension<br>with -march=armv7-a.<br>However, armclang does not<br>generate an SMC instruction<br>unless you specify it with an<br>intrinsic or inline assembly. |
| cpu=7-R                                                            | target=arm-arm-none-<br>eabi -march=armv7-r -<br>mfloat-abi=soft  | cpu=7-R                                                     | Armv7-R without VFP and<br>Advanced SIMD                                                                                                                                                                                                                                                                                                                                                                          |
| cpu=7-M                                                            | target=arm-arm-none-<br>eabi -march=armv7-m                       | cpu=7-M                                                     | Armv7-M                                                                                                                                                                                                                                                                                                                                                                                                           |
| cpu=7E-M                                                           | target=arm-arm-none-<br>eabi -march=armv7e-m -<br>mfloat-abi=soft | cpu=7E-M                                                    | Armv7E-M                                                                                                                                                                                                                                                                                                                                                                                                          |

## Table 3-2 Architecture selection in Arm Compiler 5 and Arm Compiler 6 (continued)

## Table 3-3 Processor selection in Arm Compiler 5 and Arm Compiler 6

| armcc, armlink, armasm,<br>and fromelf option in Arm<br>Compiler 5 | armclang option in Arm<br>Compiler 6                                                  | armlink, armasm, and<br>fromelf option in Arm<br>Compiler 6 | Description                                  |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------|
| cpu=Cortex-A5                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-a5 -<br>mfloat-abi=soft                     | cpu=Cortex-<br>A5.no_neon.no_vfp                            | Cortex-A5 without Advanced<br>SIMD and VFP   |
| cpu=Cortex-A5.neon                                                 | target=arm-arm-none-<br>eabi -mcpu=cortex-a5 -<br>mfloat-abi=hard                     | cpu=Cortex-A5                                               | Cortex-A5 with Advanced<br>SIMD and VFP      |
| cpu=Cortex-A5.vfp                                                  | target=arm-arm-none-<br>eabi -mcpu=cortex-a5 -<br>mfloat-abi=hard -<br>mfpu=vfpv4-d16 | cpu=Cortex-A5.no_neon                                       | Cortex-A5 with VFP, without<br>Advanced SIMD |
| cpu=Cortex-A7                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-a7 -<br>mfloat-abi=hard                     | cpu=Cortex-A7                                               | Cortex-A7 with Advanced<br>SIMD and VFP      |
| cpu=Cortex-<br>A7.no_neon.no_vfp                                   | target=arm-arm-none-<br>eabi -mcpu=cortex-a7 -<br>mfloat-abi=soft                     | cpu=Cortex-<br>A7.no_neon.no_vfp                            | Cortex-A7 without Advanced<br>SIMD and VFP   |

| armcc, armlink, armasm,<br>and fromelf option in Arm<br>Compiler 5 | armclang option in Arm<br>Compiler 6                                                       | armlink, armasm, and<br>fromelf option in Arm<br>Compiler 6 | Description                                     |
|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------|
| cpu=Cortex-A7.no_neon                                              | target=arm-arm-none-<br>eabi -mcpu=cortex-a7 -<br>mfloat-abi=hard -<br>mfpu=vfpv4-d16      | cpu=Cortex-A7.no_neon                                       | Cortex-A7 with VFP, without<br>Advanced SIMD    |
| cpu=Cortex-A8                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-a8 -<br>mfloat-abi=hard                          | cpu=Cortex-A8                                               | Cortex-A8 with VFP and<br>Advanced SIMD         |
| cpu=Cortex-A8.no_neon                                              | target=arm-arm-none-<br>eabi -mcpu=cortex-a8 -<br>mfloat-abi=soft                          | cpu=Cortex-A8.no_neon                                       | Cortex-A8 without Advanced<br>SIMD and VFP      |
| cpu=Cortex-A9                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-a9 -<br>mfloat-abi=hard                          | cpu=Cortex-A9                                               | Cortex-A9 with Advanced<br>SIMD and VFP         |
| cpu=Cortex-<br>A9.no_neon.no_vfp                                   | target=arm-arm-none-<br>eabi -mcpu=cortex-a9 -<br>mfloat-abi=soft                          | cpu=Cortex-<br>A9.no_neon.no_vfp                            | Cortex-A9 without Advanced<br>SIMD and VFP      |
| cpu=Cortex-A9.no_neon                                              | target=arm-arm-none-<br>eabi -mcpu=cortex-a9 -<br>mfloat-abi=hard -<br>mfpu=vfpv3-d16-fp16 | cpu=Cortex-A9.no_neon                                       | Cortex-A9 with VFP but<br>without Advanced SIMD |
| cpu=Cortex-A12                                                     | target=arm-arm-none-<br>eabi -mcpu=cortex-a12 -<br>mfloat-abi=hard                         | cpu=Cortex-A12                                              | Cortex-A12 with Advanced<br>SIMD and VFP        |
| cpu=Cortex-<br>A12.no_neon.no_vfp                                  | target=arm-arm-none-<br>eabi -mcpu=cortex-a12 -<br>mfloat-abi=soft                         | cpu=Cortex-<br>A12.no_neon.no_vfp                           | Cortex-A12 without Advanced<br>SIMD and VFP     |
| cpu=Cortex-A15                                                     | target=arm-arm-none-<br>eabi -mcpu=cortex-a15 -<br>mfloat-abi=hard                         | cpu=Cortex-A15                                              | Cortex-A15 with Advanced<br>SIMD and VFP        |
| cpu=Cortex-<br>A15.no_neon                                         | target=arm-arm-none-<br>eabi -mcpu=cortex-a15 -<br>mfloat-abi=hard -<br>mfpu=vfpv4-d16     | cpu=Cortex-<br>A15.no_neon                                  | Cortex-A15 with VFP, without<br>Advanced SIMD   |
| cpu=Cortex-<br>A15.no_neon.no_vfp                                  | target=arm-arm-none-<br>eabi -mcpu=cortex-a15 -<br>mfloat-abi=soft                         | cpu=Cortex-<br>A15.no_neon.no_vfp                           | Cortex-A15 without Advanced<br>SIMD and VFP     |
| cpu=Cortex-A17                                                     | target=arm-arm-none-<br>eabi -mcpu=cortex-a17 -<br>mfloat-abi=hard                         | cpu=Cortex-A17                                              | Cortex-A17 with Advanced<br>SIMD and VFP        |
| cpu=Cortex-<br>A17.no_neon.no_vfp                                  | target=arm-arm-none-<br>eabi -mcpu=cortex-a17 -<br>mfloat-abi=soft                         | cpu=Cortex-<br>A17.no_neon.no_vfp                           | Cortex-A17 without Advanced<br>SIMD and VFP     |

## Table 3-3 Processor selection in Arm Compiler 5 and Arm Compiler 6 (continued)

| armcc, armlink, armasm,<br>and fromelf option in Arm<br>Compiler 5 | armclang option in Arm<br>Compiler 6                                                | armlink, armasm, and<br>fromelf option in Arm<br>Compiler 6 | Description                            |
|--------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------|
| cpu=Cortex-R4                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-r4                                        | cpu=Cortex-R4                                               | Cortex-R4 without VFP                  |
| cpu=Cortex-R4F                                                     | target=arm-arm-none-<br>eabi -mcpu=cortex-r4f -<br>mfloat-abi=hard                  | cpu=Cortex-R4F                                              | Cortex-R4 with VFP                     |
| cpu=Cortex-R5                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-r5 -<br>mfloat-abi=soft                   | cpu=Cortex-R5.no_vfp                                        | Cortex-R5 without VFP                  |
| cpu=Cortex-R5F                                                     | target=arm-arm-none-<br>eabi -mcpu=cortex-r5 -<br>mfloat-abi=hard                   | cpu=Cortex-R5                                               | Cortex-R5 with double<br>precision VFP |
| cpu=Cortex-R5F-<br>rev1.sp                                         | target=arm-arm-none-<br>eabi -mcpu=cortex-r5 -<br>mfloat-abi=hard -<br>mfpu=vfpv3xd | cpu=Cortex-R5.sp                                            | Cortex-R5 with single precision<br>VFP |
| cpu=Cortex-R7                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-r7 -<br>mfloat-abi=hard                   | cpu=Cortex-R7                                               | Cortex-R7 with VFP                     |
| cpu=Cortex-R7.no_vfp                                               | target=arm-arm-none-<br>eabi -mcpu=cortex-r7 -<br>mfloat-abi=soft                   | cpu=Cortex-R7.no_vfp                                        | Cortex-R7 without VFP                  |
| cpu=Cortex-R8                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-r8 -<br>mfloat-abi=hard                   | cpu=Cortex-R8                                               | Cortex-R8 with VFP                     |
| cpu=Cortex-R8.no_vfp                                               | target=arm-arm-none-<br>eabi -mcpu=cortex-r8 -<br>mfloat-abi=soft                   | cpu=Cortex-R8.no_vfp                                        | Cortex-R8 without VFP                  |
| cpu=Cortex-M0                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-m0                                        | cpu=Cortex-M0                                               | Cortex-M0                              |
| cpu=Cortex-M0plus                                                  | target=arm-arm-none-<br>eabi -mcpu=cortex-<br>m0plus                                | cpu=Cortex-M0plus                                           | Cortex-M0+                             |
| cpu=Cortex-M1                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-m1                                        | cpu=Cortex-M1                                               | Cortex-M1                              |
| cpu=Cortex-M3                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-m3                                        | cpu=Cortex-M3                                               | Cortex-M3                              |
| cpu=Cortex-M4                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-m4 -<br>mfloat-abi=soft                   | cpu=Cortex-M4.no_fp                                         | Cortex-M4 without VFP                  |
| cpu=Cortex-M4.fp                                                   | target=arm-arm-none-<br>eabi -mcpu=cortex-m4 -<br>mfloat-abi=hard                   | cpu=Cortex-M4                                               | Cortex-M4 with VFP                     |

## Table 3-3 Processor selection in Arm Compiler 5 and Arm Compiler 6 (continued)

| armcc, armlink, armasm,<br>and fromelf option in Arm<br>Compiler 5 | armclang option in Arm<br>Compiler 6                                                    | armlink, armasm, and<br>fromelf option in Arm<br>Compiler 6 | Description                            |
|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------|
| cpu=Cortex-M7                                                      | target=arm-arm-none-<br>eabi -mcpu=cortex-m7 -<br>mfloat-abi=soft                       | cpu=Cortex-M7.no_fp                                         | Cortex-M7 without VFP                  |
| cpu=Cortex-M7.fp.dp                                                | target=arm-arm-none-<br>eabi -mcpu=cortex-m7 -<br>mfloat-abi=hard                       | cpu=Cortex-M7                                               | Cortex-M7 with double<br>precision VFP |
| cpu=Cortex-M7.fp.sp                                                | target=arm-arm-none-<br>eabi -mcpu=cortex-m7 -<br>mfloat-abi=hard -<br>mfpu=fpv5-sp-d16 | cpu=Cortex-M7.fp.sp                                         | Cortex-M7 with single<br>precision VFP |

## Table 3-3 Processor selection in Arm Compiler 5 and Arm Compiler 6 (continued)

## Enabling or disabling architectural features in Arm® Compiler 6

Arm Compiler 6, by default, automatically enables or disables certain architectural features such as the floating-point unit, Advanced SIMD, and Cryptographic extensions depending on the specified architecture or processor. For a list of architectural features, see -mcpu in the *armclang Reference Guide*. You can override the defaults using other options.

For armclang:

- For AArch64 targets, you must use either -march or -mcpu to specify the architecture or processor and the required architectural features. You can use +[no]feature with -march or -mcpu to override any architectural feature.
- For AArch32 targets, you must use either -march or -mcpu to specify the architecture or processor and the required architectural features. You can use -mfloat-abi to override floating-point linkage. You can use -mfpu to override floating-point unit, Advanced SIMD, and Cryptographic extensions. You can use +[no]feature with -march or -mcpu to override certain other architectural features.

For armasm, armlink, and fromelf, you must use the --cpu option to specify the architecture or processor and the required architectural features. You can use --fpu to override the floating-point unit and floating-point linkage. The --cpu option is not mandatory for armlink and fromelf, but is mandatory for armasm.

## – Note -

- In Arm Compiler 5, if you use the armcc --fpu=none option, the compiler generates an error if it detects floating-point code. This behavior is different in Arm Compiler 6. If you use the armclang mfpu=none option, the compiler automatically uses software floating-point libraries if it detects any floating-point code. You cannot use the armlink --fpu=none option to link object files created using armclang.
- To link object files created using the armclang -mfpu=none option, you must set armlink --fpu to an option that supports software floating-point linkage, for example --fpu=SoftVFP, rather than using --fpu=none.

## **Related information**

armclang -mcpu option armclang -march option armclang -mfloat-abi option armclang --mfpu option armclang --target option armlink --cpu option armlink --fpu option fromelf --cpu option fromelf --fpu option armasm --cpu option armasm --fpu option

## 3.5 Preprocessing a scatter file

Preprocessing a scatter file in Arm Compiler 6 requires extra options.

The following shows the required change for preprocessing a scatter fine in Arm Compiler 6:

## Arm Compiler 5

#!armcc -E

## Arm Compiler 6

#!armclang -E --target=arm-arm-none-eabi -mcpu=cortex-m7 -xc

The mandatory option --target specifies the target state, either AArch32 state, as shown in this example, or AArch64 state. See --*target*.

The option -mcpu specifies a processor, Cortex-M7 in this example. You can also use -march to specify an architecture. See -mcpu or -march.

The option -x specifies the source language. See -x.

For more information about the -E option, see -E.

## Chapter 4 Compiler Source Code Compatibility

Provides details of source code compatibility between Arm Compiler 6 and older armcc compiler versions.

It contains the following sections:

- 4.1 Language extension compatibility: keywords on page 4-48.
- 4.2 Language extension compatibility: attributes on page 4-51.
- 4.3 Language extension compatibility: pragmas on page 4-53.
- 4.4 Language extension compatibility: intrinsics on page 4-56.
- 4.5 Diagnostics for pragma compatibility on page 4-60.
- 4.6 C and C++ implementation compatibility on page 4-62.
- 4.7 *Compatibility of C++ objects* on page 4-64.

## 4.1 Language extension compatibility: keywords

Arm Compiler 6 provides support for some keywords that are supported in Arm Compiler 5.

\_\_\_\_\_ Note \_\_\_\_\_

This topic includes descriptions of [COMMUNITY] features. See Support level definitions on page 1-13.

The following table lists some of the commonly used keywords that are supported by Arm Compiler 5 and shows whether Arm Compiler 6 supports them using \_\_attribute\_\_. Replace any instances of these keywords in your code with the recommended alternative where available or use inline assembly instructions.

\_\_\_\_\_ Note \_\_\_\_

This is not an exhaustive list of all keywords.

| Keyword supported by Arm<br>Compiler 5 | Recommended Arm Compiler 6 keyword or alternative                                                                                                                                                                              |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| align(x)                               | attribute((aligned(x)))                                                                                                                                                                                                        |
| alignof                                | alignof                                                                                                                                                                                                                        |
| ALIGNOF                                | alignof                                                                                                                                                                                                                        |
| Embedded assembly usingasm             | Arm Compiler 6 does not support theasm keyword on function definitions and declarations for embedded assembly. Instead, you can write embedded assembly using theattribute((naked)) function attribute. Seeattribute((naked)). |
| const                                  | attribute((const))                                                                                                                                                                                                             |
| attribute((const))                     | attribute((const))                                                                                                                                                                                                             |
| forceinline                            | <ul> <li>For C90, useinline andattribute((always_inline))</li> <li>For other source languages, use inline andattribute((always_inline))</li> </ul>                                                                             |
|                                        | Seeattribute((always_inline)).                                                                                                                                                                                                 |
| global_reg                             | Use inline assembler instructions or equivalent routine.                                                                                                                                                                       |
| inline(x)                              | inline The use of this depends on the language mode.                                                                                                                                                                           |
| int64                                  | <ul> <li>No equivalent. However, you can use long long. When you use long long in C90 mode, the compiler gives:</li> <li>a warning.</li> <li>an error, if you also use -pedantic-errors.</li> </ul>                            |
| INTADDR                                | [COMMUNITY] None. There is community support for this as a Clang builtin.                                                                                                                                                      |
| irq                                    | attribute((interrupt)). This is not supported in AArch64.                                                                                                                                                                      |

## Table 4-1 Keyword language extensions in Arm Compiler 5 and Arm Compiler 6

| Keyword supported by Arm<br>Compiler 5            | Recommended Arm Compiler 6 keyword or alternative                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| packed for removing padding<br>within structures. | <ul> <li>_attribute_((packed)). This provides limited functionality compared topacked</li> <li>Theattribute_((packed)) variable attribute applies to members of a structure union, but it does not apply to variables that are not members of a struct or union.</li> <li>attribute_((packed)) is not a type qualifier. Taking the address of a packed member can result in unaligned pointers, and in most cases the compiler generates a warning. Arm recommends upgrading this warning to an error when migrating code th usespacked. To upgrade the warning to error, use the armclang option - Werror=name.</li> <li>The placement of the attribute is different from the placement ofpacked. If your legacy code contains typedefpacked struct, then replace it with:</li> </ul> |  |
| packed as a type qualifier for unaligned access.  | <pre></pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| pure                                              | attribute((const))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| smc                                               | Use inline assembler instructions or equivalent routine.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| softfp                                            | attribute((pcs("aapcs")))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| svc                                               | Use inline assembler instructions or equivalent routine.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| svc_indirect                                      | Use inline assembler instructions or equivalent routine.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| svc_indirect_r7                                   | Use inline assembler instructions or equivalent routine.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| thread                                            | thread                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| value_in_regs                                     | attribute((value_in_regs))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| weak                                              | attribute((weak))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| writeonly                                         | No equivalent.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |

## Table 4-1 Keyword language extensions in Arm Compiler 5 and Arm Compiler 6 (continued)

----- Note ------

The \_\_const keyword was supported by older versions of armcc. The equivalent for this keyword in Arm Compiler 5 and Arm Compiler 6 is \_\_attribute\_\_((const)).

## Migrating the \_\_packed keyword from Arm® Compiler 5 to Arm® Compiler 6

The \_\_packed keyword in Arm Compiler 5 has the effect of:

- Removing the padding within structures.
- Qualifying the variable for unaligned access.

Arm Compiler 6 does not support \_\_packed, but supports \_\_attribute\_\_((packed)) and \_\_unaligned keyword. Depending on the use, you might need to replace \_\_packed with both

\_\_attribute\_\_((packed)) and \_\_unaligned. The following table shows the migration paths for various uses of \_\_packed.

## Table 4-2 Migrating the \_\_packed keyword

| Arm Compiler 5                         | Arm Compiler 6                                                                                                                                                           |
|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| packed int x;                          | unaligned int x;                                                                                                                                                         |
| packed int *x;                         | unaligned int *x;                                                                                                                                                        |
| int *packed x;                         | <pre>int *unaligned x;</pre>                                                                                                                                             |
| unaligned int *packed x;               | unaligned int *unaligned x;                                                                                                                                              |
| <pre>typedefpacked struct S{} s;</pre> | <pre>typedefunaligned structattribute((packed)) S{} s;</pre>                                                                                                             |
| <pre>packed struct S{};</pre>          | There is currently no migration. Use a typedef instead.                                                                                                                  |
| <pre>packed struct S{} s;</pre>        | <pre>unaligned structattribute((packed)) S{} s;<br/>Subsequent declarations of variables of type struct S must useunaligned, for<br/>exampleunaligned struct S s2.</pre> |
| <pre>struct S{packed int a;}</pre>     | <pre>struct S {attribute((packed))unaligned int a;}</pre>                                                                                                                |

## **Related reference**

4.6 C and C++ implementation compatibility on page 4-62 4.2 Language extension compatibility: attributes on page 4-51 4.3 Language extension compatibility: pragmas on page 4-53 **Related information** -W

## 4.2 Language extension compatibility: attributes

Arm Compiler 6 provides support for some function, variable, and type attributes that were supported in Arm Compiler 5. Other attributes are not supported, or have an alternate implementation.

The following attributes are supported by Arm Compiler 5 and Arm Compiler 6. These attributes do not require modification in your code:

- \_\_attribute\_\_((aligned(x)))
- \_\_attribute\_\_((const))
- \_\_attribute\_\_((deprecated))
- \_\_attribute\_\_((noinline))
- \_\_declspec(noinline)
- \_\_attribute\_\_((nonnull))
- \_\_attribute\_\_((noreturn))
- \_\_declspec(noreturn)
- \_\_attribute\_\_((nothrow))
- \_\_declspec(nothrow)
- \_\_attribute\_\_((pcs("calling convention")))
- \_\_attribute\_\_((pure))
- \_\_attribute\_\_((unused))
- \_\_attribute\_\_((used))
- \_\_attribute\_\_((visibility))
- \_\_attribute\_\_((weak))
- \_\_attribute\_\_((weakref))

Though Arm Compiler 6 supports certain \_\_declspec attributes, Arm recommends using \_\_attribute\_\_ where available.

| Table 4-3 | Support for | declspec | attributes |
|-----------|-------------|----------|------------|
|-----------|-------------|----------|------------|

| declspec supported by Arm Compiler 5 | Recommended Arm Compiler 6 alternative              |
|--------------------------------------|-----------------------------------------------------|
| declspec(dllimport)                  | None. There is no support for BPABI linking models. |
| declspec(dllexport)                  | None. There is no support for BPABI linking models. |
| declspec(noinline)                   | attribute((noinline))                               |
| declspec(noreturn)                   | attribute((noreturn))                               |
| declspec(nothrow)                    | attribute((nothrow))                                |
| declspec(notshared)                  | None. There is no support for BPABI linking models. |
| declspec(thread)                     | thread                                              |

## \_\_attribute\_\_((always\_inline))

\_\_attribute\_\_((always\_inline)) is supported by Arm Compiler 5 and Arm Compiler 6. However, this attribute might require modification in your code.

When using Arm Compiler 5, <u>\_\_attribute\_\_((always\_inline))</u> affects the linkage of the function according to the inline semantics of the source language.

When using Arm Compiler 6, <u>\_\_attribute\_\_((always\_inline))</u> does not affect the linkage of the function. To change the linkage according to the inline semantics, you must use the keyword inline or <u>\_\_inline\_\_</u> (for C90). For more information, see <u>\_\_attribute\_\_((always\_inline))</u>.

## Section

\_\_attribute\_\_((section("name"))) is supported by Arm Compiler 5 and Arm Compiler 6. However, this attribute might require modification in your code.

When using Arm Compiler 5, section names do not need to be unique. Therefore, you could use the same section name to create different section types.

Arm Compiler 6 supports multiple sections with the same section name only if you specify a *unique ID*. You must ensure that different section types either:

- Have a unique section name.
- Have a unique ID, if they have the same section name.

If you use the same section name, for another section or symbol, without a unique ID, then armclang integrated assembler merges the sections and gives the merged section the flags of the first section with that name.

## Migrating \_\_attribute\_\_((at(*address*))) and zero-initialized \_\_attribute\_\_((section("*name*"))) from Arm<sup>®</sup> Compiler 5 to Arm<sup>®</sup> Compiler 6

Arm Compiler 5 supports the following attributes, which Arm Compiler 6 does not support:

- \_\_attribute\_\_((at(address))) to specify the absolute address of a function or variable.
- \_\_attribute\_\_((at(address), zero\_init)) to specify the absolute address of a zero-initialized variable.
- \_\_attribute\_\_((section(*name*), zero\_init)) to place a zero-initialized variable in a zero-initialized section with the given *name*.
- \_\_attribute\_\_((zero\_init)) to generate an error if the variable has an initializer.

The following table shows migration paths for these features using Arm Compiler 6 supported features:

| Arm Compiler 5 attribute                             | Arm Compiler 6 attribute                                                                                                                                                   | Description                                                                                                                                                                                      |
|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| attribute((at( <i>address</i> )))                    | attribute((section(".ARMat_ <i>address</i> ")))                                                                                                                            | armlink in Arm Compiler 6<br>still supports the placement of<br>sections in the form<br>of .ARMat_ <i>address</i>                                                                                |
| <pre>attribute((at(address), zero_init))</pre>       | attribute((section(".bss.ARMat_ <i>address</i> ")))                                                                                                                        | armlink in Arm Compiler 6<br>supports the placement of zero-<br>initialized sections in the form<br>of .bss.ARMat_address.<br>The .bss prefix is case<br>sensitive and must be all<br>lowercase. |
| <pre>attribute((section(name),<br/>zero_init))</pre> | attribute((section(".bss.name")))                                                                                                                                          | <i>name</i> is a name of your choice.<br>The .bss prefix is case<br>sensitive and must be all<br>lowercase.                                                                                      |
| attribute((zero_init))                               | Arm Compiler 6 by default places zero-initialized variables in<br>a .bss section. However, there is no equivalent to generate an<br>error when you specify an initializer. | Arm Compiler 5 generates an<br>error if the variable has an<br>initializer. Otherwise, it places<br>the zero-initialized variable in<br>a .bss section.                                          |

## Table 4-4 Migrating \_\_attribute\_\_((at(address))) and zero-initialized \_\_attribute\_\_((section("name")))

## **Related reference**

4.6 C and C++ implementation compatibility on page 4-62

4.1 Language extension compatibility: keywords on page 4-48

4.3 Language extension compatibility: pragmas on page 4-53

**Related information** 

armlink User Guide: Placing at sections at a specific address

## 4.3 Language extension compatibility: pragmas

Arm Compiler 6 provides support for some pragmas that are supported in Arm Compiler 5. Other pragmas are not supported, or must be replaced with alternatives.

The following table lists some of the commonly used pragmas that are supported by Arm Compiler 5 but are not supported by Arm Compiler 6. Replace any instances of these pragmas in your code with the recommended alternative.

| Pragma supported by Arm Compiler 5                    | Recommended Arm Compiler 6 alternative                                                                                                                                                                                                                                 |
|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>#pragma import (symbol)</pre>                    | asm(".global <i>symbol</i> \n\t");                                                                                                                                                                                                                                     |
| <pre>#pragma anon_unions #pragma no_anon_unions</pre> | In C, anonymous structs and unions are a C11 extension which is enabled by default in armclang. If you specify the <b>-pedantic</b> option, the compiler emits warnings about extensions do not match the specified language standard. For example:                    |
|                                                       | <pre>armclangtarget=aarch64-arm-none-eabi -c -pedanticstd=c90 test.c test.c:3:5: warning: anonymous structs are a C11 extension [- Wc11-extensions]</pre>                                                                                                              |
|                                                       | In C++, anonymous unions are part of the language standard, and are always enabled. However, anonymous structs and classes are an extension. If you specify the <b>-pedantic</b> option, the compiler emits warnings about anonymous structs and classes. For example: |
|                                                       | armclangtarget=aarch64-arm-none-eabi -c -pedantic -xc++<br>test.c<br>test.c:3:5: warning: anonymous structs are a GNU extension [-<br>Wgnu-anonymous-struct]                                                                                                           |
|                                                       | Introducing anonymous unions, struct and classes using a typedef is a separate extension in armclang, which must be enabled using the -fms-extensions option.                                                                                                          |
| #pragma arm<br>#pragma thumb                          | armclang does not support switching instruction set in the middle of a file. You can use the command-line options -marm and -mthumb to specify the instruction set of the whole file.                                                                                  |
| #pragma arm section                                   | <pre>#pragma clang section</pre>                                                                                                                                                                                                                                       |
|                                                       | In Arm Compiler 5, the section types you can use this pragma with are rodata, rwdata, zidata, and code. In Arm Compiler 6, the equivalent section types are rodata, data, bss, and text respectively.                                                                  |

#### Table 4-5 Pragma language extensions that must be replaced

| Pragma supported by Arm Compiler 5                                                                                | Recommended Arm Compiler 6 alternative                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>#pragma diag_default #pragma diag_suppress #pragma diag_remark #pragma diag_warning #pragma diag_error</pre> | The following pragmas provide equivalent functionality for diag_suppress,<br>diag_warning, and diag_error:<br>• #pragma clang diagnostic ignored "-Wmultichar"<br>• #pragma clang diagnostic warning "-Wmultichar"<br>• #pragma clang diagnostic error "-Wmultichar"<br>Note that these pragmas use armclang diagnostic groups, which do not have a<br>precise mapping to armcc diagnostic tags.<br>armclang has no equivalent to diag_default or diag_remark.<br>diag_default can be replaced by wrapping the change of diagnostic level with<br>#pragma clang diagnostic push and #pragma clang diagnostic pop,<br>or by manually returning the diagnostic to the default level.<br>There is an additional diagnostic level supported in armclang, fatal, which causes<br>compilation to fail without processing the rest of the file. You can set this as<br>follows: |
|                                                                                                                   | #pragma clang diagnostic fatal "-Wmultichar"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <pre>#pragma exceptions_unwind</pre>                                                                              | armclang does not support these pragmas.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <pre>#pragma no_exceptions_unwind</pre>                                                                           | Use theattribute((nothrow)) function attribute instead.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <pre>#pragma GCC system_header</pre>                                                                              | This pragma is supported by both armcc and armclang, but <b>#pragma clang</b> system_header is the preferred spelling in armclang for new code.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| #pragma hdrstop<br>#pragma no_pch                                                                                 | armclang does not support these pragmas.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <pre>#pragma import(use_no_semihosting) #pragma</pre>                                                             | <pre>armclang does not support these pragmas. However, in C code, you can replace these pragmas with:    asm(".globaluse_no_semihosting\n\t");</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <pre>import(use_no_semihosting_swi)</pre>                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| #pragma inline<br>#pragma no_inline                                                                               | <pre>armclang does not support these pragmas. However, inlining can be disabled on a per-function basis using theattribute((noinline)) function attribute. The default behavior of both armcc and armclang is to inline functions when the compiler considers this worthwhile, and this is the behavior selected by using #pragma inline in armcc. To force a function to be inlined in armclang, use theattribute((always_inline)) function attribute.</pre>                                                                                                                                                                                                                                                                                                                                                                                                            |
| #pragma Onum<br>#pragma Ospace<br>#pragma Otime                                                                   | armclang does not support changing optimization options within a file. Instead these must be set on a per-file basis using command-line options.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

## Table 4-5 Pragma language extensions that must be replaced (continued)

| Pragma supported by Arm Compiler 5   | Recommended Arm Compiler 6 alternative                                                                                                                                                                                                                                                    |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| #pragma pop<br>#pragma push          | armclang does not support these pragmas. Therefore, you cannot push and pop the state of all supported pragmas.                                                                                                                                                                           |
|                                      | However, you can push and pop the state of the diagnostic pragmas and the state of the pack pragma.                                                                                                                                                                                       |
|                                      | To control the state of the diagnostic pragmas, use <b>#pragma clang diagnostic</b> push and <b>#pragma clang diagnostic</b> pop.                                                                                                                                                         |
|                                      | To control the state of the pack pragma, use <b>#pragma pack(push)</b> and <b>#pragma pack(pop)</b> .                                                                                                                                                                                     |
| <pre>#pragma softfp_linkage</pre>    | <pre>armclang does not support this pragma. Instead, use the<br/>attribute((pcs("aapcs"))) function attribute to set the calling<br/>convention on a per-function basis, or use the -mfloat-abi=soft command-line<br/>option to set the calling convention on a per-file basis.</pre>     |
| <pre>#pragma no_softfp_linkage</pre> | <pre>armclang does not support this pragma. Instead, use the<br/>attribute((pcs("aapcs-vfp"))) function attribute to set the calling<br/>convention on a per-function basis, or use the -mfloat-abi=hard command-line<br/>option to set the calling convention on a per-file basis.</pre> |
| <pre>#pragma unroll[(n)]</pre>       | armclang supports these pragmas.                                                                                                                                                                                                                                                          |
| <pre>#pragma unroll_completely</pre> | <ul> <li>The default for #pragma unroll (that is, with no iteration count specified) differs between armclang and armcc:</li> <li>With armclang, the default is to fully unroll a loop.</li> </ul>                                                                                        |
|                                      | • With armcc, the default is <b>#pragma</b> unroll(4).                                                                                                                                                                                                                                    |

### Table 4-5 Pragma language extensions that must be replaced (continued)

## **Related reference**

*4.6 C and C++ implementation compatibility* on page 4-62

4.1 Language extension compatibility: keywords on page 4-48

4.2 Language extension compatibility: attributes on page 4-51

4.5 Diagnostics for pragma compatibility on page 4-60

**Related information** 

armclang Reference Guide: #pragma GCC system\_header

armclang Reference Guide: #pragma once

armclang Reference Guide: #pragma pack(n)

armclang Reference Guide: #pragma weak symbol, #pragma weak symbol1 = symbol2

armclang Reference Guide: #pragma unroll[(n)], #pragma unroll\_completely

## 4.4 Language extension compatibility: intrinsics

Arm Compiler 6 provides support for some intrinsics that are supported in Arm Compiler 5.

The following table lists some of the commonly used intrinsics that are supported by Arm Compiler 5 and shows whether Arm Compiler 6 supports them or provides an alternative. If there is no support Arm Compiler 6, you must replace them with suitable inline assembly instructions or calls to the standard library. To use the intrinsic in Arm Compiler 6, you must include the appropriate header file. For more information on the ACLE intrinsics, see the *Arm*<sup>®</sup> *C Language Extensions*.

— Note —

- This is not an exhaustive list of all the intrinsics.
- The intrinsics provided in <arm\_compat.h> are only supported for AArch32.

| Intrinsic in Arm<br>Compiler 5 | Function                                                                                     | Support in Arm Compiler 6                                         | Header file for<br>Arm Compiler 6 |
|--------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------|
| breakpoint                     | Inserts a BKPT instruction.                                                                  | Yes                                                               | arm_compat.h                      |
| cdp                            | Inserts a coprocessor instruction.                                                           | Yes. In Arm Compiler 6, the equivalent intrinsic isarm_cdp.       | arm_acle.h                        |
| clrex                          | Inserts a CLREX instruction.                                                                 | No                                                                | -                                 |
| clz                            | Inserts a CLZ instruction or equivalent routine.                                             | Yes                                                               | arm_acle.h                        |
| current_pc                     | Returns the program counter at this point.                                                   | Yes                                                               | arm_compat.h                      |
| current_sp                     | Returns the stack pointer at this point.                                                     | Yes                                                               | arm_compat.h                      |
| isb                            | Inserts ISB or equivalent.                                                                   | Yes                                                               | arm_acle.h                        |
| disable_fiq                    | Disables FIQ interrupts (Armv7<br>architecture only). Returns<br>previous value of FIQ mask. | Yes                                                               | arm_compat.h                      |
| disable_irq                    | Disable IRQ interrupts. Returns previous value of IRQ mask.                                  | Yes                                                               | arm_compat.h                      |
| dmb                            | Inserts a DMB instruction or equivalent.                                                     | Yes                                                               | arm_acle.h                        |
| dsb                            | Inserts a DSB instruction or equivalent.                                                     | Yes                                                               | arm_acle.h                        |
| enable_fiq                     | Enables fast interrupts.                                                                     | Yes                                                               | arm_compat.h                      |
| enable_irq                     | Enables IRQ interrupts.                                                                      | Yes                                                               | arm_compat.h                      |
| fabs                           | Inserts a VABS or equivalent code sequence.                                                  | No. Arm recommends using the standard C library function fabs().  | -                                 |
| fabsf                          | Single precision version offabs.                                                             | No. Arm recommends using the standard C library function fabsf(). | -                                 |

## Table 4-6 Compiler intrinsic support in Arm Compiler 6

| Table 4-6 Con | npiler intrinsic sup | oort in Arm Com | piler 6 (continued) |  |
|---------------|----------------------|-----------------|---------------------|--|
|               |                      |                 |                     |  |

| Intrinsic in Arm<br>Compiler 5 | Function                                                                                                                                                                                               | Support in Arm Compiler 6                                                                                                                                                                                           | Header file for<br>Arm Compiler 6 |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| force_stores                   | Flushes all external variables<br>visible from this function, if they<br>have been changed.                                                                                                            | Yes                                                                                                                                                                                                                 | arm_compat.h                      |
| ldrex                          | Inserts an appropriately sized<br>Load Exclusive instruction.                                                                                                                                          | No. This intrinsic is deprecated in ACLE 2.0.                                                                                                                                                                       | -                                 |
| ldrexd                         | Inserts an LDREXD instruction.                                                                                                                                                                         | No. This intrinsic is deprecated in ACLE 2.0.                                                                                                                                                                       | -                                 |
| ldrt                           | Inserts an appropriately sized user-mode load instruction.                                                                                                                                             | No                                                                                                                                                                                                                  | -                                 |
| memory_changed                 | Is similar toforce_stores,<br>but also reloads the values from<br>memory.                                                                                                                              | Yes                                                                                                                                                                                                                 | arm_compat.h                      |
| nop                            | Inserts a NOP or equivalent<br>instruction that will not be<br>optimized away. It also inserts a<br>sequence point, and scheduling<br>barrier for side-effecting<br>function calls.                    | Yes                                                                                                                                                                                                                 | arm_acle.h                        |
| pld                            | Inserts a PLD instruction, if supported.                                                                                                                                                               | Yes                                                                                                                                                                                                                 | arm_acle.h                        |
| pldw                           | Inserts a PLDW instruction, if<br>supported (Armv7 architecture<br>with MP).                                                                                                                           | No. Arm recommends usingpldx described in the ACLE document.                                                                                                                                                        | arm_acle.h                        |
| pli                            | Inserts a PLI instruction, if supported.                                                                                                                                                               | Yes                                                                                                                                                                                                                 | arm_acle.h                        |
| promise                        | Compiler assertion that the<br>expression always has a nonzero<br>value. If asserts are enabled then<br>the promise is checked at<br>runtime by evaluating <i>expr</i><br>using assert( <i>expr</i> ). | Yes. However, you must <b>#include</b><br><assert.h> to usepromisepromise<br/>has the same behavior as assert() unless at<br/>least one of NDEBUG or<br/>DO_NOT_LINK_PROMISE_WITH_ASSERT is<br/>defined.</assert.h> | assert.h                          |
| qadd                           | Inserts a saturating add instruction, if supported.                                                                                                                                                    | Yes arm_acle.h                                                                                                                                                                                                      |                                   |
| qdbl                           | Inserts instructions equivalent to qadd(val,val), if supported.                                                                                                                                        |                                                                                                                                                                                                                     |                                   |
| qsub                           | Inserts a saturating subtract, or equivalent routine, if supported.                                                                                                                                    | Yes                                                                                                                                                                                                                 | arm_acle.h                        |
| rbit                           | Inserts a bit reverse instruction.                                                                                                                                                                     | Yes                                                                                                                                                                                                                 | arm_acle.h                        |
| rev                            | Insert a REV, or endian swap instruction.                                                                                                                                                              | Yes arm_acle.t                                                                                                                                                                                                      |                                   |
| return_address                 | Returns value of LR when<br>returning from current function,<br>without inhibiting optimizations<br>like inlining or tailcalling.                                                                      | No. Arm recommends using inline assembly instructions.                                                                                                                                                              | -                                 |

## Table 4-6 Compiler intrinsic support in Arm Compiler 6 (continued)

| Intrinsic in Arm<br>Compiler 5 | Function                                                                                                                                                         | Support in Arm Compiler 6                           | Header file for<br>Arm Compiler 6 |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------------------------|
| ror                            | Insert an ROR instruction.                                                                                                                                       | Yes                                                 | arm_acle.h                        |
| schedule_barrier               | Create a sequence point without<br>effecting memory or inserting<br>NOP instructions. Functions with<br>side effects cannot move past the<br>new sequence point. | Yes                                                 | arm_compat.h                      |
| semihost                       | Inserts an SVC or BKPT instruction.                                                                                                                              | Yes                                                 | arm_compat.h                      |
| sev                            | Insert a SEV instruction. Error if<br>the SEV instruction is not<br>supported.                                                                                   | Yes                                                 | arm_acle.h                        |
| sqrt                           | Inserts a VSQRT instruction on targets with a VFP coprocessor.                                                                                                   | No                                                  | -                                 |
| sqrtf                          | single precision version ofsqrt.                                                                                                                                 | No                                                  | -                                 |
| ssat                           | Inserts an SSAT instruction.<br>Error if the SSAT instruction is<br>not supported.                                                                               | Yes arm_acl                                         |                                   |
| strex                          | Inserts an appropriately sized<br>Store Exclusive instruction.                                                                                                   | No. This intrinsic is deprecated in ACLE 2.0        |                                   |
| strexd                         | Inserts a doubleword Store<br>Exclusive instruction.                                                                                                             | No. This intrinsic is deprecated in ACLE 2.0.       |                                   |
| strt                           | Insert an appropriately sized STRT instruction.                                                                                                                  | No                                                  | -                                 |
| swp                            | Inserts an appropriately sized SWP instruction.                                                                                                                  | Yes. However, Arm does not recommend the use ofswp. |                                   |
| usat                           | Inserts a USAT instruction. Error if the USAT instruction is not supported.                                                                                      | ror Yes arm_acle.                                   |                                   |
| wfe                            | Inserts a WFE instruction. Error if<br>the WFE instruction is not<br>supported.                                                                                  | Yes                                                 | arm_acle.h                        |
| wfi                            | Inserts a WFI instruction. Error if<br>the WFI instruction is not<br>supported.                                                                                  | Yes                                                 | arm_acle.h                        |
| yield                          | Inserts a YIELD instruction.<br>Error if the YIELD instruction is<br>not supported.                                                                              | Yes                                                 | arm_acle.h                        |
| ARMv6 SIMD<br>intrinsics       | Inserts an Armv6 SIMD instruction.                                                                                                                               | No                                                  | -                                 |

## Table 4-6 Compiler intrinsic support in Arm Compiler 6 (continued)

| Intrinsic in Arm<br>Compiler 5 | Function                                                                                                                                                           | Support in Arm Compiler 6                                                         | Header file for<br>Arm Compiler 6 |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------|
| ETSI intrinsics                | 35 intrinsic functions and 2<br>global variable flags specified in<br>ETSI G729 used for speech<br>encoding. These are provided in<br>the Arm headers in dspfns.h. | No                                                                                | -                                 |
| C55x intrinsics                | Emulation of selected TI C55x compiler intrinsics.                                                                                                                 | No                                                                                | -                                 |
| vfp_status                     | Reads the FPSCR.                                                                                                                                                   | Yes                                                                               | arm_compat.h                      |
| FMA intrinsics                 | Intrinsics for fused-multiply-add<br>on the Cortex-M4 or Cortex-A5<br>processor in c99 mode.                                                                       | No                                                                                | -                                 |
| Named register<br>variables    | Allows direct manipulation of a system register as if it were a C variable.                                                                                        | No. To access FPSCR, use thevfp_status intrinsic or inline assembly instructions. | -                                 |

## 4.5 Diagnostics for pragma compatibility

Older armcc compiler versions supported many pragmas which are not supported by armclang, but which could change the semantics of code. When armclang encounters these pragmas, it generates diagnostic messages.

The following table shows which diagnostics are generated for each pragma type, and the diagnostic group to which that diagnostic belongs. armclang generates diagnostics as follows:

- Errors indicate use of an armcc pragma which could change the semantics of code.
- Warnings indicate use of any other armcc pragma which is ignored by armclang.
- Pragmas other than those listed are silently ignored.

## Table 4-7 Pragma diagnostics

| Pragma supported by older compiler versions        | Default diagnostic type | Diagnostic group               |
|----------------------------------------------------|-------------------------|--------------------------------|
| #pragma anon_unions                                | Warning                 | armcc-pragma-anon-unions       |
| #pragma no_anon_unions                             | Warning                 | armcc-pragma-anon-unions       |
| #pragma arm                                        | Error                   | armcc-pragma-arm               |
| <pre>#pragma arm section [section_type_list]</pre> | Error                   | armcc-pragma-arm               |
| <pre>#pragma diag_default tag[,tag,]</pre>         | Error                   | armcc-pragma-diag              |
| <pre>#pragma diag_error tag[,tag,]</pre>           | Error                   | armcc-pragma-diag              |
| <pre>#pragma diag_remark tag[,tag,]</pre>          | Warning                 | armcc-pragma-diag              |
| <pre>#pragma diag_suppress tag[,tag,]</pre>        | Warning                 | armcc-pragma-diag              |
| <pre>#pragma diag_warning tag[,tag,]</pre>         | Warning                 | armcc-pragma-diag              |
| <pre>#pragma exceptions_unwind</pre>               | Error                   | armcc-pragma-exceptions-unwind |
| <pre>#pragma no_exceptions_unwind</pre>            | Error                   | armcc-pragma-exceptions-unwind |
| <pre>#pragma GCC system_header</pre>               | None                    | -                              |
| #pragma hdrstop                                    | Warning                 | armcc-pragma-hdrstop           |
| <pre>#pragma import symbol_name</pre>              | Error                   | armcc-pragma-import            |
| #pragma inline                                     | Warning                 | armcc-pragma-inline            |
| <pre>#pragma no_inline</pre>                       | Warning                 | armcc-pragma-inline            |
| #pragma no_pch                                     | Warning                 | armcc-pragma-no-pch            |
| #pragma O <i>num</i>                               | Warning                 | armcc-pragma-optimization      |
| #pragma once                                       | None                    | -                              |
| #pragma Ospace                                     | Warning                 | armcc-pragma-optimization      |
| #pragma Otime                                      | Warning                 | armcc-pragma-optimization      |
| #pragma pack                                       | None                    | -                              |
| #pragma pop                                        | Error                   | armcc-pragma-push-pop          |
| #pragma push                                       | Error                   | armcc-pragma-push-pop          |
| <pre>#pragma softfp_linkage</pre>                  | Error                   | armcc-pragma-softfp-linkage    |
| <pre>#pragma no_softfp_linkage</pre>               | Error                   | armcc-pragma-softfp-linkage    |
| #pragma thumb                                      | Error                   | armcc-pragma-thumb             |

### Table 4-7 Pragma diagnostics (continued)

| Pragma supported by older compiler versions | Default diagnostic type | Diagnostic group |
|---------------------------------------------|-------------------------|------------------|
| #pragma weak symbol                         | None                    | -                |
| <pre>#pragma weak symbol1 = symbol2</pre>   | None                    | -                |

In addition to the above diagnostic groups, there are the following additional diagnostic groups:

#### armcc-pragmas

Contains all of the above diagnostic groups.

#### unknown-pragmas

Contains diagnostics about pragmas which are not known to armclang, and are not in the above table.

#### pragmas

Contains all pragma-related diagnostics, including armcc-pragmas and unknown-pragmas.

Any non-fatal armclang diagnostic group can be ignored, upgraded, or downgraded using the following command-line options:

### Suppress a group of diagnostics:

-Wno-diag-group

## Upgrade a group of diagnostics to warnings:

-Wdiag-group

## Upgrade a group of diagnostics to errors: -Werror=diag-group

Downgrade a group of diagnostics to warnings: -Wno-error=diag-group

## **Related reference**

4.3 Language extension compatibility: pragmas on page 4-53

## 4.6 C and C++ implementation compatibility

Arm Compiler 6 C and C++ implementation details differ from previous compiler versions.

The following table describes the C and C++ implementation detail differences.

## Table 4-8 C and C++ implementation detail differences

| Feature                                | Older versions of Arm Compiler                                                                                                                                                              | Arm Compiler 6                                                                                                                                                                                          |
|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Integer operations                     |                                                                                                                                                                                             |                                                                                                                                                                                                         |
| Shifts                                 | <b>int</b> <i>shifts</i> > 0 && < 127                                                                                                                                                       | Warns when shift amount > width of type.                                                                                                                                                                |
|                                        | <pre>int left_shifts &gt; 31 == 0</pre>                                                                                                                                                     | You can use the -Wshift-count-overflow option to                                                                                                                                                        |
|                                        | <pre>int right_shifts &gt; 31 == 0</pre>                                                                                                                                                    | suppress this warning.                                                                                                                                                                                  |
|                                        | (for unsigned or positive)                                                                                                                                                                  |                                                                                                                                                                                                         |
|                                        | <pre>int right_shifts &gt; 31 == -1</pre>                                                                                                                                                   |                                                                                                                                                                                                         |
|                                        | (for negative)                                                                                                                                                                              |                                                                                                                                                                                                         |
|                                        | <pre>long long shifts &gt; 0 &amp;&amp; &lt; 63</pre>                                                                                                                                       |                                                                                                                                                                                                         |
| Integer division                       | Checks that the sign of the remainder matches the sign of the numerator                                                                                                                     | The sign of the remainder is not necessarily the same as the sign of the numerator.                                                                                                                     |
| Floating-point operations              |                                                                                                                                                                                             |                                                                                                                                                                                                         |
| Default standard                       | IEEE 754 standard, rounding to nearest<br>representable value, exceptions disabled by<br>default.                                                                                           | All facilities, operations, and representations guaranteed<br>by the IEEE standard are available in single and double-<br>precision. Modes of operation can be selected dynamically<br>at runtime.      |
|                                        |                                                                                                                                                                                             | This is equivalent to thefpmode=ieee_full option in older versions of Arm Compiler.                                                                                                                     |
| #pragma STDC<br>FP_CONTRACT            | <pre>#pragma STDC FP_CONTRACT</pre>                                                                                                                                                         | Might affect code generation.                                                                                                                                                                           |
| Unions, enums and structs              |                                                                                                                                                                                             |                                                                                                                                                                                                         |
| Enum packing                           | Enums are implemented in the smallest<br>integral type of the correct sign to hold the<br>range of the enum values, except for when<br>compiling in C++ mode with<br>enum_is_int.           | By default enums are implemented as <b>int</b> , with <b>long long</b> used when required.                                                                                                              |
| Allocation of bit-fields in containers | Allocation of bit-fields in containers.                                                                                                                                                     | A container is an object, aligned as the declared type. Its<br>size is sufficient to contain the bit-field, but might be<br>smaller or larger than the bit-field declared type.                         |
| Signedness of plain bit-               | Unsigned.                                                                                                                                                                                   | Signed.                                                                                                                                                                                                 |
| fields                                 | Plain bit-fields declared without either the <b>signed</b> or <b>unsigned</b> qualifiers default to <b>unsigned</b> . Thesigned_bitfields option treats plain bit-fields as <b>signed</b> . | Plain bit-fields declared without either the <b>signed</b> or <b>unsigned</b> qualifiers default to <b>signed</b> . There is no equivalent to either thesigned_bitfields orno_signed_bitfields options. |
| Arrays and pointers                    |                                                                                                                                                                                             |                                                                                                                                                                                                         |

## Table 4-8 C and C++ implementation detail differences (continued)

| Feature                                   | Older versions of Arm Compiler                                                                                                                                          | Arm Compiler 6                                                                                                                                                                                                                                                                      |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Casting between integers and pointers     | No change of representation                                                                                                                                             | Converting a signed integer to a pointer type with greater<br>bit width sign-extends the integer.                                                                                                                                                                                   |
|                                           |                                                                                                                                                                         | Converting an unsigned integer to a pointer type with greater bit width zero-extends the integer.                                                                                                                                                                                   |
| Misc C                                    |                                                                                                                                                                         | -                                                                                                                                                                                                                                                                                   |
| <pre>sizeof(wchar_t)</pre>                | 2 bytes                                                                                                                                                                 | 4 bytes                                                                                                                                                                                                                                                                             |
| size_t                                    | Defined as <b>unsigned int</b> , 32-bit.                                                                                                                                | Defined as <b>unsigned int</b> in 32-bit architectures, and <i><sign><type></type></sign></i> 64-bit in 64-bit architectures.                                                                                                                                                       |
| ptrdiff_t                                 | Defined as <b>signed int</b> , 32-bit.                                                                                                                                  | Defined as <b>unsigned int</b> in 32-bit architectures, and <i><sign><type></type></sign></i> 64-bit in 64-bit architectures.                                                                                                                                                       |
| Misc C++                                  |                                                                                                                                                                         |                                                                                                                                                                                                                                                                                     |
| C++ library                               | Rogue Wave Standard C++ Library                                                                                                                                         | LLVM libc++ Library Note                                                                                                                                                                                                                                                            |
|                                           |                                                                                                                                                                         | When the C++ library is used in source code, there is limited compatibility between object code created with Arm Compiler 6 and object code created with Arm Compiler 5. This also applies to indirect use of the C++ library, for example memory allocation or exception handling. |
| Implicit inclusion                        | If compilation requires a template definition<br>from a template declared in a header file<br>xyz.h, the compiler implicitly includes the<br>file xyz.cc or xyz.CC.     | Not supported.                                                                                                                                                                                                                                                                      |
| Alternative template<br>lookup algorithms | When performing referencing context<br>lookups, name lookup matches against<br>names from the instantiation context as well<br>as from the template definition context. | Not supported.                                                                                                                                                                                                                                                                      |
| Exceptions                                | Off by default, function unwinding on withexceptions by default.                                                                                                        | On by default in C++ mode.                                                                                                                                                                                                                                                          |
| Translation                               | 1                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                   |
| Diagnostics messages format               | <pre>source-file, line-number : severity : error-code : explanation</pre>                                                                                               | <pre>source-file:line-number:char-number: description [diagnostic-flag]</pre>                                                                                                                                                                                                       |
| Environment                               | 1                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                   |
| Physical source file bytes interpretation | Current system locale dependent or set using thelocale command-line option.                                                                                             | UTF-8                                                                                                                                                                                                                                                                               |

## **Related reference**

- 4.1 Language extension compatibility: keywords on page 4-48
- 4.2 Language extension compatibility: attributes on page 4-51
- 4.3 Language extension compatibility: pragmas on page 4-53
- 4.7 Compatibility of C++ objects on page 4-64

## 4.7 Compatibility of C++ objects

The compatibility of C++ objects compiled with Arm Compiler 5 depends on the C++ libraries used.

## Compatibility with objects compiled using Rogue Wave standard library headers

Arm Compiler 6 does not support binary compatibility with objects compiled using the Rogue Wave standard library include files.

There are warnings at link time when objects are mixed. L6869W is reported if an object requests the Rogue Wave standard library. L6870W is reported when using an object that is compiled with Arm Compiler 5 with exceptions support.

The impact of mixing objects that have been compiled against different C++ standard library headers might include:

- Undefined symbol errors.
- Increased code size.
- Possible runtime errors.

If you have Arm Compiler 6 objects that have been compiled with the legacy -stdlib=legacy\_cpplib option then these objects use the Rogue Wave standard library and therefore might be incompatible with objects created using Arm Compiler 6.4 or later. To resolve these issues, you must recompile all object files with Arm Compiler 6.4 or later.

## Compatibility with C++ objects compiled using Arm® Compiler 5

The choice of C++ libraries at link time must match the choice of C++ include files at compile time for all input objects. Arm Compiler 5 objects that use the Rogue Wave C++ libraries are not compatible with Arm Compiler 6 objects. Arm Compiler 5 objects that use C++ but do not make use of the Rogue Wave header files can be compatible with Arm Compiler 6 objects that use libc++ but this is not guaranteed.

Arm recommends using Arm Compiler 6 for building the object files.

## Compatibility of arrays of objects compiled using Arm® Compiler 5

Arm Compiler 6 is not compatible with objects from Arm Compiler 5 that use operator new[] and delete[]. Undefined symbol errors result at link time because Arm Compiler 6 does not provide the helper functions that Arm Compiler 5 depends on. For example:

```
construct.cpp:
class Foo
{
    public:
        Foo() : x_(new int) { *x_ = 0; }
        void setX(int x) { *x_ = x; }
        ~Foo() { delete x_; }
    private:
        int* x_;
};
void func(void)
{
    Foo* array;
        array = new Foo [10];
        array[0].setX(1);
        delete[] array;
}
```

If you build this example with the Arm Compiler 5 compiler, armcc, and link with the Arm Compiler 6 linker, armlink, using:

```
armcc -c construct.cpp -Ospace -O1 --cpu=cortex-a9
armlink construct.o -o construct.axf
```

the linker reports:

Error: L6218E: Undefined symbol \_\_aeabi\_vec\_delete (referred from construct.o). Error: L6218E: Undefined symbol \_\_aeabi\_vec\_new\_cookie\_nodtor (referred from construct.o).

To resolve these linker errors, you must use the Arm Compiler 6 compiler, armclang, to compile all C++ files that use the new[] and delete[] operators.

\_\_\_\_\_ Note \_\_\_\_\_

You do not have to specify --stdlib=libc++ for armlink, because this is the default and only option in Arm Compiler 6.4, and later.

**Related information** armlink User Guide: --stdlib

## Chapter 5 Migrating from armasm to the armclang integrated assembler

Describes how to migrate assembly code from armasm syntax to GNU syntax (used by armclang).

It contains the following sections:

- 5.1 Migration of assembler command-line options from armasm to the armclang integrated assembler on page 5-67.
- 5.2 Overview of differences between armasm and GNU syntax assembly code on page 5-72.
- 5.3 Comments on page 5-74.
- 5.4 Labels on page 5-75.
- 5.5 Numeric local labels on page 5-76.
- 5.6 Functions on page 5-78.
- 5.7 Sections on page 5-79.
- 5.8 Symbol naming rules on page 5-81.
- 5.9 Numeric literals on page 5-82.
- 5.10 Operators on page 5-83.
- 5.11 Alignment on page 5-84.
- 5.12 PC-relative addressing on page 5-85.
- 5.13 A32 and T32 instruction substitutions on page 5-86.
- 5.14 A32 and T32 pseudo-instructions on page 5-88.
- 5.15 Conditional directives on page 5-89.
- 5.16 Data definition directives on page 5-90.
- 5.17 Instruction set directives on page 5-92.
- 5.18 Miscellaneous directives on page 5-93.
- 5.19 Symbol definition directives on page 5-95.
- 5.20 Migration of armasm macros to integrated assembler macros on page 5-96.

# 5.1 Migration of assembler command-line options from armasm to the armclang integrated assembler

Arm Compiler 6 provides many command-line options, including most Clang command-line options as well as several Arm-specific options.

\_\_\_\_\_ Note \_\_\_\_\_

This topic includes descriptions of [COMMUNITY] features. See Support level definitions on page 1-13.

— Note –

The following GNU assembly directives are [COMMUNITY] features:

- .eabi\_attribute Tag\_ABI\_PCS\_RO\_data, value
- .eabi\_attribute Tag\_ABI\_PCS\_R9\_use, value
- .eabi\_attribute Tag\_ABI\_PCS\_RW\_data, value
- .eabi\_attribute Tag\_ABI\_VFP\_args, value
- .eabi\_attribute Tag\_CPU\_unaligned\_access, value
- .ident
- .protected

.section .note.GNU-stack, "x"

- -Wa,--noexecstack
- -Wa,-L
  - -Wa,-defsym,*symbol=value*

The following table describes the most common armasm command-line options, and shows the equivalent options for the armclang integrated assembler.

Additional information about command-line options is available:

- The armclang Reference Guide provides more detail about a number of command-line options.
- For a full list of Clang command-line options, consult the Clang and LLVM documentation.

| armasm option               | armclang integrated assembler option | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| arm_only                    | No equivalent.                       | Enforces A32 instructions only.                                                                                                                                                                                                                                                                                                                                                                                       |
| apcs=/nointerwork           | No equivalent.                       | Specifies that the code in the input file can interwork between A32 and T32 safely. Interworking is always enabled in Arm Compiler 6.                                                                                                                                                                                                                                                                                 |
| apcs=/ropi,<br>apcs=/noropi | No direct equivalent.                | <pre>With armasm, the options specify whether the code in the input<br/>file is Read-Only Position-Independent (ROPI) code.<br/>With the armclang integrated assembler, use the GNU<br/>assembly .eabi_attribute directive instead.<br/>To specify that the code is ROPI code, use the directive as<br/>follows:<br/>.eabi_attribute Tag_ABI_PCS_R0_data, 1<br/>The code is marked as not ROPI code by default.</pre> |

## Table 5-1 Comparison of command-line options in armasm and the armclang integrated assembler

| armasm option                          | armclang integrated assembler option | Description                                                                                                                                                                                          |
|----------------------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| apcs=/rwpi,<br>apcs=/norwpi            | No direct equivalent.                | With armasm, the options specify whether the code in the input file is <i>Read-Write Position-Independent</i> (RWPI) code.                                                                           |
| apcs=/norwp1                           |                                      | With the armclang integrated assembler, use the GNU assembly .eabi_attribute directive instead.                                                                                                      |
|                                        |                                      | To specify that the code is RWPI code, use the directive as follows:                                                                                                                                 |
|                                        |                                      | <pre>.eabi_attribute Tag_ABI_PCS_R9_use, 1 .eabi_attribute Tag_ABI_PCS_RW_data, 2</pre>                                                                                                              |
|                                        |                                      | The code is marked as not RWPI code by default.                                                                                                                                                      |
| apcs=/hardfp,<br>apcs=/softfp          | No direct equivalent.                | With armasm, the options set attributes in the object file to request hardware or software floating-point linkage.                                                                                   |
|                                        |                                      | With the armclang integrated assembler, use the GNU assembly .eabi_attribute directive instead.                                                                                                      |
|                                        |                                      | To request hardware floating-point linkage, use the directive as follows:                                                                                                                            |
|                                        |                                      | .eabi_attribute Tag_ABI_VFP_args, 1                                                                                                                                                                  |
|                                        |                                      | To request software floating-point linkage, use the directive as follows:                                                                                                                            |
|                                        |                                      | <pre>.eabi_attribute Tag_ABI_VFP_args, 0</pre>                                                                                                                                                       |
| checkreglist,<br>diag_warning=1206     | This is the default.                 | Generates warnings if register lists in LDM and STM instructions are not provided in increasing register number order.                                                                               |
| 0_ 0                                   |                                      | This warning cannot be suppressed or upgraded to an error.                                                                                                                                           |
| comment_section,<br>no_comment_section | No direct equivalent.                | With armasm, the option controls the inclusion of a comment section .comment in object files.                                                                                                        |
| no_comment_section                     |                                      | With the armclang integrated assembler, use the GNU assembly .ident directive to manually add a comment section.                                                                                     |
| debug,                                 | - g                                  | Instructs the assembler to generate DWARF debug tables.                                                                                                                                              |
| -g                                     |                                      | With armasm, the default format for debug tables is DWARF 3.<br>Named local labels are not preserved in the object file, unless<br>thekeep option is used.                                           |
|                                        |                                      | With the armclang integrated assembler, the default format for debug tables is DWARF 4. Named local labels are always preserved in the object file. See the entry forkeep in this table for details. |

| armasm option              | armclang integrated assembler option                      | Description                                                                                                                                                                                                                                                                                                                                             |
|----------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| diag_warning=1645          | No equivalent.                                            | With armasm, the option enables warnings about instruction substitutions.                                                                                                                                                                                                                                                                               |
|                            |                                                           | With the armclang integrated assembler, instruction<br>substitution support is limited. Where it is not supported, the<br>assembler generates an error message.                                                                                                                                                                                         |
|                            |                                                           | Use the <b>armasm</b> warning when migrating code to find instructions being substituted and perform the substitution manually.                                                                                                                                                                                                                         |
| diag_warning=1763          | No equivalent.                                            | With armasm, the option enables warnings about automatic generation of IT blocks when assembling T32 code (formerly Thumb code).                                                                                                                                                                                                                        |
|                            |                                                           | With the armclang integrated assembler, automatic generation<br>of IT blocks is disabled by default. The assembler generates an<br>error message when assembling conditional instructions without<br>an enclosing IT block. To enable automatic generation of IT<br>blocks, use the command-line option<br>-mimplicit-it=always or -mimplicit-it=thumb. |
| dllexport_all              | No direct equivalent.                                     | With armasm, the option gives all exported global symbols<br>STV_PROTECTED visibility in ELF rather than STV_HIDDEN,<br>unless overridden by source directives.                                                                                                                                                                                         |
|                            |                                                           | With the armclang integrated assembler, use the GNU assembly .protected directive to manually give exported symbols STV_PROTECTED visibility.                                                                                                                                                                                                           |
| execstack,<br>no_execstack | -Wa,noexecstack<br>No direct equivalent for<br>execstack. | With armasm, the option generates a .note.GNU-stack section marking the stack as either executable or non-executable.                                                                                                                                                                                                                                   |
|                            |                                                           | With the armclang integrated assembler, the equivalent option<br>can be used to generate a .note.GNU-stack section marking<br>the stack as non-executable.                                                                                                                                                                                              |
|                            |                                                           | To generate such a section and mark the stack as executable, use the GNU assembly <b>.section</b> directive as follows:                                                                                                                                                                                                                                 |
|                            |                                                           | .section .note.GNU-stack, "x"                                                                                                                                                                                                                                                                                                                           |
|                            |                                                           | The command-line option -Wa,noexecstack overrides the use of the .section directive.                                                                                                                                                                                                                                                                    |

| armasm option                            | armclang integrated assembler option | Description                                                                                                                                                                                                                                    |
|------------------------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| keep                                     | No direct equivalent.                | With armasm, the option instructs the assembler to keep named local labels in the symbol table of the object file, for use by the debugger.                                                                                                    |
|                                          |                                      | With the armclang integrated assembler, named local labels defined without using the GNU assembly local symbol name prefix .L are always preserved in the object file.                                                                         |
|                                          |                                      | Use the command-line option -Wa, -L to automatically preserve<br>all named local labels defined using the GNU assembly local<br>symbol name prefix.                                                                                            |
| -M                                       | -M                                   | Instructs the assembler to produce a list of makefile dependency<br>lines suitable for use by a make utility. It only includes<br>dependencies visible to the preprocessor.                                                                    |
|                                          |                                      | The option does not include files added using the INCBIN,<br>INCLUDE, or GET directives with armasm, or the GNU<br>assembly .incbin or .include directives with the armclang<br>integrated assembler.                                          |
|                                          |                                      | With the armclang integrated assembler, using this option with<br>-o outputs the makefile dependency lines to the file specified.<br>An object file is not produced.                                                                           |
| mm                                       | -MM                                  | Creates a single makefile dependency file, without the system<br>header files. It only includes dependencies visible to the<br>preprocessor.                                                                                                   |
|                                          |                                      | The option does not include files added using the INCBIN,<br>INCLUDE, or GET directives with armasm, or the GNU<br>assembly .incbin or .include directives with the armclang<br>integrated assembler.                                          |
|                                          |                                      | Note         With the armclang integrated assembler, using this option with         -o outputs the makefile dependency file to the file specified. An object file is not produced.                                                             |
| no_hide_all                              | -fvisibility=default                 | Gives all exported and imported global symbols STV_DEFAULT visibility in ELF rather than STV_HIDDEN, unless overridden using source directives.                                                                                                |
| predefine "directive",<br>pd "directive" | -Wa,-defsym, <i>symbol=value</i>     | With armasm, the option instructs the assembler to pre-execute<br>one of the SETA, SETL, or SETS directives as specified using<br><i>directive</i> .                                                                                           |
|                                          |                                      | With the armclang integrated assembler, the option instructs the assembler to pre-define the symbol <i>symbol</i> with the value <i>value</i> . This GNU assembly .set directive can be used to change this value in the file being assembled. |

| armasm option                            | armclang integrated assembler option | Description                                                                                                                                |
|------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| unaligned_access,<br>no_unaligned_access | No direct equivalent.                | With armasm, the options instruct the assembler to set an attribute in the object file to enable or disable the use of unaligned accesses. |
|                                          |                                      | With the armclang integrated assembler, use the GNU assembly .eabi_attribute directive instead.                                            |
|                                          |                                      | To enable the use of unaligned access, use the directive as follows:                                                                       |
|                                          |                                      | .eabi_attribute Tag_CPU_unaligned_access, 1                                                                                                |
|                                          |                                      | To disable the use of unaligned access, use the directive as follows:                                                                      |
|                                          |                                      | .eabi_attribute Tag_CPU_unaligned_access, 0                                                                                                |
| unsafe                                   | No direct equivalent.                | With armasm, the option enables instructions for architectures other than the target architecture to be assembled without error.           |
|                                          |                                      | With the armclang integrated assembler, use the GNU assembly .inst directive to generate such instructions.                                |

## **Related information**

GNU Binutils - Using as: .section GNU Binutils - Using as: .ident GNU Binutils - Using as: .protected GNU Binutils - Using as: .protected GNU Binutils - Using as: .include GNU Binutils - Using as: .incbin GNU Binutils - Using as: .set GNU Binutils - Using as: .set armasm User Guide: GET or INCLUDE armasm User Guide: INCBIN armclang Reference Guide: -mimplicit-it

## 5.2 Overview of differences between armasm and GNU syntax assembly code

armasm (for assembling legacy assembly code) uses armasm syntax assembly code.

armclang aims to be compatible with GNU syntax assembly code (that is, the assembly code syntax supported by the GNU assembler, as).

If you have legacy assembly code that you want to assemble with armclang, you must convert that assembly code from armasm syntax to GNU syntax.

The specific instructions and order of operands in your UAL syntax assembly code do not change during this migration process.

However, you need to make changes to the syntax of your assembly code. These changes include:

- The directives in your code.
- The format of labels, comments, and some types of literals.
- Some symbol names.
- The operators in your code.

The following examples show simple, equivalent, assembly code in both armasm and GNU syntax.

#### armasm syntax

```
; Simple armasm syntax example
; Iterate round a loop 10 times, adding 1 to a register each time.
         AREA ||.text||, CODE, READONLY, ALIGN=2
main PROC
                                  ; W5 = 100
        MOV
                   w5,#0x64
         MOV
                   w4,#0
                                    W4 = 0
                                  ; W4 = 0
; branch to test_loop
                  test_loop
         В
100p
                                  ; Add 1 to W5
; Add 1 to W4
         ADD
                   w5,w5,#1
                  w4,w4,#1
         ADD
test_loop
         СМР
                   w4,#0xa
                                  ; if W4 < 10, branch back to loop
         BI T
                   loop
         ENDP
         END
```

#### **GNU** syntax

```
// Simple GNU syntax example 5.3 Comments on page 5-74//
// Iterate round a loop 10 times, adding 1 to a register each time.
         .section .text,"ax"
                                   // 5.7 Sections on page 5-79
         .balign 4
                                  // 5.4 Labels on page 5-75
// W5 = 100 5.9 Numeric literals on page 5-82
// W4 = 0
main:
         MOV
                   w5,#0x64
         MOV
                   w4,#0
                   test_loop
                                   // branch to test_loop
         В
loop:
         ADD
                   w5,w5,#1
                                   // Add 1 to W5
         ADD
                   w4,w4,#1
                                   // Add 1 to W4
test_loop:
         .
CMP
                   w4,#0xa
                                   // if W4 < 10, branch back to loop</pre>
         BLT
                   loop
                                   // 5.18 Miscellaneous directives on page 5-93
         .end
```

#### **Related reference**

5.3 Comments on page 5-74

5.4 Labels on page 5-75

5.5 Numeric local labels on page 5-76

5.6 Functions on page 5-78

5.7 Sections on page 5-79

5.8 Symbol naming rules on page 5-81

5.9 Numeric literals on page 5-82

5.10 Operators on page 5-83

5.11 Alignment on page 5-84

5.12 PC-relative addressing on page 5-85

5.15 Conditional directives on page 5-89

5.16 Data definition directives on page 5-90

5.17 Instruction set directives on page 5-92

5.18 Miscellaneous directives on page 5-93

5.19 Symbol definition directives on page 5-95

### **Related information**

About the Unified Assembler Language

### 5.3 Comments

A comment identifies text that the assembler ignores.

### armasm syntax

A comment is the final part of a source line. The first semicolon on a line marks the beginning of a comment except where the semicolon appears inside a string literal.

The end of the line is the end of the comment. A comment alone is a valid line.

For example:

```
; This whole line is a comment
; As is this line
myProc: PROC
MOV r1, #16 ; Load R0 with 16
```

### **GNU** syntax

GNU syntax assembly code provides two different methods for marking comments:

• The /\* and \*/ markers identify multiline comments:

```
/* This is a comment
that spans multiple
lines */
```

• The // marker identifies the remainder of a line as a comment:

MOV R0,#16 // Load R0 with 16

**Related information** 

*GNU Binutils - Using as: Comments armasm User Guide: Syntax of source lines in assembly language* 

### 5.4 Labels

Labels are symbolic representations of addresses. You can use labels to mark specific addresses that you want to refer to from other parts of the code.

#### armasm syntax

A label is written as a symbol beginning in the first column. A label can appear either in a line on its own, or in a line with an instruction or directive. Whitespace separates the label from any following instruction or directive:

```
MOV R0,#16
loop SUB R0,R0,#1 ; "loop" is a label
CMP R0,#0
BGT loop
```

### **GNU** syntax

A label is written as a symbol that either begins in the first column, or has nothing but whitespace between the first column and the label. A label can appear either in a line on its own, or in a line with an instruction or directive. A colon ":" follows the label (whitespace is allowed between the label and the colon):

```
MOV R0,#16
loop: // "loop" label on its own line
SUB R0,R0,#1
CMP R0,#0
BGT loop
MOV R0,#16
loop: SUB R0,R0,#1 // "loop" label in a line with an instruction
CMP R0,#0
BGT loop
```

### **Related reference**

5.5 Numeric local labels on page 5-76

**Related information** 

GNU Binutils - Using as: Labels

### 5.5 Numeric local labels

Numeric local labels are a type of label that you refer to by a number rather than by name. Unlike other labels, the same numeric local label can be used multiple times and the same number can be used for more than one numeric local label.

### armasm syntax

A numeric local label is a number in the range 0-99, optionally followed by a scope name corresponding to a ROUT directive.

Numeric local labels follow the same syntax as all other labels.

Refer to numeric local labels using the following syntax:

%[F|B][A|T]n[routname]

Where:

- F and B instruct the assembler to search forwards and backwards respectively. By default, the assembler searches backwards first, then forwards.
- A and T instruct the assembler to search all macro levels or only the current macro level respectively. By default, the assembler searches all macros from the current level to the top level, but does not search lower level macros.
- *n* is the number of the numeric local label in the range 0-99.
- routname is an optional scope label corresponding to a ROUT directive. If routname is specified in either a label or a reference to a label, the assembler checks it against the name of the nearest preceding ROUT directive. If it does not match, the assembler generates an error message and the assembly fails.

For example, the following code implements an incrementing loop:

| 1 | MOV | · · · <b>,</b> · · = | ; r4=1                               |
|---|-----|----------------------|--------------------------------------|
| T |     |                      | ; Local label                        |
|   | ADD | r4,r4,#1             | ; Increment r4                       |
|   | CMP | r4,#0x5              | ; if r4 < 5                          |
|   | BLT | %b1                  | ;branch backwards to local label "1" |

Here is the same example using a ROUT directive to restrict the scope of the local label:

```
routA
                                         Start of "routA" scope
           ROUT
           MOV
                       r4,#1
                                         r4=1
1routA
                                         Local label
           ADD
                       r4,r4,#1
                                         Increment r4
           CMP
                       r4,#0x9
                                         if r4 < 9...
                                         ...branch backwards to local label "1routA"
Start of "routB" scope (and therefore end of "routA" scope)
           BLT
                       %b1routA
routB
           ROUT
```

### **GNU** syntax

A numeric local label is a number in the range 0-99.

Numeric local labels follow the same syntax as all other labels.

Refer to numeric local labels using the following syntax:

*n*{f|b}

Where:

- *n* is the number of the numeric local label in the range 0-99.
- f and b instruct the assembler to search forwards and backwards respectively. There is no default. You must specify one of f or b.

For example, the following code implements an incrementing loop:

|    | MOV | r4,#1    | // r4=1         |
|----|-----|----------|-----------------|
| 1: |     |          | // Local label  |
|    | ADD | r4,r4,#1 | // Increment r4 |
|    |     |          |                 |

CMP r4,#0x5 // if r4 < 5... BLT 1b // ...branch backwards to local label "1"

— Note ——

GNU syntax assembly code does not provide mechanisms for restricting the scope of local labels.

### **Related reference**

5.4 Labels on page 5-75 **Related information** GNU Binutils - Using as: Labels GNU Binutils - Using as: Local labels armasm User Guide: Labels armasm User Guide: Numeric local labels armasm User Guide: Syntax of numeric local labels armasm User Guide: ROUT

### 5.6 Functions

Assemblers can identify the start of a function when producing DWARF call frame information for ELF.

### armasm syntax

The FUNCTION directive marks the start of a function. PROC is a synonym for FUNCTION.

The ENDFUNC directive marks the end of a function. ENDP is a synonym for ENDFUNC.

For example:

```
myproc PROC
; Procedure body
ENDP
```

### **GNU** syntax

Use the .type directive to identify symbols as functions. For example:

.type myproc, "function" myproc: // Procedure body

GNU syntax assembly code provides the .func and .endfunc directives. However, these are not supported by armclang. armclang uses the .size directive to set the symbol size:

```
.type myproc, "function"
myproc:
    // Procedure body
.Lmyproc_end0:
    .size myproc, .Lmyproc_end0-myproc
```

— Note –

Functions must be typed to link properly.

### **Related information**

GNU Binutils - Using as: .type armasm User Guide: FUNCTION or PROC armasm User Guide: ENDFUNC or ENDP

### 5.7 Sections

Sections are independent, named, indivisible chunks of code or data that are manipulated by the linker.

### armasm syntax

The AREA directive instructs the assembler to assemble a new code or data section.

Section attributes within the AREA directive provide information about the section. Available section attributes include the following:

- CODE specifies that the section contains machine instructions.
- READONLY specifies that the section must not be written to.
- ALIGN=*n* specifies that the section is aligned on a  $2^n$  byte boundary

For example:

```
AREA mysection, CODE, READONLY, ALIGN=3
```

\_\_\_\_\_ Note \_\_\_\_\_

The ALIGN attribute does not take the same values as the ALIGN directive. ALIGN=n (the AREA attribute) aligns on a  $2^n$  byte boundary. ALIGN n (the ALIGN directive) aligns on an n-byte boundary.

### **GNU** syntax

The .section directive instructs the assembler to assemble a new code or data section.

Flags provide information about the section. Available section flags include the following:

- a specifies that the section is allocatable.
- x specifies that the section is executable.
- w specifies that the section is writable.
- S specifies that the section contains null-terminated strings.

For example:

.section mysection, "ax"

Not all armasm syntax AREA attributes map onto GNU syntax .section flags. For example, the armasm syntax ALIGN attribute corresponds to the GNU syntax .balign directive, rather than a .section flag:

```
.section mysection,"ax"
.balign 8
```

– Note –

When using Arm Compiler 5, section names do not need to be unique. Therefore, you could use the same section name to create different section types.

Arm Compiler 6 supports multiple sections with the same section name only if you specify a *unique ID*. You must ensure that different section types either:

- Have a unique section name.
- Have a unique ID, if they have the same section name.

If you use the same section name for another section or symbol, without a unique ID, then armclang integrated assembler merges the sections and gives the merged section the flags of the first section with that name.

```
// stores both the code and data in one section
// uses the flags from the first section
.section "sectionX", "ax"
mov r0, r0
.section "sectionX", "a", %progbits
.word 0xdeadbeef
```

```
// stores both the code and data in one section
// uses the flags from the first section
.section "sectionY", "a", %progbits
.word 0xdeadbeef
.section "sectionY", "ax"
mov r0, r0
```

When you assemble the above example code with:

armclang --target=arm-arm-none-eabi -c -march=armv8-m.main example\_sections.s

The armclang integrated assembler:

- merges the two sections named sectionX into one section with the flags "ax".
- merges the two sections named sectionY into one section with the flags "a", %progbits.

#### **Related information**

GNU Binutils - Using as: .section GNU Binutils - Using as: .align armasm User Guide: AREA

# 5.8 Symbol naming rules

armasm syntax assembly code and GNU syntax assembly code use similar, but different naming rules for symbols.

Symbol naming rules which are common to both armasm syntax and GNU syntax include:

- Symbol names must be unique within their scope.
- Symbol names are case-sensitive, and all characters in the symbol name are significant.
- Symbols must not use the same name as built-in variable names or predefined symbol names.

Symbol naming rules which differ between armasm syntax and GNU syntax include:

• armasm syntax symbols must start with a letter or the underscore character "\_".

GNU syntax symbols must start with a letter, the underscore character "\_", or a period ".".

• armasm syntax symbols use double bars to delimit symbol names containing non-alphanumeric characters (except for the underscore):

IMPORT ||Image\$\$ARM\_LIB\_STACKHEAP\$\$ZI\$\$Limit||

GNU syntax symbols do not require double bars:

.global Image\$\$ARM\_LIB\_STACKHEAP\$\$ZI\$\$Limit

#### **Related information**

GNU Binutils - Using as: Symbol Names armasm User Guide: Symbol naming rules

### 5.9 Numeric literals

armasm syntax assembly and GNU syntax assembly provide different methods for specifying some types of numeric literal.

### Implicit shift operations

armasm syntax assembly allows immediate values with an implicit shift operation. For example, the MOVK instruction takes a 16-bit operand with an optional left shift. armasm accepts the instruction MOVK x1, #0x40000, converting the operand automatically to MOVK x1, #0x4, LSL #16.

GNU syntax assembly expects immediate values to be presented as encoded. The instruction MOVK x1, #0x40000 results in the following message: error: immediate must be an integer in range [0, 65535].

### **Hexadecimal literals**

armasm syntax assembly provides two methods for specifying hexadecimal literals, the prefixes "&" and "0x".

For example, the following are equivalent:

| ADD | r1, | #0xAF |
|-----|-----|-------|
| ADD | r1, | #&AF  |

GNU syntax assembly only supports the "0x" prefix for specifying hexadecimal literals. Convert any "&" prefixes to "0x".

### n\_base-n-digits format

armasm syntax assembly lets you specify numeric literals using the following format:

n\_base-n-digits

For example:

- 2\_1101 is the binary literal 1101 (13 in decimal).
- 8\_27 is the octal literal 27 (23 in decimal).

GNU syntax assembly does not support the *n*\_base-*n*-digits format. Convert all instances to a supported numeric literal form.

For example, you could convert:

ADD r1, #2\_1101

to:

ADD r1, #13

or:

ADD r1, #0xD

Related information

GNU Binutils - Using as: Integers armasm User Guide: Syntax of numeric literals

### 5.10 Operators

armasm syntax assembly and GNU syntax assembly provide different methods for specifying some operators.

The following table shows how to translate armasm syntax operators to GNU syntax operators.

#### Table 5-2 Operator translation

| armasm syntax operator | GNU syntax operator |
|------------------------|---------------------|
| :OR:                   |                     |
| :EOR:                  | ^                   |
| :AND:                  | &                   |
| :NOT:                  | ~                   |
| :SHL:                  | <<                  |
| :SHR:                  | >>                  |
| :LOR:                  |                     |
| :LAND:                 | &&                  |
| :ROL:                  | No GNU equivalent   |
| :ROR:                  | No GNU equivalent   |

### **Related information**

GNU Binutils - Using as: Infix Operators armasm User Guide: Unary operators armasm User Guide: Shift operators armasm User Guide: Addition, subtraction, and logical operators

# 5.11 Alignment

Data and code must be aligned to appropriate boundaries.

For example, The T32 pseudo-instruction ADR can only load addresses that are word aligned, but a label within T32 code might not be word aligned. You must use an alignment directive to ensure four-byte alignment of an address within T32 code.

An alignment directive aligns the current location to a specified boundary by padding with zeros or NOP instructions.

### armasm syntax

armasm syntax assembly provides the ALIGN n directive, where n specifies the alignment boundary in bytes. For example, the directive ALIGN 128 aligns addresses to 128-byte boundaries.

armasm syntax assembly also provides the PRESERVE8 directive. The PRESERVE8 directive specifies that the current file preserves eight-byte alignment of the stack.

### **GNU** syntax

GNU syntax assembly provides the .balign n directive, which uses the same format as ALIGN.

Convert all instances of ALIGN *n* to .balign *n*.

\_\_\_\_\_ Note \_\_\_\_\_

GNU syntax assembly also provides the .align n directive. However, the format of n varies from system to system. The .balign directive provides the same alignment functionality as .align with a consistent behavior across all architectures.

Convert all instances of PRESERVE8 to .eabi\_attribute Tag\_ABI\_align\_preserved, 1.

### **Related information**

GNU Binutils - Using as: ARM Machine Directives GNU Binutils - Using as: .align GNU Binutils - Using as: .balign armasm User Guide: REQUIRE8 and PRESERVE8 armasm User Guide: ALIGN

### 5.12 PC-relative addressing

armasm syntax assembly and GNU syntax assembly provide different methods for performing PC-relative addressing.

### armasm syntax

armasm syntax assembly provides the symbol {pc} to let you specify an address relative to the current instruction.

For example:

ADRP x0, {pc}

### **GNU** syntax

GNU syntax assembly does not support the {pc} symbol. Instead, it uses the special dot "." character, as follows:

ADRP x0, .

**Related information** GNU Binutils - Using as: The Special Dot Symbol

armasm User Guide: Register-relative and PC-relative expressions

# 5.13 A32 and T32 instruction substitutions

In certain circumstances, if the value of an Operand2 constant is not available with a given instruction, but its logical inverse or negation is available, then armasm can produce an equivalent instruction with the inverted or negated constant. The armclang integrated assembler provides limited support for such substitutions.

### Substitutions when using armasm

More information about the syntax of Operand2 constants is available in the *armasm User Guide*. The following table shows the instruction substitutions supported by armasm, based on the values of Operand2 constants for the A32 and T32 instruction sets. The equivalent instructions shown can be used manually with the armclang integrated assembler for instructions where automatic substitution is not supported.

| A32 and T32 instruction                     | Equivalent instruction                       | Constant substitution method |
|---------------------------------------------|----------------------------------------------|------------------------------|
| ADC{S}{cond} {Rd}, Rn, #constant            | <pre>SBC{S}{cond} {Rd}, Rn, #~constant</pre> | Logical inversion            |
| ADD{S}{cond} {Rd}, Rn, #constant            | <pre>SUB{S}{cond} {Rd}, Rn, #-constant</pre> | Negation                     |
| AND{S}{cond} Rd, Rn, #constant              | BIC{S}{cond} Rd, Rn, #~constant              | Logical inversion            |
| BIC{S}{cond} Rd, Rn, #constant              | AND{S}{cond} Rd, Rn, #~constant              | Logical inversion            |
| CMP{cond} Rn, #constant                     | CMN{cond} Rn, #-constant                     | Negation                     |
| CMN{cond} Rn, #constant                     | CMP{cond} Rn, #-constant                     | Negation                     |
| MOV{S}{cond} Rd, #constant                  | MVN{S}{cond} Rd, #~constant                  | Logical inversion            |
| MVN{S}{cond} Rd, #constant                  | MOV{S}{cond} Rd, #~constant                  | Logical inversion            |
| ORN{S}{cond} Rd, Rn, #constant              | ORR{S}{cond} Rd, Rn, #~constant              | Logical inversion            |
| (T32 only)                                  | (T32 only)                                   |                              |
| ORR{S}{cond} Rd, Rn, #constant              | ORN{S}{cond} Rd, Rn, #~constant              | Logical inversion            |
| (T32 only)                                  | (T32 only)                                   |                              |
| <pre>SBC{S}{cond} {Rd}, Rn, #constant</pre> | ADC{S}{cond} {Rd}, Rn, #~constant            | Logical inversion            |
| <pre>SUB{S}{cond} {Rd}, Rn, #constant</pre> | ADD{S}{cond} {Rd}, Rn, #-constant            | Negation                     |

#### Table 5-3 A32 and T32 instruction substitutions supported by armasm

To find instruction substitutions in code assembled using armasm, use the command-line option -- diag\_warning=1645.

### Substitutions when using armclang integrated assembler

The armclang integrated assembler is also able to produce valid equivalent instructions through substitution, by inverting or negating the specified immediate value. This applies to both assembly language source files and to inline assembly code in C and C++ language source files.

You can disable this substitution using the -mno-neg-immediates armclang option.

### **Related information**

-mno-neg-immediates armclang option armasm User Guide: Syntax of Operand2 as a constant armasm User Guide: ADC armasm User Guide: ADD

5 Migrating from armasm to the armclang integrated assembler 5.13 A32 and T32 instruction substitutions

armasm User Guide: AND armasm User Guide: BIC armasm User Guide: CMP and CMN armasm User Guide: MOV armasm User Guide: MVN armasm User Guide: ORN armasm User Guide: ORR armasm User Guide: SBC armasm User Guide: SUB

### 5.14 A32 and T32 pseudo-instructions

armasm supports several A32 and T32 pseudo-instructions. The support for the pseudo-instructions varies with the armclang integrated assembler.

More information about the A32 and T32 pseudo-instructions is available in the *armasm User Guide*. The following table shows how to migrate the pseudo-instructions for use with the armclang integrated assembler:

| Table 5-4 | A32 and | Т32 | pseudo-instruction migration | ı |
|-----------|---------|-----|------------------------------|---|
|-----------|---------|-----|------------------------------|---|

| A32 and T32 pseudo-<br>instruction | armclang integrated assembler equivalent                                                                    |  |  |
|------------------------------------|-------------------------------------------------------------------------------------------------------------|--|--|
| ADRL{cond} Rd, Label               | No equivalent.                                                                                              |  |  |
|                                    | Use an ADR instruction if <i>LabeL</i> is within the supported offset range.                                |  |  |
|                                    | Use an LDR pseudo-instruction if <i>LabeL</i> is outside the supported offset range for an ADR instruction. |  |  |
| CPY{cond} Rd, Rm                   | mov{cond} Rd, Rm                                                                                            |  |  |
| LDR{cond}{.W} Rt, =expr            | Identical.                                                                                                  |  |  |
| LDR{cond}{.W} Rt,<br>=LabeL_expr   | Identical.                                                                                                  |  |  |
| MOV32{cond} Rd, expr               | Use the following instruction sequence:<br>movw{cond} Rd, #:lower16:expr<br>movt{cond} Rd, #:upper16:expr   |  |  |
| NEG{cond} Rd, Rm                   | rsbs{cond} Rd, Rm, #0                                                                                       |  |  |
| UND{cond}{.W} {#expr}              | Use the following instruction for the A32 instruction set:                                                  |  |  |
|                                    | udf{c}{q} {#}imm                                                                                            |  |  |
|                                    | Use the following instruction for the T32 instruction set with 8-bit encoding:                              |  |  |
|                                    | udf{C}{q} {#}imm                                                                                            |  |  |
|                                    | Use the following instruction for the T32 instruction set with 16-bit encoding:                             |  |  |
|                                    | udf{c}.w {#}imm                                                                                             |  |  |

### **Related information**

armasm User Guide: ADRL pseudo-instruction armasm User Guide: CPY pseudo-instruction armasm User Guide: LDR pseudo-instruction armasm User Guide: MOV armasm User Guide: MOV7 armasm User Guide: NEG pseudo-instruction armasm User Guide: RSB armasm User Guide: UDF armasm User Guide: UND pseudo-instruction

### 5.15 Conditional directives

Conditional directives specify conditions that control whether or not to assemble a sequence of assembly code.

The following table shows how to translate armasm syntax conditional directives to GNU syntax directives:

### Table 5-5 Conditional directive translation

| armasm syntax directive | GNU syntax directive     |
|-------------------------|--------------------------|
| IF                      | .if family of directives |
| IF :DEF:                | .ifdef                   |
| IF :LNOT::DEF:          | .ifndef                  |
| ELSE                    | .else                    |
| ELSEIF                  | .elseif                  |
| ENDIF                   | .endif                   |

In addition to the change in directives shown, the following syntax differences apply:

• In armasm syntax, the conditional directives can use forward references. This is possible as armasm is a two-pass assembler. In GNU syntax, forward references are not supported, as the armclang integrated assembler only performs one pass over the main text.

If a forward reference is used with the .ifdef directive, the condition will always fail implicitly. Similarly, if a forward reference is used with the .ifndef directive, the condition will always pass implicitly.

• In armasm syntax, the maximum total nesting depth for directive structures such as IF...ELSE...ENDIF is 256. In GNU syntax, this limit is not applicable.

### **Related information**

GNU Binutils - Using as: .if GNU Binutils - Using as: .else GNU Binutils - Using as: .elseif GNU Binutils - Using as: .endif armasm User Guide: IF, ELSE, ENDIF, and ELIF

# 5.16 Data definition directives

Data definition directives allocate memory, define data structures, and set initial contents of memory.

The following table shows how to translate armasm syntax data definition directives to GNU syntax directives:

\_\_\_\_\_ Note \_\_\_\_

This list only contains examples of common data definition assembly directives. It is not exhaustive.

### Table 5-6 Data definition directives translation

| armasm<br>syntax<br>directive | GNU syntax<br>directive | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DCB                           | .byte                   | Allocate one-byte blocks of memory, and specify the initial contents.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| DCW                           | .hword                  | Allocate two-byte blocks of memory, and specify the initial contents.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| DCD                           | .word                   | Allocate four-byte blocks of memory, and specify the initial contents.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DCI                           | .inst                   | Allocate a block of memory in the code, and specify the opcode. In A32 code, this is a four-byte block. In T32 code, this can be a two-byte or four-byte blockinst.n allocates a two-byte block and .inst.w allocates a four-byte block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DCQ                           | .quad                   | Allocate eight-byte blocks of memory, and specify the initial contents.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SPACE                         | .org                    | Allocate a zeroed block of memory.<br>The armasm syntax SPACE directive allocates a zeroed block of memory with the specified size. The<br>GNU assembly .org directive zeroes the memory up to the given address. The address must be<br>greater than the address at which the directive is placed.<br>The following example shows the armasm syntax and GNU syntax methods of creating a 100-byte<br>zeroed block of memory using these directives:<br>; armasm syntax implementation<br>start_address SPACE 0x100<br>// GNU syntax implementation<br>start_address:<br>.org start_address + 0x100<br>If label arithmetic is not required, the GNU assembly .space directive can be used instead of<br>the .org directive. However, Arm recommends using the .org directive wherever possible. |

The following examples show how to rewrite a vector table in both armasm and GNU syntax.

| armasm <b>syntax</b>                                                                 |                                                          | GNU syntax                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                    |
|--------------------------------------------------------------------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Undefined_Addr Du<br>SVC_Addr Du<br>Prefetch_Addr Du<br>Abort_Addr Du<br>IRQ_Addr Du | _Addr<br>Addr<br>r ; Reserved vector<br>CD Reset_Handler | Vectors:<br>ldr pc, Reset_Addr<br>ldr pc, Undefined_Addr<br>ldr pc, SVC_Addr<br>ldr pc, Prefetch_Addr<br>ldr pc, Abort_Addr<br>b.<br>ldr pc, IRQ_Addr<br>ldr pc, FIQ_Addr<br>.balign 4<br>Reset_Addr:<br>.word Reset_Handler<br>Undefined_Addr:<br>.word Undefined_Handler<br>SVC_Addr:<br>.word SVC_Handler<br>Prefetch_Addr:<br>.word Prefetch_Handler<br>Abort_Addr:<br>.word Abort_Handler<br>IRQ_Addr:<br>.word IRQ_Handler<br>FIQ_Addr:<br>word FIQ_Handler | // Reserved vector |

### **Related information**

GNU Binutils - Using as: .byte GNU Binutils - Using as: .word GNU Binutils - Using as: .hword GNU Binutils - Using as: .quad GNU Binutils - Using as: .space GNU Binutils - Using as: .org GNU Binutils - Using as: ARM Machine Directives

# 5.17 Instruction set directives

Instruction set directives instruct the assembler to interpret subsequent instructions as either A32 or T32 instructions.

The following table shows how to translate armasm syntax instruction set directives to GNU syntax directives:

#### Table 5-7 Instruction set directives translation

| armasm syntax directive GNU syntax directive |                    | Description                                            |
|----------------------------------------------|--------------------|--------------------------------------------------------|
| ARM or CODE32                                | .arm or .code 32   | Interpret subsequent instructions as A32 instructions. |
| THUMB or CODE16                              | .thumb or .code 16 | Interpret subsequent instructions as T32 instructions. |

### **Related information**

GNU Binutils - Using as: ARM Machine Directives armasm User Guide: ARM or CODE32 directive armasm User Guide: CODE16 directive armasm User Guide: THUMB directive

### 5.18 Miscellaneous directives

Miscellaneous directives perform a range of different functions.

The following table shows how to translate armasm syntax miscellaneous directives to GNU syntax directives:

### Table 5-8 Miscellaneous directives translation

| armasm<br>syntax<br>directive              | GNU syntax directive                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| foo EQU 0x1C                               | .equ foo, 0x1C                                  | Assigns a value to a symbol. Note the rearrangement of operands.                                                                                                                                                                                                                                                                                                                                                                                                         |
| EXPORT<br>StartHere<br>GLOBAL<br>StartHere | .global StartHere<br>.type StartHere, @function | Declares a symbol that can be used by the linker (that is, a symbol that is<br>visible to the linker).<br>armasm automatically determines the types of exported symbols. However,<br>armclang requires that you explicitly specify the types of exported symbols<br>using the .type directive.<br>If the .type directive is not specified, the linker outputs warnings of the<br>form:<br>Warning: L6437W: Relocation #RELA:1 in test.o(.text)<br>with respect to symbol |
|                                            |                                                 | Warning: L6318W: test.o(.text) contains branch to a non-<br>code symbol <i>symbol</i> .                                                                                                                                                                                                                                                                                                                                                                                  |
| GET file<br>INCLUDE file                   | .include file                                   | Includes a file within the file being assembled.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IMPORT foo                                 | .global foo                                     | Provides the assembler with a name that is not defined in the current assembly.                                                                                                                                                                                                                                                                                                                                                                                          |
| INCBIN                                     | .incbin                                         | Partial support, armclang does not fully support .incbin.                                                                                                                                                                                                                                                                                                                                                                                                                |
| INFO n,<br>"string"                        | .warning "string"                               | The INFO directive supports diagnostic generation on either pass of the assembly (specified by <i>n</i> ). The .warning directive does not let you specify a particular pass, because the armclang integrated assembler only performs one pass.                                                                                                                                                                                                                          |
| ENTRY                                      | armlinkentry= <i>location</i>                   | The ENTRY directive declares an entry point to a program. armclang does not provide an equivalent directive. Use armlinkentry=location to specify the entry point directly to the linker, rather than defining it in the assembly code.                                                                                                                                                                                                                                  |

#### Table 5-8 Miscellaneous directives translation (continued)

| armasm<br>syntax<br>directive | GNU syntax directive                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| END                           | .end                                          | Marks the end of the assembly file.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PRESERVE8                     | .eabi_attribute<br>Tag_ABI_align_preserved, 1 | Emits a build attribute which guarantees that the functions in the file<br>preserve 8-byte stack alignment.<br><b>Note</b> — Note — For armasm syntax assembly language source files, even if you do not<br>specify the PRESERVE8 directive, armasm automatically emits the build<br>attribute if all functions in the file preserve 8-byte stack alignment. For GNU<br>syntax assembly language source files, the armclang integrated assembler<br>does not automatically emit this build attribute. Therefore you must<br>manually inspect and ensure that all functions in your GNU syntax assembly<br>language source file preserve 8-byte stack alignment and then manually add<br>the directive to the file. |

### **Related information**

GNU Binutils - Using as: .type GNU Binutils - Using as: ARM Machine Directives GNU Binutils - Using as: .warning GNU Binutils - Using as: .equ GNU Binutils - Using as: .global GNU Binutils - Using as: .include GNU Binutils - Using as: .incbin armasm User Guide: ENTRY armasm User Guide: END armasm User Guide: INFO armasm User Guide: EXPORT or GLOBAL armlink User Guide: --entry

# 5.19 Symbol definition directives

Symbol definition directives declare and set arithmetic, logical, or string variables.

The following table shows how to translate armasm syntax symbol definition directives to GNU syntax directives:

\_\_\_\_\_ Note —

This list only contains examples of common symbol definition directives. It is not exhaustive.

| armasm syntax directive | GNU syntax directive | Description                                                                  |
|-------------------------|----------------------|------------------------------------------------------------------------------|
| LCLA var                | No GNU equivalent    | Declare a local arithmetic variable, and initialize its value to 0.          |
| LCLL var                | No GNU equivalent    | Declare a local logical variable, and initialize its value to FALSE.         |
| LCLS var                | No GNU equivalent    | Declare a local string variable, and initialize its value to a null string.  |
| No armasm equivalent    | .set var, 0          | Declare a static arithmetic variable, and initialize its value to 0.         |
| No armasm equivalent    | .set var, FALSE      | Declare a static logical variable, and initialize its value to FALSE.        |
| No armasm equivalent    | .set var, ""         | Declare a static string variable, and initialize its value to a null string. |
| GBLA var                | .global var          | Declare a global arithmetic variable, and initialize its value to 0.         |
|                         | .set var, 0          |                                                                              |
| GBLL var                | .global var          | Declare a global logical variable, and initialize its value to FALSE.        |
|                         | .set var, FALSE      |                                                                              |
| GBLS var                | .global var          | Declare a global string variable, and initialize its value to a null string. |
|                         | .set var, ""         |                                                                              |
| var SETA expr           | .set var, expr       | Set the value of an arithmetic variable.                                     |
| var SETL expr           | .set var, expr       | Set the value of a logical variable.                                         |
| var SETS expr           | .set var, expr       | Set the value of a string variable.                                          |
| foo RN 11               | foo .req r11         | Define an alias foo for register R11.                                        |
| foo QN q5.I32           | foo .qn q5.i32       | Define an I32-typed alias foo for the quad-precision register Q5.            |
| foo DN d2.I32           | foo .dn d2.i32       | Define an I32-typed alias foo for the double-precision register D2.          |

#### Table 5-9 Symbol definition directives translation

### **Related information**

GNU Binutils - Using as: ARM Machine Directives GNU Binutils - Using as: .global GNU Binutils - Using as: .set

### 5.20 Migration of armasm macros to integrated assembler macros

The armclang integrated assembler provides similar macro features to those provided by armasm. The macro syntax is based on GNU assembler macro syntax.

\_\_\_\_\_ Note \_\_\_\_\_

This topic includes descriptions of [COMMUNITY] features. See Support level definitions on page 1-13.

—— Note —

The following GNU assembly directives are [COMMUNITY] features:

- .macro and .endm
- .rept and .endr
- .error

Additional information about macro features is available:

- The *armasm User Guide* provides more detail about the macro directives supported, and examples of using macros.
- The GNU Binutils Using as document provides more detail about GNU assembly macro directives.

#### Macro directive features

The following table describes the most common armasm macro directive features, and shows the equivalent features for the armclang integrated assembler.

#### Table 5-10 Comparison of macro directive features provided by armasm and the armclang integrated assembler

| armasm feature                                                                             | armclang integrated assembler feature                                                                     | Description                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MACRO,<br>MEND directives                                                                  | .macro,<br>.endm directives                                                                               | Directives to mark the start and end of the definition of a macro.                                                                                                                                                                                                                                                                                              |
| {\$label} macro<br>parameter                                                               | Use a normal macro parameter.                                                                             | Optionally define an internal label to use within the macro.                                                                                                                                                                                                                                                                                                    |
| {\$cond} macro<br>parameter                                                                | Use a normal macro parameter.                                                                             | Optionally define a condition code to use within the macro.                                                                                                                                                                                                                                                                                                     |
| { <b>\$parameter{,\$para</b><br><b>meter}</b> } custom<br>macro parameter<br>specification | <pre>{parameter{:type} {,parameter{:type}}} custom macro parameter and parameter type specification</pre> | With armasm, any number of custom macro parameters can be<br>defined. Unspecified parameters are substituted with an empty<br>string.<br>With the armclang integrated assembler, the custom macro<br>parameters can optionally have a parameter type type. This can be<br>either req or vararg. Unspecified parameters are substituted with<br>an empty string. |
|                                                                                            |                                                                                                           | The req type specifies a required parameter. The assembler generates an error when instantiating a macro if a required parameter is missing and a default value is not available.                                                                                                                                                                               |
|                                                                                            |                                                                                                           | The vararg type collects all remaining parameters as one<br>parameter. It can only be used as the last parameter within the list<br>of parameters for a given macro. Only one vararg parameter can<br>be specified.                                                                                                                                             |

#### armasm feature armclang integrated assembler Description feature **MEXIT** directive .exitm directive Exit early from a macro definition. IF, .if family of directives. The directives allow conditional assembly of instructions. ELSE. and the .else. With armasm, the conditional assembly directives use a logical expression that evaluates to either TRUE or FALSE as their ELIF. .elseif. controlling expression. **ENDIF** conditional .endif directives With the armclang integrated assembler, multiple variants of the assembly directives GNU assembly .if directive are available, referred to as the .if family of directives. For the .if and .elseif directives, the controlling expression is a logical expression that evaluates to either TRUE or FALSE. For other directives in the .if family of directives, the controlling expression is an implicit part of the directive used, and varies for each such directive. WHILE. The directives allow a sequence of instructions or directives to be .rept, assembled repeatedly. **WEND** directives .endr directives With armasm, the WHILE directive uses a logical expression that evaluates to either TRUE or FALSE as its controlling expression. The sequence enclosed between a WHILE and WEND directive pair is assembled until the logical expression evaluates to FALSE. With the armclang integrated assembler, the GNU assembly .rept directive takes a fixed number of repetitions as a parameter. The sequence enclosed between a .rept and .endr directive pair is assembled the specified fixed number of times. To replicate the effect of using a logical expression to repeatedly assemble a code sequence, the .rept directive can be used within a macro. See the example provided later in this section. **ASSERT** directive Use a combination of the .if family With armasm, the ASSERT directive generates an error message of directives and the .error during assembly if a given assertion is false. A logical expression directive. that evaluates to TRUE or FALSE is used as the assertion. With the armclang integrated assembler, this functionality can be achieved by using a GNU assembly directive from the .if family of directives to conditionally display an error message during assembly using the GNU assembly .error directive. Macros can be created to simplify this process. See the example provided later in this section.

#### Table 5-10 Comparison of macro directive features provided by armasm and the armclang integrated assembler (continued)

### Notable differences between armasm macro syntax and GNU macro syntax

The following syntax restrictions apply to GNU macro syntax in addition to the differences due to macro directives:

• In armasm macro syntax, using the pipe character | as the parameter value when instantiating a macro selects the default value of the parameter. In GNU macro syntax, leaving the parameter value empty

when instantiating a macro selects the default value of the parameter. If a default value is not specified in the macro definition, an empty string is used.

- In armasm macro syntax, a dot can be used between a parameter and subsequent text, or another parameter, if a space is not required in the expansion. In GNU macro syntax, a set of parentheses () can be used between a parameter and subsequent text, if a space is not required in the expansion. There is no need to separate a parameter from another subsequent parameter.
- Although the integrated assembler is case-insensitive to register names, the GNU assembly .ifc directive always performs a case-sensitive comparison. Manually check that the register names use the same case-sense when comparing them using the directive.

### Migration of macro examples provided in the armasm User Guide

### Table 5-11 NOT EQUALS assertion

armasm syntax implementation
ASSERT arg1 <> arg2
GNU syntax implementation
/\* Helper macro to replicate ASSERT <> directive
functionality from armasm.
Displays error if NE assertion fails. \*/
.macro assertNE arg1:req, arg2:req, message:req
.ifc \arg1, \arg2
.error "\message"
.endif
.endm

### Table 5-12 Unsigned integer division macro

| syntax implementation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ro takes the following parameters:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| The register that holds the divisor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| The register that holds the dividend before the instructions are executed. After the instructions are executed, it holds the remainder.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| The register where the quotient of the division is placed. It can be NULL ("") if only the remainder is required.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| A temporary register used during the calculation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <pre>MACRO<br/>DivMod \$Div,\$Top,\$Bot,\$Temp<br/>ASSERT \$Top &lt;&gt; \$Bot ; Produce an error message if the<br/>ASSERT \$Top &lt;&gt; \$Temp ; registers supplied are<br/>ASSERT \$Bot &lt;&gt; \$Temp ; not all different<br/>IF "\$Div" &lt;&gt; ""<br/>ASSERT \$Div &lt;&gt; \$Top ; These three only matter if \$Div<br/>ASSERT \$Div &lt;&gt; \$Bot ; is not null ("")<br/>ASSERT \$Div &lt;&gt; \$Temp ;<br/>ENDIF</pre>                                                                                                                                                                                                                 |
| <pre>MOV \$Temp, \$Bot ; Put divisor in \$Temp<br/>CMP \$Temp, \$Top, LSR #1 ; double it until<br/>MOVLS \$Temp, \$Temp, LSL #1 ; 2 * \$Temp &gt; \$Top<br/>CMP \$Temp, \$Top, LSR #1<br/>BLS %090 ; The b means search backwards<br/>IF "\$Div" &lt;&gt; "" ; Omit next instruction if \$Div<br/>; is null<br/>MOV \$Div, #0 ; Initialize quotient<br/>ENDIF<br/>CMP \$Top, \$Temp ; Can we subtract \$Temp?<br/>SUBCS \$Top, \$Top, \$Temp ; If we can, do so<br/>IF "\$Div" &lt;&gt; "" ; Omit next instruction if \$Div<br/>; is null<br/>ADC \$Div, \$Div, \$Div ; Double \$Div<br/>ENDIF<br/>MOV \$Temp, \$Temp, LSR #1 ; Halve \$Temp,</pre> |
| CMP\$Temp, \$Bot; and loop untilBHS%b91; less than divisorMEND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

GNU syntax implementation

The macro takes the following parameters:

Lab

A label to mark the start of the code. This parameter is required.

#### BotRegNum

The register number for the register that holds the divisor. This parameter is required.

#### TopRegNum

The register number for the register that holds the dividend before the instructions are executed. After the instructions are executed, it holds the remainder. This parameter is required.

#### DivRegNum

The register number for the register where the quotient of the division is placed. It can be NULL ("") if only the remainder is required. This parameter is optional.

#### TempRegNum

The register number for a temporary register used during the calculation. This parameter is required.

```
.macro DivMod Lab:req, DivRegNum, TopRegNum:req, BotRegNum:req, TempRegNum:req
assertNE \TopRegNum, \BotRegNum, "Top and Bottom cannot be the same register"
assertNE \TopRegNum, \TempRegNum, "Top and Temp cannot be the same register"
assertNE \BotRegNum, \TempRegNum, "Bottom and Temp cannot be the same register"
      .ifnb \DivRegNum
            assertNE \DivRegNum, \TopRegNum, "Div and Top cannot be the same register"
assertNE \DivRegNum, \BotRegNum, "Div and Bottom cannot be the same register"
assertNE \DivRegNum, \TempRegNum, "Div and Temp cannot be the same register"
      .endif
\Lab:
                  r\TempRegNum, r\BotRegNum
                                                                          // Put divisor in r\TempRegNum
      mov
                  r\TempRegNum, r\TopRegNum,
                                                             lsr #1
                                                                        // double it until
      cmp
90:
      movls
                  r\TempRegNum, r\TempRegNum, lsl #1 // 2 * r\TempRegNum > r\TopRegNum
                  cmp
      bls
      .ifnb \DivRegNum
            mov r\DivRegNum, #0
                                                 // Initialize quotient
      .endif
91:
                  r\TopRegNum, r\TempRegNum // Can we subtract r\TempRegNum?
r\TopRegNum, r\TopRegNum, r\TempRegNum // If we can, then do so
DivRegNum // Omit next instruction if r\DivRegNum is null
      cmp
      subcs
      .ifnb \DivRegNum
            adc r\DivRegNum, r\DivRegNum, r\DivRegNum
                                                                              // Double r\DivRegNum
      .endif
                  r\TempRegNum, r\TempRegNum, lsr #1 // Halve r\TempRegNum
      mov
                                                                          // and loop until
                  r\TempRegNum, r\BotRegNum
      cmp
                  91b
      bhs
                                                                         // less than divisor
      .endm
```

Notable differences from the armasm syntax implementation:

- A custom macro, assertNE, is used instead of the armasm ASSERT directive.
- Register numbers are used instead of registers as parameters. This is because the GNU assembly .ifc directive used for the assertNE assertions treats its operands as case-sensitive.
- The GNU assembly .ifnb directive is used to check if the parameter DivRegNum has been defined. In the armasm syntax implementation, the armasm IF directive is used.

#### Table 5-13 Assembly-time diagnostics macro

```
armasm syntax implementation
                                            ; This macro produces
; assembly_+**
                                            ; Macro definition
           MACRO
                      $param1="default"
          diagnose
                                              assembly-time diagnostics
          INFŎ
                      0,"$param1"
                                             (on second assembly pass)
          MEND
 ; macro expansion
                                 ; Prints blank line at assembly-time
; Prints "hello" at assembly-time
; Prints "default" at assembly-time
          diagnose
          diagnose "hello"
          diagnose |
GNU syntax implementation
     macro definition
 11
      .macro diagnose, param1="default"
.warning "\param1"
      .endm
     macro instantiation
 11
      // at assembly-time
Notable differences from the armasm syntax implementation:
   It is not possible to print a blank line at assembly-time using the GNU assembly .warning directive. Only a
   warning with an empty message can be printed.
•
   The format of the diagnostic message displayed is different between armasm and the armclang integrated
   assembler.
   With armasm, the diagnostic messages displayed at assembly-time by the macro example are:
     "macros_armasm.S", line 11:
"macros_armasm.S", line 12: hello
"macros_armasm.S", line 13: default
   With the armclang integrated assembler, the diagnostic messages displayed at assembly-time by the macro
   example are:
     <instantiation>:1:1: warning:
     .warning
     macros_armclang.S:11:5: note: while in macro instantiation
         diagnose
     <instantiation>:1:1: warning: hello
     .warning "hello'
     macros_armclang.S:13:5: note: while in macro instantiation
         diagnose "hello"
     <instantiation>:1:1: warning: default
.warning "default"
     macros_armclang.S:14:5: note: while in macro instantiation
         diagnose
```

### Table 5-14 Conditional loop macro

| armasm syntax                                                                                                                                | implementation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| The macro take                                                                                                                               | s the following parameters:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| \$counter                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| for the                                                                                                                                      | ssembly-time variable for the loop counter. This parameter is required. The <b>{\$label}</b> parameter e MACRO directive has been used for this parameter. If a normal macro parameter is used, the neter cannot be instantiated as a label.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| \$N                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| The n                                                                                                                                        | naximum number of iterations for the loop. This parameter is required.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| \$decr                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| The lo                                                                                                                                       | pop decrement value. This parameter is optional.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| do                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| The te                                                                                                                                       | ext to which <b>\$counter</b> is appended in each iteration of the loop. This parameter is required.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| MACRO<br>\$counter<br>ASSERT<br>ASSERT<br>GBLA<br>\$counter<br>WHILE<br>\$counter<br>WEND<br>; macro ins:<br>AREA<br>THUMB<br>counter<br>END | <pre>WhileLoop \$N, \$decr="1", \$do     ; macro definition     "\$counter" &lt;&gt; ""     ; check that \$counter has been specified     ; check that \$N has been specified     ; check that \$do has been specified     ; check that \$do has been specified     ; create new local variable \$counter     ; initialise \$counter     ; loop while \$counter &gt; 0     ; do\$counter ; assemble in each iteration of the loop     ; decrement the counter by \$decr  tantiation WhileLoopMacro,CODE WhileLoop 10, 2, "mov r0, #"</pre> |

GNU syntax implementation The macro takes the following parameters: counter The assembly-time variable for the loop counter. This parameter is required. Ν The maximum number of iterations for the loop. This parameter is required. decr The loop decrement value. This parameter is optional. do The text to which \counter is appended in each iteration of the loop. This parameter is required. /\* Macro that inserts the \counter value at the end of all \do varargs, up to N times. \*/ .macro WhileLoop, counter:req, N:req, decr=1, do:vararg .set \counter, \N // initialise the variable \counter // initialise the variable \counter to 0
// loop up to \N times .rept \N .ifgt \counter // assemble only if \counter is greater than zero \do\counter set \counter, \counter-\decr // decrement the counter by \decr .endif .endr .endm 11 macro instantiation section "WhileLoopMacro", "ax" WhileLoop counter, 10, 2, mov r0, # Note The order in which the GNU assembly.ifgt, .endif, .rept, and .endr directives are used is important. Including the .endr directive as a statement within the .ifgt ... .endif structure produces an error. Similarly, placing the .endif directive outside the .rept ... .endr structure produces an error. The macro expansion produces the following code: mov r0, #0xa mov r0, #8 mov r0, #6 mov r0, #4 mov r0, #2 Notable differences from the armasm syntax implementation: In the armasm syntax implementation, the ASSERT directive is used to raise an error if a required parameter is missing. In the GNU syntax implementation, this can be achieved by using the parameter type req for required parameters in the macro definition. In the armasm syntax implementation, the macro instantiation uses a string as the value to the \$do parameter. The quotes are implicitly removed at assembly-time. Quotes are required as the parameter value contains spaces. In the GNU syntax implementation, this is achieved using the parameter type vararg for the \do parameter in the macro definition. • In the GNU syntax implementation, the .rept ... .endr structure is always evaluated \N times at assembly-time. This is because the .ifgt ... .endif structure must be placed within the .rept ... .endr structure. In the armasm syntax implementation, the WHILE...WEND structure is only evaluated the required number of times at assembly-time based on the controlling expression of the WHILE directive.

### **Related information**

GNU Binutils - Using as: .error GNU Binutils - Using as: .macro GNU Binutils - Using as: .rept GNU Binutils - Using as: .if GNU Binutils - Using as: .else GNU Binutils - Using as: .elseif GNU Binutils - Using as: .endif GNU Binutils - Using as: .warning armasm User Guide: ASSERT armasm User Guide: IF, ELSE, ENDIF, and ELIF armasm User Guide: MACRO and MEND armasm User Guide: MEXIT armasm User Guide: WHILE and WEND armasm User Guide: Use of macros

# Chapter 6 Changes Between Different Versions of Arm<sup>®</sup> Compiler 6

Describes the changes that affect migration and compatibility between different versions of Arm Compiler 6.

It contains the following sections:

- 6.1 Summary of changes between Arm<sup>®</sup> Compiler 6.9 and Arm<sup>®</sup> Compiler 6.10 on page 6-106.
- 6.2 Summary of changes between Arm<sup>®</sup> Compiler 6.8 and Arm<sup>®</sup> Compiler 6.9 on page 6-107.
- 6.3 Summary of changes between Arm<sup>®</sup> Compiler 6.7 and Arm<sup>®</sup> Compiler 6.8 on page 6-108.
- 6.4 Summary of changes between Arm<sup>®</sup> Compiler 6.6 and Arm<sup>®</sup> Compiler 6.7 on page 6-110.
- 6.5 Summary of changes between Arm<sup>®</sup> Compiler 6.5 and Arm<sup>®</sup> Compiler 6.6 on page 6-111.
- 6.6 Compiling with -mexecute-only generates an empty .text section on page 6-114.

### 6.1 Summary of changes between Arm<sup>®</sup> Compiler 6.9 and Arm<sup>®</sup> Compiler 6.10

A summary of the changes between Arm Compiler 6.9 and Arm Compiler 6.10.

### **General changes**

The following are general changes in Arm Compiler 6.10:

- When using the legacy assembler, armasm, to assemble for AArch32 targets that support A32 and T32 instruction sets, the apcs interworking default has changed from /nointerwork to /interwork. If you must use the non-interworking apcs, then you must specify --apcs=/nointerwork on the command-line of the legacy assembler, armasm. However, from Arm Compiler 6.10, the compiler does not include pure A32 libraries for non-interworking apcs. Therefore, if you use the non-interworking apcs for A32 code and require library support, then armlink generates an error unless you provide your own supporting libraries.
- In certain circumstances, when a legacy assembler or linker process invoked the compiler as a subprocess to preprocess a file but all suitable licenses were already in use, the processes could deadlock. This issue has been fixed.
- The default C++ source language mode has changed from gnu++98 to gnu++14.

gnu++14 language and library features are a [BETA] product feature. Arm recommends compiling with -std=c++11 to restrict Arm Compiler to using only C++11 language and library features, which are fully supported.

See -std in the armclang Reference Guide.

### Enhancements

The following are enhancements in Arm Compiler 6.10:

### Compiler and integrated assembler (armclang)

Added support for the -fno-builtin option that can prevent the compiler from optimizing calls to certain standard C library functions, such as printf(). When compiling without -fno-builtin, the compiler can replace such calls with inline code or with calls to other library functions.

See -fno-builtin in the armclang Reference Guide.

### 6.2 Summary of changes between Arm<sup>®</sup> Compiler 6.8 and Arm<sup>®</sup> Compiler 6.9

A summary of the changes between Arm Compiler 6.8 and Arm Compiler 6.9.

### **General changes**

The following are general changes in Arm Compiler 6.9:

• Added support for the Armv8.4-A architecture. To target Armv8.4-A, use the following options:

| State   | armclang options                                 | armlink, and fromelf options           |
|---------|--------------------------------------------------|----------------------------------------|
| AArch64 | target=aarch64-arm-none-eabi<br>-march=armv8.4-a | Do not use thecpu= <i>name</i> option. |
| AArch32 | target=arm-arm-none-eabi<br>-march=armv8.4-a     | Do not use thecpu= <i>name</i> option. |

\_\_\_\_\_ Note \_\_\_\_\_

The legacy assembler, armasm, does not support the Armv8.4-A architecture.

• Added support for the optional Cryptographic Extension in Armv8.4-A. To target Armv8.4-A with the Cryptographic Extension, use the following options:

| State   | armclang options                                                           | armlink and fromelf options            |
|---------|----------------------------------------------------------------------------|----------------------------------------|
| AArch64 | target=aarch64-arm-none-eabi<br>-march=armv8.4-a+crypto                    | Do not use thecpu= <i>name</i> option. |
| AArch32 | target=arm-arm-none-eabi<br>-march=armv8.4-a<br>-mfpu=crypto-neon-fp-armv8 | Do not use thecpu= <i>name</i> option. |

------ Note ------

The legacy assembler, armasm, does not support the Armv8.4-A architecture.

For more information about selecting specific cryptographic algorithms, see *-mcpu* in the *armclang Reference Guide*.

• A change in Arm Compiler 6.9 means that compiling with -mexecute-only always generates an empty .text section that is read-only.

For more information about handling this section, see 6.6 *Compiling with -mexecute-only generates an empty .text section* on page 6-114.

### 6.3 Summary of changes between Arm<sup>®</sup> Compiler 6.7 and Arm<sup>®</sup> Compiler 6.8

A summary of the changes between Arm Compiler 6.7 and Arm Compiler 6.8.

### **General changes**

The following are general changes in Arm Compiler 6.8:

• Added support for the optional Dot Product instructions in Armv8.2-A and Armv8.3-A. To target Armv8.2-A and Armv8.3-A with the Dot Product instructions, use the following options:

| Processor                   | armclang options                                         | armasm, armlink, and fromelf options |
|-----------------------------|----------------------------------------------------------|--------------------------------------|
| Armv8.3-A and AArch64 state | target=aarch64-arm-none-eabi<br>-march=armv8.3-a+dotprod | cpu=8.3-A.64.dotprod                 |
| Armv8.3-A and AArch32 state | target=arm-arm-none-eabi<br>-march=armv8.3-a+dotprod     | cpu=8.3-A.32.dotprod                 |
| Armv8.2-A and AArch64 state | target=aarch64-arm-none-eabi<br>-march=armv8.2-a+dotprod | cpu=8.2-A.64.dotprod                 |
| Armv8.2-A and AArch32 state | target=arm-arm-none-eabi<br>-march=armv8.2-a+dotprod     | cpu=8.2-A.32.dotprod                 |

 Added support for the Cortex-A75 and Cortex-A55 processors. To target Cortex-A75 and Cortex-A55, use the following options:

| Processor                    | armclang options                                                    | armasm, armlink, and fromelf options |
|------------------------------|---------------------------------------------------------------------|--------------------------------------|
| Cortex-A75 for AArch64 state | target=aarch64-arm-none-eab<br>-mcpu=cortex-a75                     | 8.2-A.64                             |
| Cortex-A75 for AArch32 state | target=arm-arm-none-eab<br>-mcpu=cortex-a75                         | 8.2-A.32                             |
| Cortex-A55 for AArch64 state | target=aarch64-arm-none-eab<br>-mcpu=cortex-a55<br>-mcpu=cortex-a55 | 8.2-A.64                             |
| Cortex-A55 for AArch32 state | target=arm-arm-none-eab<br>-mcpu=cortex-a55<br>-mcpu=cortex-a55     | 8.2-A.32                             |

When resolving the relocations of a branch instruction from a function with build attributes that include ~PRES8 to another function with build attributes that include REQ8, the linker previously reported:

Error: L6238E: <objname>(<secname>) contains invalid call from '~PRES8 (The user did not require code to preserve 8-byte alignment of 8-byte data objects)' function to 'REQ8 (Code was permitted to depend on the 8-byte alignment of 8-byte data items)' function <sym>.

This behavior has been changed. By default, the linker no longer reports an error in these circumstances. To restore the previous behavior, use the option --strict\_preserve8\_require8. For more information about this option, see --strict\_preserve8\_require8 in the armlink User Guide.

To successfully link with --strict\_preserve8\_require8

- 1. Manually inspect assembly language source files that are assembled using the integrated assembler.
- 2. Ensure that all functions preserve 8-byte alignment of the stack and of 8-byte data items.
- 3. Add the directive .eabi\_attribute Tag\_ABI\_align\_preserved, 1 to each such source file.

#### Enhancements

The following are enhancements in Arm Compiler 6.8:

#### Compiler and integrated assembler (armclang)

• Previously, the inline assembler and integrated assembler provided limited support for instruction substitutions for the A32 and T32 instruction sets. Substitution occurs when a valid encoding does not exist for an instruction with a particular immediate, but an equivalent instruction that has the same result with the inverted or negated immediate is available. To disable this feature, use the option -mno-neg-immediates.

When -mno-neg-immediatess is not specified, the range of substitutions that the inline assembler and integrated assembler perform has also been extended to cover extra valid substitutions for A64, A32, and T32.

For more information about this option, see *-mno-neg-immediates* in the *armclang Reference Guide*.

- Added support for:
  - #pragma clang section. This pragma enables migration of source code that previously used the legacy armcc feature #pragma arm section. See #pragma clang section in the armclang Reference Guide.
  - -nostdlib and -nostdlibinc options that enable objects to be linked with other ABIcompliant libraries. See -nostdlib and -nostdlibinc in the armclang Reference Guide.
  - \_\_unaligned keyword. This keyword aids migration of source code that previously used the legacy armcc feature \_\_packed. See \_\_unaligned in the armclang Reference Guide.

#### **General enhancements**

Added support for C++14 source language modes. Use one of the following options to enable the compilation of C++14 source code:

- -std=c++14.
- -std=gnu++14.

See -std in the armclang Reference Guide.

# 6.4 Summary of changes between Arm<sup>®</sup> Compiler 6.6 and Arm<sup>®</sup> Compiler 6.7

A summary of the changes between Arm Compiler 6.6 and Arm Compiler 6.7.

#### **General changes**

The following are general changes in Arm Compiler 6.7:

- Armv8-M architecture-based targets are now supported when using an Arm DS-5 Professional license.
- Arm Compiler 6.7 includes FlexNet Publisher 11.14.1.0 client libraries. This version of the license client is not compatible with previous versions of the FlexNet Publisher license server software. When used with a license server running an armlmd or lmgrd version earlier than 11.14.1.0, Arm Compiler 6.7 can report any of the following:
  - Failed to check out a license.Bad message command.
  - Failed to check out a license.Version of vendor daemon is too old.
  - Flex error code: -83.
  - Flex error code: -140.

A license server running arm1md and 1mgrd version 11.14.1.0 (or later) is compatible with Arm Compiler 6.7 and all previous releases of Arm tools.

Arm recommends that you always use the latest version of the license server software that is available from *https://developer.arm.com/products/software-development-tools/license-management/downloads*.

• Previously, when generating execute-only sections, the tools set the ELF section header flag to SHF\_ARM\_NOREAD. For compliance with forthcoming changes to the *Application Binary Interface* (*ABI*) for the Arm<sup>®</sup> Architecture, this behavior has changed. For execute-only sections, the tools now set the ELF section header flag to SHF\_ARM\_PURECODE.

#### Enhancements

The following are enhancements in Arm Compiler 6.7:

#### Compiler and integrated assembler (armclang)

- Added support for the -ffp-mode=model option that you can use to specify the level of floating-point standard compliance:
  - -ffp-mode=std selects the default compiler behavior.

Arm recommends using -ffp-mode rather than -ffast-math or -fno-fast-math.

For more information about this option, see *-ffp-mode* in the *armclang Reference Guide*. Extended the support for the <u>\_\_attribute\_\_((value\_in\_regs))</u> function attribute to improve compatibility with the equivalent Arm Compiler 5 feature.

For more information about this attribute, see the <u>attribute</u> ((value\_in\_regs)) function attribute in the armclang Reference Guide.

• Added support for the generation of implicit IT blocks when assembling for T32 state. To specify the behavior of the inline assembler and integrated assembler if there are conditional instructions outside IT blocks, use the option -mimplicit-it=name.

For more information about this option, see -mimplicit-it in the armclang Reference Guide.

• Previously, when compiling at -Os, the compiler could over-align literal pools that are generated during vectorization to a 128-bit boundary. This behavior has been changed. The compiler now avoids adding excessive padding.

#### armlink

Added support for \_\_at sections that are named .bss.ARM.\_\_at\_<address>. The linker places the associated ZI data at the specified address.

# 6.5 Summary of changes between Arm<sup>®</sup> Compiler 6.5 and Arm<sup>®</sup> Compiler 6.6

A summary of the changes between Arm Compiler 6.5 and Arm Compiler 6.6.

#### **General changes**

The following are general changes in Arm Compiler 6.6:

• Added support for the Armv8.3-A architecture. To target Armv8.3-A, use the following options:

| State   | armclang options                                 | armasm, armlink, and fromelf options |
|---------|--------------------------------------------------|--------------------------------------|
| AArch64 | target=aarch64-arm-none-eabi<br>-march=armv8.3-a | cpu=8.3-A.64                         |
| AArch32 | target=arm-arm-none-eabi<br>-march=armv8.3-a     | cpu=8.3-A.32                         |

Added support for the Armv8-A AArch64 state Scalable Vector Extension (SVE) to the compiler. To target bare-metal systems with SVE, use the option -march=armv8-a+sve. See the *ARM Compiler Scalable Vector Extension User Guide* for more information.

To disassemble objects that have been built for SVE, llvm-objdump is provided as an interim solution. fromelf is to be enhanced to support SVE in a future release of Arm Compiler.

SVE features are available under a separate license. Contact Arm for more information. Added support for the Cortex-R52 processor. To target Cortex-R52, use the following options:

| Processor variant             | armclang options                                           | armasm, armlink, and fromelf options |
|-------------------------------|------------------------------------------------------------|--------------------------------------|
| D32 and Advanced SIMD         | target=arm-arm-none-eab<br>-mcpu=cortex-r52                | cpu=Cortex-R52                       |
| D16 and single-precision only | target=arm-arm-none-eab<br>-mcpu=cortex-r52 -mfpu=fpv5-d16 | cpu=Cortex-R52fpu=FPv5-SP            |

• Added support for the Cortex-M23 processor. To target Cortex-M23, use the following options:

#### armclang

--target=arm-arm-none-eabi -mcpu=cortex-m23

#### armasm, armlink, and fromelf

--cpu=Cortex-M23

• Added support for the Cortex-M33 processor. To target Cortex-M33, use the following options:

| Processor variant       | armclang options                                                      | armasm, armlink, and fromelf options |
|-------------------------|-----------------------------------------------------------------------|--------------------------------------|
| With both DSP and FP    | target=arm-arm-none-eab<br>-mcpu=cortex-m33                           | cpu=Cortex-M33                       |
| Without DSP but with FP | <pre>target=arm-arm-none-eab -mcpu=cortex-m33+nodsp</pre>             | cpu=Cortex-M33.no_dsp                |
| With DSP but without FP | target=arm-arm-none-eab<br>-mcpu=cortex-m33<br>-mfloat-abi=soft       | cpu=Cortex-M33fpu=SoftVFP            |
| Without both DSP and FP | target=arm-arm-none-eab<br>-mcpu=cortex-m33+nodsp<br>-mfloat-abi=soft | cpu=Cortex-M33.no_dsp<br>fpu=SoftVFP |

The default compiler behavior has changed. The following options are selected by default:

- -fdata-sections.
- -ffunction-sections.

-fomit-frame-pointer.

— -fvisibility=hidden.

- Configuration options that select a smaller, less IEEE 754 compliant floating-point math library.

To restore the previous behavior, select from the following options:

- -fno-data-sections.
- -fno-function-sections.
- -fno-omit-frame-pointer.

- Note -

```
— -fvisibility=default [COMMUNITY].
```

Arm recommends not using this option to restore the previous behavior.

-fno-fast-math.

For more information about support level definitions and a subset of these options, see the *armclang Reference Guide*.

• The --cpu=*name* option in armasm, armlink, and fromelf has changed to improve compatibility with the -mcpu compiler option.

| Replace this option name   | With this option name    |
|----------------------------|--------------------------|
| Cortex-A5.neon             | Cortex-A5                |
| Cortex-A5.vfp              | Cortex-A5.no_neon        |
| Cortex-A5                  | Cortex-A5.no_neon.no_vfp |
| Cortex-R5F-rev1            | Cortex-R5                |
| Cortex-R5F                 | Cortex-R5-rev0           |
| Cortex-R5                  | Cortex-R5-rev0.no_vfp    |
| Cortex-R5F-rev1.sp         | Cortex-R5.sp             |
| Cortex-R5-rev1             | Cortex-R5.no_vfp         |
| Cortex-M4F or Cortex-M4.fp | Cortex-M4                |
| Cortex-M4                  | Cortex-M4.no_fp          |
| Cortex-M7.fp.dp            | Cortex-M7                |
| Cortex-M7                  | Cortex-M7.no_fp          |

- The following linker options are deprecated and are to be removed in a future release:
  - --compress\_debug.
  - --gnu\_linker\_defined\_syms.
  - --legacyalign.
  - --match=crossmangled.
  - --strict\_enum\_size.
  - --strict\_wchar\_size.

#### Enhancements

The following are enhancements in Arm Compiler 6.6:

#### Compiler and integrated assembler (armclang)

Added support for:

- \_\_attribute\_\_((naked)) function attribute. This function attribute enables migration of Arm Compiler 5 and earlier embedded assembler functions to Arm Compiler 6.
- Use of floating-point code in secure functions when compiling with -mcmse -mfloat-abi=hard.

#### armlink

Added full support for link-time optimization (LTO). To use LTO, specify the -flto option to the compiler and the --lto option to the linker.

#### Libraries and system headers

- Added [ALPHA] support for multithreading features in the C++11 standard library, for example std::atomic and std::thread. The API for these features is in the arm-tpl.h header file, but you must implement the low-level interface to the underlying operating system. The specification of this thread porting API is available through a separate document. Contact Arm Support for more information.
- Added support to the Arm C library to implement semihosting calls using the HLT instruction for Armv8-A and Armv8-R targets in AArch32 state.
- Added support for use of the C++ library without exceptions. To target C++ without exceptions, compile with the option -fno-exceptions.

When linking objects compiled without exceptions, a specialized C++ library variant is selected that does not have the code-size overhead of exceptions. This C++ library variant has undefined behavior at points where the normal library variant results in an exception being thrown.

### 6.6 Compiling with -mexecute-only generates an empty .text section

A change between Arm Compiler 6.8 and Arm Compiler 6.9 means that compiling with -mexecuteonly always generates an empty .text section that is read-only. That is, a section that does not have the SHF\_ARM\_PURECODE attribute.

The linker normally removes the empty .text section during unused section elimination. However, the unused section elimination does not occur when:

- The image has no entry point.
- You specify one of the following linker options:
  - --no\_remove.

— --keep (<object-file-name>(.text)).

If you use a scatter file to merge execute-only (XO) and read-only (RO) sections into a single executable region, then the XO sections lose the XO attribute and become RO.

When compiling with -fno-function-sections, all functions are placed in the .text section with the SHF\_ARM\_PURECODE attribute. As a result, there are two sections with the name .text, one with and one without the SHF\_ARM\_PURECODE attribute. You cannot select between the two .text sections by name. Therefore, you must use attributes as the selectors in the scatter file to differentiate between XO and RO sections.

#### Examples

The following example shows how Arm Compiler 6 handles .text sections:

1. Create the file example.c containing:

```
void foo() {}
int main() {
   foo();
}
```

2. Compile the program and examine the object file with fromelf.

```
armclang --target=arm-arm-none-eabi -mcpu=Cortex-M3 -mexecute-only -c -o example.o
example.c
fromelf example.o
```

The output shows that Section #2 is the empty RO .text section:

```
...
** Section #1 '.strtab' (SHT_STRTAB)
           : 148 bytes
    Size
** Section #2 '.text' (SHT_PROGBITS) [SHF_ALLOC + SHF_EXECINSTR]
Size : 0 bytes (alignment 4)
    Address: 0x00000000
** Section #3 '.text.foo' (SHT_PROGBITS) [SHF_ALLOC + SHF_EXECINSTR + SHF_ARM_PURECODE]
Size : 2 bytes (alignment 4)
Address: 0x00000000
** Section #4 '.ARM.exidx.text.foo' (SHT_ARM_EXIDX) [SHF_ALLOC + SHF_LINK_ORDER]
    Size : 8 bytes (alignment 4)
    Address: 0x00000000
    Link to section #3 '.text.foo'
** Section #5 '.rel.ARM.exidx.text.foo' (SHT_REL)
    Size : 8 bytes (alignment 4)
Symbol table #13 '.symtab'
    1 relocations applied to section #4 '.ARM.exidx.text.foo'
** Section #6 '.text.main' (SHT_PROGBITS) [SHF_ALLOC + SHF_EXECINSTR + SHF_ARM_PURECODE]
    Size : 10 bytes (alignment 4)
    Address: 0x0000000
. . .
```

3. Create the file example.scat containing:

```
LR_XO 0x10000
{
    ER_MAIN_FOO 0x10000
    {
        example.o(.text*)
    }
}
LR_2 0x20000
{
    ER_REST 0x20000
    {
        *(+RO, +ZI)
    }
ARM_LIB_STACKHEAP 0x80000 EMPTY -0x1000 {}
}
```

4. Create an image file with armlink and examine the image file with fromelf:

```
armlink --scatter example.scat -o example_scat.axf example.o fromelf example_scat.axf
```

The output shows that Section #1 has the SHF\_ARM\_PURECODE attribute:

```
** Section #1 'ER_MAIN_FOO' (SHT_PROGBITS) [SHF_ALLOC + SHF_EXECINSTR + SHF_ARM_PURECODE]
Size : 16 bytes (alignment 4)
Address: 0x00010000

** Section #2 'ER_REST' (SHT_PROGBITS) [SHF_ALLOC + SHF_EXECINSTR]
Size : 604 bytes (alignment 4)
Address: 0x00020000
...
```

5. Repeat the link again with the linker option --no\_remove and examine the image file with fromelf.

```
armlink --scatter example.scat --no_remove -o example_scat.axf example.o
fromelf example_scat.axf
```

The output shows that Section #1 does not have the SHF\_ARM\_PURECODE attribute:

```
** Section #1 'ER_MAIN_FOO' (SHT_PROGBITS) [SHF_ALLOC + SHF_EXECINSTR]
Size : 16 bytes (alignment 4)
Address: 0x00010000
** Section #2 'ER_REST' (SHT_PROGBITS) [SHF_ALLOC + SHF_EXECINSTR]
Size : 604 bytes (alignment 4)
Address: 0x00020000
```

The empty RO .text section is no longer removed and is placed in the same execution region as .text.main and .text.foo. Therefore, these sections become read-only.

The same result is obtained when linking with --keep example.o(.text) or if there is no main or no entry point.

- 6. To ensure that the sections remain as execute-only, either:
  - Change the scatter file to use the XO attribute selector as follows:

```
LR_XO 0x10000
{
    ER_MAIN_FOO 0x10000
    {
        example.o(+XO)
    }
}
LR_2 0x20000
{
    ER_REST 0x20000
    {
        *(+RO, +ZI)
    }
```

```
Explicitly place sections in their execution regions. However, compiling with -fno-function sections generates two .text sections with different attributes:
```

ARM\_LIB\_STACKHEAP 0x80000 EMPTY -0x1000 {}

٠

```
armclang --target=arm-arm-none-eabi -mcpu=Cortex-M3 -mexecute-only -fno-function-
sections -c -o example.o example.c
fromelf example.o
...
** Section #1 '.strtab' (SHT_STRTAB)
Size : 107 bytes
** Section #2 '.text' (SHT_PROGBITS) [SHF_ALLOC + SHF_EXECINSTR]
Size : 0 bytes (alignment 4)
Address: 0x00000000
** Section #3 '.text' (SHT_PROGBITS) [SHF_ALLOC + SHF_EXECINSTR + SHF_ARM_PURECODE]
Size : 14 bytes (alignment 4)
Address: 0x00000000
...
```

In this case, differentiating the sections by name only is not possible. If unused section elimination does not remove the empty .text sections, the attribute selectors are required to place the sections in different output sections.

# Appendix A Code examples

Provides source code examples for Arm Compiler 5 and Arm Compiler 6.

It contains the following sections:

- *A.1 Example startup code for Arm<sup>®</sup> Compiler 5 project* on page Appx-A-118.
- *A.2 Example startup code for Arm<sup>®</sup> Compiler 6 project* on page Appx-A-120.

# A.1 Example startup code for Arm<sup>®</sup> Compiler 5 project

This is an example startup code that compiles without errors using Arm Compiler 5.

This code has been modified to demonstrate migration from Arm Compiler 5 to Arm Compiler 6. This code requires other modifications for use in a real application.

```
startup ac5.c:
\overset{'}{*} Copyright (c) 2009-2017 ARM Limited. All rights reserved.
   SPDX-License-Identifier: Apache-2.0
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
* www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitation of the transformation of the specific language governing permissions and
* limitations under the License.
//#include <RZ_A1H.h>
                    _____
  Definitions
                            */
#define SYS_MODE 0x1F
                                           // System mode
/*_____
  Internal References
 *_
*-----void Vectors
                                                                                     ----*/
                         (void) __attribute__ ((section("RESET")));
void Reset_Handler(void);
extern int printf(const char *format, ...);
   _declspec(noreturn) void main (void)
   __enable_irq();
printf("Starting main\n");
   while(1);
#pragma import (__use_no_semihosting)
                                          -----
  Exception / Interrupt Handler
                                                                                                      ----*/
void Undef_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void SVC_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void PAbt_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void DAbt_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void IRQ_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void FIQ_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
                                                                  -----
  Exception / Interrupt Vector Table
                                                     */
   _asm void Vectors(void) {
   IMPORT Undef_Handler
IMPORT SVC_Handler
   IMPORT PAbt_Handler
   IMPORT IRQ_Handler
   IMPORT FIQ_Handler
            PC, =Reset_Handler
PC, =Undef_Handler
   LDR
   LDR
            PC, =SVC_Handler
PC, =PAbt_Handler
   LDR
   LDR
   LDR
            PC, =DAbt_Handler
   NOP
```

```
PC, =IRQ_Handler
PC, =FIQ_Handler
  I DR
  LDR
}
/*---
   Reset Handler called on controller reset
  *
                                                                                                    ----*/
 asm void Reset Handler(void) {
  // Mask interrupts
CPSID if
   // Put any cores other than 0 to sleep
               p15, 0, R0, c0, c0, 5
R0, R0, #3
                                                    // Read MPIDR
  MRC
   ANDS
goToSleep
   WETNE
                goToSleep
   BNE
   // Reset SCTLR Settings
MRC p15, 0, R0, c1, c0, 0
BIC R0, R0, #(0x1 << 12)
BIC R0, R0, #(0x1 << 2)
DIC R0, R0, #(0x1 << 2)</pre>
                                                           // Read CP15 System Control register
// Clear I bit 12 to disable I Cache
// Clear C bit 2 to disable D Cache
// Clear M bit 0 to disable MMU
// Clear Z bit 11 to disable branch prediction
// Clear V bit 13 to disable hivecs
// Write value back to CP15 System Control register
   MRC
   BIC
                R0, R0, #0x1
R0, R0, #(0x1 << 11)
   BIC
   BIC
               R0, R0, #(0x1 << 13)
p15, 0, R0, c1, c0, 0
   BIC
   MCR
   TSR
   // Configure ACTLR
               p15, 0, r0, c1, c0, 1
r0, r0, #(1 << 1)
p15, 0, r0, c1, c0, 1
                                                            // Read CP15 Auxiliary Control Register
   MRC
   ORR
                                                             // Enable L2 prefetch hint (UNK/WI since r4p1)
                                                            // Write CP15 Auxiliary Control Register
   MCR
   // Set Vector Base Address Register (VBAR) to point to this application's vector table
              R0, =Vectors
p15, 0, R0, c12, c0, 0
   LDR
   MCR
  // Setup Stack for each exceptional mode
IMPORT |Image$$FIQ_STACK$$ZI$$Limit|
IMPORT |Image$$IRQ_STACK$$ZI$$Limit
IMPORT |Image$$SVC_STACK$$ZI$$Limit
IMPORT |Image$$ABT_STACK$$ZI$$Limit
IMPORT |Image$$UND_STACK$$ZI$$Limit
IMPORT |Image$$UND_STACK$$ZI$$Limit|
IMPORT |Image$$UND_STACK$$ZI$$Limit|
               Image$$ARM_LIB_STACK$$ZI$$Limit|
   IMPORT
   CPS
              #0x11
              SP, =|Image$$FIQ_STACK$$ZI$$Limit|
#0x12
   LDR
   CPS
   LDR
              SP, =|Image$$IRQ_STACK$$ZI$$Limit|
   CPS
              #0x13
              SP, =|Image$$SVC_STACK$$ZI$$Limit|
#0x17
   LDR
   CPS
   LDR
              SP, =|Image$$ABT_STACK$$ZI$$Limit|
   CPS
              #0x1B
              SP, =|Image$$UND_STACK$$ZI$$Limit|
#0x1F
   LDR
   CPS
   I DR
              SP, =|Image$$ARM_LIB_STACK$$ZI$$Limit|
   // Call SystemInit
   IMPORT SystemInit
BL SystemInit
   // Unmask interrupts
   CPSIE if
   // Call main
   IMPORT main
   BL
              main
}
/*____
                                             _ _ _ _ _ _
                                                        -----
  Default Handler for Exceptions / Interrupts
  *_
                                                                                                   ----*/
void Default_Handler(void) {
      while(1);
}
```

# Related reference

B.1 Apache License on page Appx-B-123

# A.2 Example startup code for Arm<sup>®</sup> Compiler 6 project

This is an example startup code that compiles without errors using Arm Compiler 6.

This code has been modified to demonstrate migration from Arm Compiler 5 to Arm Compiler 6. This code requires other modifications for use in a real application.

```
startup ac6.c:
 \overset{'}{*} Copyright (c) 2009-2017 ARM Limited. All rights reserved.
   SPDX-License-Identifier: Apache-2.0
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
 * www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitation of the transformation of the specific language governing permissions and
 * limitations under the License.
                   _____
   Definitions
                                   .....*/
#define USR_MODE 0x10 // User mode
#define FIQ_MODE 0x11 // Fast Interrupt Request mode
#define IRQ_MODE 0x12 // Interrupt Request mode
#define SVC_MODE 0x13 // Supervisor mode
#define ABT_MODE 0x17 // Abort mode
#define UND_MODE 0x18 // Undefined Instruction mode
#define SYS_MODE 0x1F // System mode
 /*_____
   Internal References
  *_
                                      _____
                                                                                                               ____*/
void Vectors (void) __attribute__ ((naked, section("RESET")));
void Reset_Handler (void) __attribute__ ((naked));
extern int printf(const char *format, ...);
   _declspec(noreturn) int main (void)
{
   __asm("CPSIE i");
printf("Starting main\n");
while(1) __asm volatile("");
}
   _asm(".global __use_no_semihosting");
 /*-
                                                   -----
   Exception / Interrupt Handler
  *
                                -*/
void Undef_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void SVC_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void PAbt_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void DAbt_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void IRQ_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
void FIQ_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
                                                                Exception / Interrupt Vector Table
                                                             */
void Vectors(void) {
   __asm volatile(
"LDR PC, =Re
                                                                                       \n"
              PC, =Reset_Handler
    "LDR
                PC, =Undef_Handler
PC, =SVC_Handler
                                                                                       \n"
                                                                                       \n"
    "LDR
   "LDR
"LDR
                                                                                       \n"
                PC, =PAbt_Handler
PC, =DAbt_Handler
                                                                                       \n"
                                                                                       \n"
    "NOP
    "LDR
                                                                                       \n"
                 PC, =IRQ_Handler
   "LDR
                                                                                       \n"
                 PC, =FIQ Handler
    );
}
```

```
*-----*
void Reset Handler(void) {
  __asm volatile(
  // Mask interrupts
"CPSID if
                                                                 \n"
  \n" // Read MPIDR
                                                                 \n"
  "goToSleep:
"WFINE
                                                                 \n"
                                                                 ∖n"
                                                                 \n"
  "BNE
             goToSleep
  // Reset SCTLR Settings
"MRC p15, 0, R0, c1

      Scilk Settings

      p15, 0, R0, c1, c0, 0

      R0, R0, #(0x1 << 12)</td>

      R0, R0, #(0x1 << 2)</td>

      R0, R0, #0x1

      P0, R0, #0x1

                                                                \n"
                                                                      // Read CP15 System Control register
                                                                \n" // Read CPIS System Control register
\n" // Clear I bit 12 to disable I Cache
\n" // Clear C bit 2 to disable D Cache
\n" // Clear M bit 0 to disable MMU
  "BIC
  "BIC
  "BIC
                                                                \n"
  "BIC
                                                                       // Clear Z bit 11 to disable branch
             RØ, RØ, #(0x1 << 11)
prediction
             R0, R0, #(0x1 << 13)
p15, 0, R0, c1, c0, 0
                                                                \n"
                                                                \n" // Clear V bit 13 to disable hivecs \n" // Write value back to CP15 System
   "BTC
  "MCR
Control register
                                                                \n"
   "ISB
  // Configure ACTLR
"MRC p15, 0, re
             p15, 0, r0, c1, c0, 1
                                                                \n" // Read CP15 Auxiliary Control
Register
"ORR
                                                                \n" // Enable L2 prefetch hint (UNK/WI
             r0, r0, #(1 << 1)
since r4p1)
                                                                \n" // Write CP15 Auxiliary Control
  "MCR
             p15, 0, r0, c1, c0, 1
Register
  // Set Vector Base Address Register (VBAR) to point to this application's vector table "LDR R0, =Vectors \n"
            R0, =Vectors
p15, 0, R0, c12, c0, 0
                                                                 \n"
  "MCR
  // Setup Stack for each exceptional mode
"CPS #0x11
            #0x11
                                                                 \n"
                                                                 \n"
\n"
  "LDR
             SP, =Image$$FIQ STACK$$ZI$$Limit
  "CPS
             #0x12
                                                                 \n"
   "LDR
            SP, =Image$$IRQ STACK$$ZI$$Limit
                                                                 \n"
  "CPS
            #0x13
   "LDR
             SP, =Image$$SVC_STACK$$ZI$$Limit
                                                                 ∖n"
  "CPS
            #0x17
                                                                 \n"
            SP, =Image$$ABT_STACK$$ZI$$Limit
#0x1B
  "LDR
                                                                 \n"
  "CPS
                                                                 ∖n"
  "LDR
                                                                 \n"
            SP, =Image$$UND_STACK$$ZI$$Limit
  "CPS
                                                                 \n"
            #0x1F
  "LDR
            SP, =Image$$ARM_LIB_STACK$$ZI$$Limit
                                                                 ∖n"
  // Call SystemInit
"BL SystemInit
                                                                \n"
            SystemInit
  // Unmask interrupts
"CPSIE if
                                                                \n"
  // Call main
"BL main
                                                              \n"
  );
}
/*-----
 Default Handler for Exceptions / Interrupts
 *_
                                                        ....*/
void Default_Handler(void) {
  while(1);
}
```

#### **Related reference**

B.1 Apache License on page Appx-B-123

# Appendix B Licenses

Describes the Apache license.

It contains the following section:

• *B.1 Apache License* on page Appx-B-123.

# B.1 Apache License

Version 2.0, January 2004

http://www.apache.org/licenses/ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION

1. Definitions.

"License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document.

"Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License.

"Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity.

"You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License.

"Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files.

"Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types.

"Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below).

"Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof.

"Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution."

"Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work.

2. Grant of Copyright License.

Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form.

3. Grant of Patent License.

Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed.

4. Redistribution.

You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions:

- a. You must give any other recipients of the Work or Derivative Works a copy of this License; and
- b. You must cause any modified files to carry prominent notices stating that You changed the files; and
- c. You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and
- d. If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License.

You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License.

5. Submission of Contributions.

Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions.

6. Trademarks.

This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file.

7. Disclaimer of Warranty.

Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License.

8. Limitation of Liability.

In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages.

9. Accepting Warranty or Additional Liability.

While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability.

#### END OF TERMS AND CONDITIONS

#### APPENDIX: HOW TO APPLY THE APACHE LICENSE TO YOUR WORK

To apply the Apache License to your work, attach the following boilerplate notice, with the fields enclosed by brackets "[]" replaced with your own identifying information. (Don't include the brackets!) The text should be enclosed in the appropriate comment syntax for the file format. We also recommend that a file or class name and description of purpose be included on the same "printed page" as the copyright notice for easier identification within third-party archives.

Copyright [yyyy] [name of copyright owner]

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.