关于PICC18编译器的链接脚本文件
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项目的项目文件中。
所需要的启动模块、标准函数库和处理器函数库在链接器描述文件中指定,所以在bank文件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 RegistersSFR
//逻辑代码段用于指定应将定义的存储器区域的哪一个区域用于一段源代码。要使用逻辑代码段,用 SECTION 伪指令在链接描述文件中定义代
//码段,然后使用该语言内置机制在源文件中引用该名称 (如 MPLAB C18 #pragma section)。此代码段伪指令通过指定代码段的名
称,//以及包含此代码段的 ROM 中的程序存储器区块或 RAM 中的数据存储器区块来定义代码段:
//SECTION NAME=secName { ROM=memName | RAM=memName }
SECTION    NAME=CONFIG    ROM=config
//只有 MPLAB C18 要求设置软件堆栈。下面的语句指定堆栈大小以及堆栈将被分配到的可选 DATABANK
//STACK SIZE=allocSize [RAM=memName]
STACK SIZE=0x100 RAM=gpr14
 

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。