微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 关于PIC的C18编译器的链接脚本文件

关于PIC的C18编译器的链接脚本文件

时间:10-18 来源:互联网 点击:

在PIC单片机编程中,链接描述文件(*.lkr)是链接器的命令文件。它们指定以下内容:

* 目标部件的程序和数据存储器区域

* 堆栈大小和位置 (对于 MPLAB C18)

* 源代码中的逻辑代码段与程序和数据区域的映射

MPLAB C18 C 编译器为每种单片机提供了多达四种类型的链接器描述文件(*.lkr)。这些链接器描述文件与MPLAB IDE所提供链接器描述文件的

不同之处在于,它们在编译器启动代码和库中自动链接,并留出堆栈区。为PIC18F4620单片机提供的四个链接器描述文件如下所示:

18f4620.lkr 供在非扩展模式下编译的应用程序使用。

18f4620i.lkr 供在非扩展模式下编译并使用 MPLAB ICD 2 调试的应用程序使用。“i”表示此链接器描述文件为MPLAB ICD 2使用的资源分配存储空间。

18f4620_e.lkr 供在扩展模式编译的应用程序使用。

18f4620i_e.lkr 供在扩展模式下编译并使用 MPLAB ICD 2 调试的应用程序使用。“i”表示此链接器描述文件为MPLAB ICD 2使用的资源分配存储空间。

对于 18f4620i_e.lkr 必须添加到 MPLAB IDE项目的项目文件中。

所需要的启动模块、标准函数库和处理器函数库在链接器描述文件中指定,所以在mplab的项目树的“Object Files”或“Library Files”中都不需要添加任何文件。当然,如果项目中要链接其它目标文件或库文件,那么应将它们添加到这些分支下。

下面我们结合18f4620.lkr来说明链接描述文件中代码的含义

// $Id: 18f4620.lkr,v 1.3 2004/04/26 18:09:00 curtiss Exp $

// File: 18f4620.lkr

// Sample linker script for the PIC18F4620 processor

//将当前目录library/object搜索路径,.代表当前目录

LIBPATH .

//FILES伪指令指定链接的目标或库文件

//注:可以在一个单独的 FILES 伪指令中指定多个目标或库文件。

FILES c018i.o

FILES clib.lib

FILES p18f4620.lib

//链接描述文件说明PICmicro MCU的存储器架构。这使链接器可把代码在可用的ROM 空间,把变量放在可用的 RAM 空间。标记PROTECTED的区域不会被用于一般程序或数据的分配。只有在为代码段指定了一个绝对地址时,或在链接描述文件中使用SECTION 伪指令将该代码段分配给该区域时,代码或数据才被分配到这些区域。

//CODEPAGE 伪指令用于程序代码、初始化的数据值、常数值和外部存储器。

CODEPAGE NAME=vectors START=0x0 END=0x29 PROTECTED //复位向量和中断向量

CODEPAGE NAME=page START=0x2A END=0xFFFF //用户存储空间

CODEPAGE NAME=idlocs START=0x200000 END=0x200007 PROTECTED //ID 地址单元

CODEPAGE NAME=config START=0x300000 END=0x30000D PROTECTED //配置存储空间

CODEPAGE NAME=devid START=0x3FFFFE END=0x3FFFFF PROTECTED //器件 ID

CODEPAGE NAME=eedata START=0xF00000 END=0xF003FF PROTECTED //EEPROM 数据

//DATABANK(分组寄存器)和ACCESSBANK(快速操作寄存器)伪指令用于内部RAM中的变量

ACCESSBANK NAME=accessram START=0x0 END=0x7F //Bank 0

DATABANK NAME=gpr0 START=0x80 END=0xFF //Bank 0

DATABANK NAME=gpr1 START=0x100 END=0x1FF //Bank 1

DATABANK NAME=gpr2 START=0x200 END=0x2FF //Bank 2

DATABANK NAME=gpr3 START=0x300 END=0x3FF //Bank 3

DATABANK NAME=gpr4 START=0x400 END=0x4FF //Bank 4

DATABANK NAME=gpr5 START=0x500 END=0x5FF //Bank 5

DATABANK NAME=gpr6 START=0x600 END=0x6FF //Bank 6

DATABANK NAME=gpr7 START=0x700 END=0x7FF //Bank 7

DATABANK NAME=gpr8 START=0x800 END=0x8FF //Bank 8

DATABANK NAME=gpr9 START=0x900 END=0x9FF //Bank 9

DATABANK NAME=gpr10 START=0xA00 END=0xAFF //Bank 10

DATABANK NAME=gpr11 START=0xB00 END=0xBFF //Bank 11

DATABANK NAME=gpr12 START=0xC00 END=0xCFF //Bank 12

DATABANK NAME=gpr13 START=0xD00 END=0xDFF //Bank 13

DATABANK NAME=gpr14 START=0xE00 END=0xEFF //Bank 14

DATABANK NAME=gpr15 START=0xF00 END=0xF7F //Bank 15

ACCESSBANK NAME=accesssfr START=0xF80 END=0xFFF PROTECTED //Bank 15 Special Function Registers(SFR)

//逻辑代码段用于指定应将定义的存储器区域的哪一个区域用于一段源代码。要使用逻辑代码段,用 SECTION 伪指令在链接描述文件中定义代

//码段,然后使用该语言内置机制在源文件中引用该名称 (如 MPLAB C18 的 #pragma section)。此代码段伪指令通过指定代码段的名

称,//以及包含此代码段的 ROM 中的程序存储器区块或 RAM 中的数据存储器区块来

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top