您的位置 首页 模拟

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

结合18f4620.lkr来说明链接描述文件中代码的含义//$Id:18f4620.lkr,v1.32004/04/2618:09:00curtissExp$//File:18f4620…

结合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

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/zhishi/moni/272415.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部