微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > pic单片机,链接描述文件(*.lkr)含义

pic单片机,链接描述文件(*.lkr)含义

时间:11-13 来源:互联网 点击:
结合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 中的数据存储器区块来定义代码段:
//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

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

网站地图

Top