⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 at91sam9260_4kram_sdram.xcl

📁 ATMEL AT91SAM9260的中段控制程序!
💻 XCL
字号:
// ---------------------------------------------------------
//   ATMEL Microcontroller Software Support  -  ROUSSET  -
// ---------------------------------------------------------
// The software is delivered "AS IS" without warranty or
// condition of any  kind, either express, implied or
// statutory. This includes without limitation any warranty
// or condition with respect to merchantability or fitness
// for any particular purpose, or against the infringements of
// intellectual property rights of others.
// ---------------------------------------------------------
//  File: at91SAM9260_4KRAM_SDRAM.xlc
//  Object              : Generic Linker Command File for IAR for RAM debug
//  1.0 09/Aug/06 JPP   : Creation to 4.31A
//-----------------------------------------------------------------------------

//*************************************************************************
// XLINK command file template for EWARM/ICCARM
//
// Usage:  xlink  -f lnkarm  <your_object_file(s)>
//                -s <program start label>  <C/C++ runtime library>
//*************************************************************************
// -------------
// Code segments - may be placed anywhere in memory.
// -------------
//   INTVEC     -- Exception vector table.
//   SWITAB     -- Software interrupt vector table.
//   ICODE      -- Startup (cstartup) and exception code.
//   DIFUNCT    -- Dynamic initialization vectors used by C++.
//   CODE       -- Compiler generated code.
//   CODE_I     -- Compiler generated code declared __ramfunc (executes in RAM)
//   CODE_ID    -- Initializer for CODE_I (ROM).
//
// -------------
// Data segments - may be placed anywhere in memory.
// -------------
//   CSTACK     -- The stack used by C/C++ programs (system and user mode).
//   IRQ_STACK  -- The stack used by IRQ service routines.
//   SVC_STACK  -- The stack used in supervisor mode
//                 (Define other exception stacks as needed for
//                 FIQ, ABT, UND).
//   HEAP       -- The heap used by malloc and free in C and new and
//                 delete in C++.
//   INITTAB    -- Table containing addresses and sizes of segments that
//                 need to be initialized at startup (by cstartup).
//   CHECKSUM   -- The linker places checksum byte(s) in this segment,
//                 when the -J linker command line option is used.
//   DATA_y     -- Data objects.
//
// Where _y can be one of:
//   _AN        -- Holds uninitialized located objects, i.e. objects with
//                 an absolute location given by the @ operator or the
//                 #pragma location directive. Since these segments
//                 contain objects which already have a fixed address,
//                 they should not be mentioned in this linker command
//                 file.
//   _C         -- Constants (ROM).
//   _I         -- Initialized data (RAM).
//   _ID        -- The original content of _I (copied to _I by cstartup) (ROM).
//   _N         -- Uninitialized data (RAM).
//   _Z         -- Zero initialized data (RAM).
//
// Note:  Be sure to use end values for the defined address ranges.
//        Otherwise, the linker may allocate space outside the
//        intended memory range.
//*************************************************************************

//*************************************************************************
// Inform the linker about the CPU family used.
// AT91SAM9260 Memory mapping
// No remap
//  ROM 32 Kb                    (0x0000 8000)
//  Start address 0x0010 0000 or  0x0000 0000
//  RAM 4Kb and 4Kb              (0x0000 1000)
//  Start address 0x0020 0000 or  0x0000 0000
//  Start address 0x0030 0000
//  SDRAM EBI CS1 64 Mb          (0x0400 0000)
//  Start address 0x2000 0000
//  ROMSTART (FLASH)
//  Start address 0x0000 0000
//  Size 512 Kbo  0x0004 0000
//  RAMSTART
//  Start address 0x0020 0000
//  Size  4 Kb    0x0000 1000
//  Start address 0x0030 0000
//  Size  4 Kb    0x0000 1000
// Remap done
//  RAMSTART
//  Start address 0x0000 0000
//  Size  4 Kb    0x0000 1000
//  ROMSTART
//  TBD board definition
//*************************************************************************
-carm

//*************************************************************************
// Internal Ram segments mapped AFTER REMAP 160 K.
//*************************************************************************
// Use these addresses for the .
-Z(CONST)INTRAMSTART=00200000
-Z(CONST)INTRAMEND=00200400

-Z(CONST)INTRAMSTART_REMAP=20000000
-Z(CONST)INTRAMEND_REMAP=24000000

//*************************************************************************
// Read/write segments mapped to RAM.
//*************************************************************************
-DRAMSTART=20000000
-DRAMEND=24000000

//************************************************
// Address range for reset and exception
// vectors (INTVEC).
// The vector area is 32 bytes,
// an additional 32 bytes is allocated for the
// constant table used by ldr PC in cstartup.s79.
//************************************************
-Z(CODE)INTVEC=00-3F

//************************************************
// Startup code and exception routines (ICODE).
//************************************************
-Z(CODE)ICODE,DIFUNCT=RAMSTART-RAMEND
-Z(CODE)SWITAB=RAMSTART-RAMEND

//************************************************
// Code segments may be placed anywhere.
//************************************************
-Z(CODE)CODE=RAMSTART-RAMEND

//************************************************
// Various constants and initializers.
//************************************************
-Z(CONST)INITTAB,DATA_ID,DATA_C=RAMSTART-RAMEND
-Z(CONST)CHECKSUM=RAMSTART-RAMEND

//************************************************
// Data segments.
//************************************************
-Z(DATA)DATA_I,DATA_Z,DATA_N=RAMSTART-RAMEND

//************************************************
// __ramfunc code copied to and executed from RAM.
//************************************************
-Z(DATA)CODE_I=RAMSTART-RAMEND
-Z(CONST)CODE_ID=RAMSTART-RAMEND // Initializer for
-QCODE_I=CODE_ID

//************************************************
// ICCARM produces code for __ramfunc functions in
// CODE_I segments. The -Q XLINK command line
// option redirects XLINK to emit the code in the
// debug information associated with the CODE_I
// segment, where the code will execute.
//************************************************

//*************************************************************************
// Stack and heap segments.
//*************************************************************************
-D_CSTACK_SIZE=(100*4)
-D_IRQ_STACK_SIZE=(2*8*4)
-D_HEAP_SIZE=10  // IMAL

-Z(DATA)CSTACK+_CSTACK_SIZE=RAMSTART-RAMEND
-Z(DATA)IRQ_STACK+_IRQ_STACK_SIZE=RAMSTART-RAMEND
-Z(DATA)HEAP+_HEAP_SIZE=RAMSTART-RAMEND    // IMAL

//*************************************************************************
// ELF/DWARF support.
//
// Uncomment the line "-Felf" below to generate ELF/DWARF output.
// Available format specifiers are:
//
//   "-yn": Suppress DWARF debug output
//   "-yp": Multiple ELF program sections
//   "-yas": Format suitable for debuggers from ARM Ltd (also sets -p flag)
//
// "-Felf" and the format specifiers can also be supplied directly as
// command line options, or selected from the Xlink Output tab in the
// IAR Embedded Workbench.
//*************************************************************************

// -Felf

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -