aboutsummaryrefslogtreecommitdiffstats
path: root/firmware/link/AT91SAM7S64-ROM-sam7dfu-dfu.ld
blob: dcd68113fae03d130f60212295d922675e94bde7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/* Memory Definitions */

MEMORY
{
  FLASH  (rx) : ORIGIN = 0x00000000, LENGTH = 0x00004000
  DATA   (rw) : ORIGIN = 0x00200000, LENGTH = 0x00004000
  STACK  (rw) : ORIGIN = 0x00204000, LENGTH = 0x00000000
}

/* Section Definitions */

SECTIONS
{
	. = 0x00000000;
	/* first section is .text which is used for code */
	.text 0x00000000: AT ( 0x00000000 ) { 
		* (.reset)
		* (.text)
		* (.rodata*)
		/* * (.dfu.functab) */ /* for debugging */
  		. = ALIGN(4);
  	} >FLASH

  	_etext = . ;
	PROVIDE (etext = .);

	.data.shared (0x00200020): AT (LOADADDR(.text) + SIZEOF(.text)) {
		_data_shared = . ;
		* (.data.shared)
		. = ALIGN(4);
	} >DATA

	_edata_shared = . ;
	_data_flash = LOADADDR(.data.shared) + SIZEOF(.data.shared);

	/* 0x00200000 ... */
	.data (0x00200000 + SIZEOF(.text)): AT 
		( LOADADDR(.text) + SIZEOF(.text) + SIZEOF(.data.shared)) {
  		_data = . ;
		* (.vectram)
  		* (.data)
  		. = ALIGN(4);
  	} >DATA

  	_edata = . ;
	PROVIDE (edata = .);
	
	/* dfu.functab addresses are valid as long as DFU is in flash, i.e.
	 * only while application calls those functions.  Once executing in
	 * DFU mode, we are re-located to ram */
	.dfu.functab 0x00003fd0: AT ( ADDR(.dfu.functab) - ADDR(.text) ) {
  		*(.dfu.functab)
  		. = ALIGN(4096);
  	} >FLASH


	/* .bss section which is used for uninitialized data */
	.bss : {
		__bss_start = . ;
		__bss_start__ = . ;
		*(.bss)
		*(COMMON)
	} >DATA

	. = ALIGN(4);
	__bss_end__ = . ;
	__bss_end__ = . ;

	PROVIDE (main = .);

	_end = . ;

	. = ALIGN(4);
	.int_data : { 
		*(.internal_ram_top) 
   	} >STACK 

	PROVIDE (end = .);

  /* Stabs debugging sections.  */
  .stab          0 : { *(.stab) }
  .stabstr       0 : { *(.stabstr) }
  .stab.excl     0 : { *(.stab.excl) }
  .stab.exclstr  0 : { *(.stab.exclstr) }
  .stab.index    0 : { *(.stab.index) }
  .stab.indexstr 0 : { *(.stab.indexstr) }
  .comment       0 : { *(.comment) }
  /* DWARF debug sections.
     Symbols in the DWARF debugging sections are relative to the beginning
     of the section so we begin them at 0.  */
  /* DWARF 1 */
  .debug          0 : { *(.debug) }
  .line           0 : { *(.line) }
  /* GNU DWARF 1 extensions */
  .debug_srcinfo  0 : { *(.debug_srcinfo) }
  .debug_sfnames  0 : { *(.debug_sfnames) }
  /* DWARF 1.1 and DWARF 2 */
  .debug_aranges  0 : { *(.debug_aranges) }
  .debug_pubnames 0 : { *(.debug_pubnames) }
  /* DWARF 2 */
  .debug_info     0 : { *(.debug_info .gnu.linkonce.wi.*) }
  .debug_abbrev   0 : { *(.debug_abbrev) }
  .debug_line     0 : { *(.debug_line) }
  .debug_frame    0 : { *(.debug_frame) }
  .debug_str      0 : { *(.debug_str) }
  .debug_loc      0 : { *(.debug_loc) }
  .debug_macinfo  0 : { *(.debug_macinfo) }
  /* SGI/MIPS DWARF 2 extensions */
  .debug_weaknames 0 : { *(.debug_weaknames) }
  .debug_funcnames 0 : { *(.debug_funcnames) }
  .debug_typenames 0 : { *(.debug_typenames) }
  .debug_varnames  0 : { *(.debug_varnames) }

}