How do I place a group of functions or variables in a specific section?
http://supp.iar.com/Support/?Note=27498
EWARM v5.xx (and newer)
The placement of a few functions in a specific section is done with the ...
#pragma location="FUNCTIONS"
void h(void);
... but this becomes impractical when there are many functions to place.
So the ILINK linker of EWARM 5.xx can place all functions from a file into a specific section.
Placing many functions
| • |
Collect these functions in one (or more) source files. |
| • |
Remove any #pragma location you have earlier added. |
| • |
Edit the .icf file with a line the holds the keyword "object" as exemplified below. For more information, please see the chapter Section-selectors in the EWARM_DevelopmentGuide.pdf file. |
Example
The link to the right holds an edited variant of "Tutor 1", where ILINK will place all code from the file Utilities.c at address 0x7000000 and higher.
The change made to the "Tutor 1", is the addition of these files to the .icf file:
define symbol __EXAMPLE_start__ = 0x7000000;
define symbol __EXAMPLE_end__ = 0x700FFFF;
define region EXAMPLE_region = mem:[from __EXAMPLE_start__ to __EXAMPLE_end__];
place in EXAMPLE_region { readonly object Utilities.o};
EWARM v6.70 (and newer)
Two new pragma directives have been added in v6.70 ...
#pragma default_variable_attributes
... and ...
#pragma default_function_attributes
... to set default placement and attributes for variable/function declarations and definitions.
This means that you can override multiple declarations and definitions by using a single #pragma.
Example
Below is an example of how to use these new pragmas:
/* Place following functions in section MY_FUNC */
#pragma default_function_attributes = @ "MY_FUNC" int fun1(int x)
{
return x + ;
} int fun2(int x)
{
return x - ;
} /* Stop placing functions in section MY_FUNC */
#pragma default_function_attributes = int fun3(int x)
{
return x + x;
} /* Place following data in section MY_DATA */
#pragma default_variable_attributes = @ "MY_DATA" int data1;
int data2; /* Stop placing data in section MY_DATA */
#pragma default_variable_attributes = int data3; int main()
{
data1 = fun1();
data2 = fun2();
data3 = fun3(); return data1 + data2 + data3;
}
#pragma location
Syntax
#pragma location={address|register|NAME}
Parameters
Description Use this pragma directive to specify:
address The absolute address of the global or static variable or function for which you want an absolute location.
register An identifier that corresponds to one of the ARM core registers R4–R11.
NAME A user-defined section name; cannot be a section name predefined for use by the compiler and linker.
Description
Use this pragma directive to specify:
The location—the absolute address—of the global or static variable whose declaration follows the pragma directive.
The variables must be declared __no_init.
An identifier specifying a register. The variable defined after the pragma directive is placed in the register.
The variable must be declared as __no_init and have file scope.
A string specifying a section for placing either a variable or function whose declaration follows the pragma directive.
Do not place variables that would normally be in different sections
(for example, variables declared as __no_init and variables declared as const) in the same named section.
#pragma location=0xFFFF0400
__no_init volatile char PORT1;
/* PORT1 is located at address 0xFFFF0400 */ #pragma location=R8
__no_init int TASK;
/* TASK is placed in R8 */ #pragma location="FLASH"
char PORT2;
/* PORT2 is located in section FLASH */ /* A better way is to use a corresponding mechanism */
#define FLASH _Pragma("location=\"FLASH\"")
FLASH int i; /* i is placed in the FLASH section */
Controlling data and function placement in memory
The compiler provides different mechanisms for controlling placement of functions and data objects in memory.
To use memory efficiently, you should be familiar with these mechanisms to know
which one is best suited for different situations. You can use:
The @ operator and the #pragma location directive for absolute placement
Use the @ operator or the #pragma location directive to place individual global and static variables at absolute addresses.
This is useful for individual data objects that must be located at a fixed address to conform to external requirements,
for example to populate interrupt vectors or other hardware tables.
Note that it is not possible to use this notation for absolute placement of individual functions.
The @ operator and the #pragma location directive for section placement
Use the @ operator or the #pragma location directive to place groups of functions or global and static variables in named sections,
without having explicit control of each object.
The sections can, for example, be placed in specific areas of memory, or initialized or copied in controlled ways using the section begin and end operators.
This is also useful if you want an interface between separately linked units, for example an application project and a boot loader project.
Use named sections when absolute control over the placement of individual variables is not needed, or not useful.
The @ operator and the #pragma location directive for register placement
Use the @ operator or the #pragma location directive to place individual global and static variables in registers.
The variables must be declared __no_init. This is useful for individual data objects that must be located in a specific register.
The --section option
Use the --section option to place functions and/or data objects in named sections, which is useful, for example,
if you want to direct them to different fast or slow memories. For more information, see --section, page 266.
--section OldName=NewName
Description The compiler places functions and data objects into named sections which are referred to by the IAR ILINK Linker.
Use this option to change the name of the section OldName to NewName.
This is useful if you want to place your code or data in different address ranges and you find the @ notation,
alternatively the #pragma location directive, insufficient.
Note that any changes to the section names require corresponding modifications in the linker configuration file.
To place functions in the section MyText, use:
--section .text=MyText
At compile time, data and functions are placed in different sections, see Modules and sections, page 68.
At link time, one of the most important functions of the linker is to assign load addresses to the various sections used by the application.
All sections, except for the sections holding absolute located data, are automatically allocated to memory according to the specifications
in the linker configuration file, see Placing code and data—the linker configuration file, page 70.
Placing code and data—the linker configuration file
The placement of sections in memory is performed by the IAR ILINK Linker. It uses the linker configuration file
where you can define how ILINK should treat each section and how they should be placed into the available memories.
A typical linker configuration file contains definitions of:
● Available addressable memories
● Populated regions of those memories
● How to treat input sections
● Created sections
● How to place sections into the available regions.
The file consists of a sequence of declarative directives. This means that the linking process will be governed by all directives at the same time.
To use the same source code with different derivatives, just rebuild the code with the appropriate configuration file.
How do I place a group of functions or variables in a specific section?的更多相关文章
- 7 Scatter-loading Features
7.1 About scatter-loading The scatter-loading mechanism enables you to specify the memory map of an ...
- Think Python - Chapter 03 - Functions
3.1 Function callsIn the context of programming, a function is a named sequence of statements that p ...
- Analytic Functions in Oracle
Contents Overview and IntroductionHow Analytic Functions WorkThe SyntaxExamplesCalculate a running T ...
- Aggregate (GROUP BY) Function Descriptions
w Table 13.25 Aggregate (GROUP BY) Functions Name Description AVG() Return the average value of the ...
- C-Language Functions
转自:https://www.postgresql.org/docs/9.6/xfunc-c.html 可以作为学习基于c编写pg extension 的资料 36.9. C-Language Fun ...
- 表视图为Group类型的注意问题
使用group类型的tableview时,第一个section距离navigationbar的距离很大,不符合这边的设计图. 使用 myTableView . sectionHeaderHeight ...
- CentOS 6.8 LAMP 安装配置
1.远程系统拒绝了连接: 需要关闭防火墙/etc/rc.d/init.d/iptables stop service iptables stop chkconfig iptables off sete ...
- Web服务之LNMMP架构及动静分离实现
原文链接:http://hoolee.blog.51cto.com/7934938/1413346 讲的非常详细,尽管我只看动静分离,可是看了一下其他的部署,也是非常不错,适合新手 一.LNMMP ...
- Google C++ Style Guide
Background C++ is one of the main development languages used by many of Google's open-source project ...
随机推荐
- iostat的深入理解
问题背景 iostat -xdm 1 通常用来查看机器磁盘IO的性能. 我们一般会有个经验值,比如,ioutil要小于80%, svctm要小于2ms. 前几天碰到一个奇怪的现象:有一台SSD机器,磁 ...
- ueditor的工具栏显示乱码解决方法 小问题.. 是你的页面编码与语言包js编码不符所导致的
ueditor的工具栏显示乱码解决方法 小问题.. 是你的页面编码与语言包js编码不符所导致的解决方法:用记事本将ueditor\..\lang\zh-cn\zh-cn.js打开,然后保存为ANSI ...
- oracle收集
1. 高级sql学习——with子句 http://blog.chinaunix.net/uid-10697776-id-2935678.html 2.java List 排序 Collections ...
- web-3g-(163)网易-邮箱-记事本-数据库设计
ylbtech-DatabaseDesgin:ylbtech-cnblogs(博客园)-数据库设计-2,Admin(用户后台) DatabaseName:cnblogs(博客园) Model:Admi ...
- IntelliJ IDEA svn 提交错误
环境说明: 系统:Mac OS X 10.9 以及 10.10 系统设置:LANG=zh_CN.UTF-8 svn 客户端:1.8.10 IntelliJ IDEA 13 毫无疑问,IntelliJ ...
- linux下使用go-oci8
地址:https://github.com/wendal/go-oci8 它是 https://github.com/mattn/go-oci8 的分支. win下安装步骤参考:http://www. ...
- OSX 10.10安装教程。
现在苹果已经放出了OS X 10.9 Mavericks第一个开发者预览版,从Mac App Store中获得的安装程序,可以在10.8的系统中直接进行升级,原有文件都会保留.但是要想制作成一个10. ...
- [转]Chrome浏览器的离线安装包下载地址
每当chrome有更新之后,都有不少用户想要下载离线版的安装文件,但苦于找不到下载地址而发愁,其实这个问题很简单,下面我来分享一下方法(仅针对Windows操作系统): 对于稳定版(正式版)Chrom ...
- Android百度地图开发(三)范围搜索
// 1.新建项目 将地图API添加进classpath中: 2.在activity_main.xml中添加一个MapView,用来显示地图: <LinearLayout xmlns:andro ...
- Ubuntu 16.04 TensorFlow CPU 版本安装
1.下载Anaconda,官方网站.我下载的时Python 2.7 64bit版本: 2.安装执行命令 bash Anaconda2-4.2.0-Linux-x86_64.sh 设置好目录后等 ...