1/* This linker script generated from xt-genldscripts.tpp for LSP c:\_ddm\audio\devices\MIMXRT685S\xtensa\sim */ 2/* Linker Script for ld -N */ 3MEMORY 4{ 5 dsp_core_seg : org = 0x00200000, len = 0x280000 6 dsp_uncached_seg : org = 0x20060000, len = 0x10000 7 dram0_0_seg : org = 0x24000000, len = 0x10000 8 iram0_0_seg : org = 0x24020000, len = 0x400 9 iram0_1_seg : org = 0x24020400, len = 0x17C 10 iram0_2_seg : org = 0x2402057C, len = 0x20 11 iram0_3_seg : org = 0x2402059C, len = 0x20 12 iram0_4_seg : org = 0x240205BC, len = 0x20 13 iram0_5_seg : org = 0x240205DC, len = 0x20 14 iram0_6_seg : org = 0x240205FC, len = 0x20 15 iram0_7_seg : org = 0x2402061C, len = 0x20 16 iram0_8_seg : org = 0x2402063C, len = 0xF9C4 17} 18 19PHDRS 20{ 21 dsp_core_phdr PT_LOAD; 22 dsp_core_bss_phdr PT_LOAD; 23 dsp_uncached_phdr PT_LOAD; 24 dram0_0_phdr PT_LOAD; 25 dram0_0_bss_phdr PT_LOAD; 26 iram0_0_phdr PT_LOAD; 27 iram0_1_phdr PT_LOAD; 28 iram0_2_phdr PT_LOAD; 29 iram0_3_phdr PT_LOAD; 30 iram0_4_phdr PT_LOAD; 31 iram0_5_phdr PT_LOAD; 32 iram0_6_phdr PT_LOAD; 33 iram0_7_phdr PT_LOAD; 34 iram0_8_phdr PT_LOAD; 35} 36 37 38/* Default entry point: */ 39ENTRY(_ResetVector) 40 41 42/* Memory boundary addresses: */ 43_memmap_mem_dsp_core_start = 0x200000; 44_memmap_mem_dsp_core_end = 0x480000; 45_memmap_mem_dsp_uncached_start = 0x20000000; 46_memmap_mem_dsp_uncached_end = 0x20480000; 47_memmap_mem_dram0_start = 0x24000000; 48_memmap_mem_dram0_end = 0x24010000; 49_memmap_mem_iram0_start = 0x24020000; 50_memmap_mem_iram0_end = 0x24030000; 51 52/* Memory segment boundary addresses: */ 53_memmap_seg_dsp_core_start = 0x200000; 54_memmap_seg_dsp_core_max = 0x480000; 55_memmap_seg_dsp_uncached_start = 0x20060000; 56_memmap_seg_dsp_uncached_max = 0x20070000; 57_memmap_seg_dram0_0_start = 0x24000000; 58_memmap_seg_dram0_0_max = 0x24010000; 59_memmap_seg_iram0_0_start = 0x24020000; 60_memmap_seg_iram0_0_max = 0x24020400; 61_memmap_seg_iram0_1_start = 0x24020400; 62_memmap_seg_iram0_1_max = 0x2402057c; 63_memmap_seg_iram0_2_start = 0x2402057c; 64_memmap_seg_iram0_2_max = 0x2402059c; 65_memmap_seg_iram0_3_start = 0x2402059c; 66_memmap_seg_iram0_3_max = 0x240205bc; 67_memmap_seg_iram0_4_start = 0x240205bc; 68_memmap_seg_iram0_4_max = 0x240205dc; 69_memmap_seg_iram0_5_start = 0x240205dc; 70_memmap_seg_iram0_5_max = 0x240205fc; 71_memmap_seg_iram0_6_start = 0x240205fc; 72_memmap_seg_iram0_6_max = 0x2402061c; 73_memmap_seg_iram0_7_start = 0x2402061c; 74_memmap_seg_iram0_7_max = 0x2402063c; 75_memmap_seg_iram0_8_start = 0x2402063c; 76_memmap_seg_iram0_8_max = 0x24030000; 77 78_rom_store_table = 0; 79PROVIDE(_memmap_reset_vector = 0x24020000); 80PROVIDE(_memmap_vecbase_reset = 0x24020400); 81/* Various memory-map dependent cache attribute settings: */ 82_memmap_cacheattr_wb_base = 0x00000024; 83_memmap_cacheattr_wt_base = 0x00000021; 84_memmap_cacheattr_bp_base = 0x00000022; 85_memmap_cacheattr_unused_mask = 0xFFFFFF00; 86_memmap_cacheattr_wb_trapnull = 0x22222224; 87_memmap_cacheattr_wba_trapnull = 0x22222224; 88_memmap_cacheattr_wbna_trapnull = 0x22222225; 89_memmap_cacheattr_wt_trapnull = 0x22222221; 90_memmap_cacheattr_bp_trapnull = 0x22222222; 91_memmap_cacheattr_wb_strict = 0xFFFFFF24; 92_memmap_cacheattr_wt_strict = 0xFFFFFF21; 93_memmap_cacheattr_bp_strict = 0xFFFFFF22; 94_memmap_cacheattr_wb_allvalid = 0x22222224; 95_memmap_cacheattr_wt_allvalid = 0x22222221; 96_memmap_cacheattr_bp_allvalid = 0x22222222; 97_memmap_region_map = 0x00000003; 98PROVIDE(_memmap_cacheattr_reset = _memmap_cacheattr_wb_trapnull); 99 100SECTIONS 101{ 102 103 NonCacheable.init : ALIGN(4) 104 { 105 NonCacheable_init_start = ABSOLUTE(.); 106 *(NonCacheable.init) 107 . = ALIGN (4); 108 NonCacheable_init_end = ABSOLUTE(.); 109 } >dsp_uncached_seg :dsp_uncached_phdr 110 111 NonCacheable : ALIGN(4) 112 { 113 NonCacheable_start = ABSOLUTE(.); 114 *(NonCacheable) 115 . = ALIGN (4); 116 NonCacheable_end = ABSOLUTE(.); 117 _memmap_seg_dsp_uncached_end = ALIGN(0x8); 118 } >dsp_uncached_seg :dsp_uncached_phdr 119 120 _memmap_mem_dsp_uncached_max = ABSOLUTE(.); 121 122 .dram0.rodata : ALIGN(4) 123 { 124 _dram0_rodata_start = ABSOLUTE(.); 125 *(.dram0.rodata) 126 *(.dram.rodata) 127 . = ALIGN (4); 128 _dram0_rodata_end = ABSOLUTE(.); 129 } >dram0_0_seg :dram0_0_phdr 130 131 .ResetVector.literal : ALIGN(4) 132 { 133 _ResetVector_literal_start = ABSOLUTE(.); 134 *(.ResetVector.literal) 135 . = ALIGN (4); 136 _ResetVector_literal_end = ABSOLUTE(.); 137 } >dram0_0_seg :dram0_0_phdr 138 139 .Level2InterruptVector.literal : ALIGN(4) 140 { 141 _Level2InterruptVector_literal_start = ABSOLUTE(.); 142 *(.Level2InterruptVector.literal) 143 . = ALIGN (4); 144 _Level2InterruptVector_literal_end = ABSOLUTE(.); 145 } >dram0_0_seg :dram0_0_phdr 146 147 .Level3InterruptVector.literal : ALIGN(4) 148 { 149 _Level3InterruptVector_literal_start = ABSOLUTE(.); 150 *(.Level3InterruptVector.literal) 151 . = ALIGN (4); 152 _Level3InterruptVector_literal_end = ABSOLUTE(.); 153 } >dram0_0_seg :dram0_0_phdr 154 155 .DebugExceptionVector.literal : ALIGN(4) 156 { 157 _DebugExceptionVector_literal_start = ABSOLUTE(.); 158 *(.DebugExceptionVector.literal) 159 . = ALIGN (4); 160 _DebugExceptionVector_literal_end = ABSOLUTE(.); 161 } >dram0_0_seg :dram0_0_phdr 162 163 .NMIExceptionVector.literal : ALIGN(4) 164 { 165 _NMIExceptionVector_literal_start = ABSOLUTE(.); 166 *(.NMIExceptionVector.literal) 167 . = ALIGN (4); 168 _NMIExceptionVector_literal_end = ABSOLUTE(.); 169 } >dram0_0_seg :dram0_0_phdr 170 171 .KernelExceptionVector.literal : ALIGN(4) 172 { 173 _KernelExceptionVector_literal_start = ABSOLUTE(.); 174 *(.KernelExceptionVector.literal) 175 . = ALIGN (4); 176 _KernelExceptionVector_literal_end = ABSOLUTE(.); 177 } >dram0_0_seg :dram0_0_phdr 178 179 .UserExceptionVector.literal : ALIGN(4) 180 { 181 _UserExceptionVector_literal_start = ABSOLUTE(.); 182 *(.UserExceptionVector.literal) 183 . = ALIGN (4); 184 _UserExceptionVector_literal_end = ABSOLUTE(.); 185 } >dram0_0_seg :dram0_0_phdr 186 187 .DoubleExceptionVector.literal : ALIGN(4) 188 { 189 _DoubleExceptionVector_literal_start = ABSOLUTE(.); 190 *(.DoubleExceptionVector.literal) 191 . = ALIGN (4); 192 _DoubleExceptionVector_literal_end = ABSOLUTE(.); 193 } >dram0_0_seg :dram0_0_phdr 194 195 .iram0.literal : ALIGN(4) 196 { 197 _iram0_literal_start = ABSOLUTE(.); 198 *(.iram0.literal) 199 *(.iram.literal) 200 *(.iram.text.literal) 201 . = ALIGN (4); 202 _iram0_literal_end = ABSOLUTE(.); 203 } >dram0_0_seg :dram0_0_phdr 204 205 .dram0.data : ALIGN(4) 206 { 207 _dram0_data_start = ABSOLUTE(.); 208 *(.dram0.data) 209 *(.dram.data) 210 . = ALIGN (4); 211 _dram0_data_end = ABSOLUTE(.); 212 } >dram0_0_seg :dram0_0_phdr 213 214 .dram0.bss (NOLOAD) : ALIGN(8) 215 { 216 . = ALIGN (8); 217 _dram0_bss_start = ABSOLUTE(.); 218 *(.dram0.bss) 219 . = ALIGN (8); 220 _dram0_bss_end = ABSOLUTE(.); 221 _memmap_seg_dram0_0_end = ALIGN(0x8); 222 } >dram0_0_seg :dram0_0_bss_phdr 223 224 _memmap_mem_dram0_max = ABSOLUTE(.); 225 226 .ResetVector.text : ALIGN(4) 227 { 228 _ResetVector_text_start = ABSOLUTE(.); 229 KEEP (*(.ResetVector.text)) 230 . = ALIGN (4); 231 _ResetVector_text_end = ABSOLUTE(.); 232 } >iram0_0_seg :iram0_0_phdr 233 234 .ResetHandler.text : ALIGN(4) 235 { 236 _ResetHandler_text_start = ABSOLUTE(.); 237 *(.ResetHandler.literal .ResetHandler.text) 238 . = ALIGN (4); 239 _ResetHandler_text_end = ABSOLUTE(.); 240 _memmap_seg_iram0_0_end = ALIGN(0x8); 241 } >iram0_0_seg :iram0_0_phdr 242 243 244 .WindowVectors.text : ALIGN(4) 245 { 246 _WindowVectors_text_start = ABSOLUTE(.); 247 KEEP (*(.WindowVectors.text)) 248 . = ALIGN (4); 249 _WindowVectors_text_end = ABSOLUTE(.); 250 _memmap_seg_iram0_1_end = ALIGN(0x8); 251 } >iram0_1_seg :iram0_1_phdr 252 253 254 .Level2InterruptVector.text : ALIGN(4) 255 { 256 _Level2InterruptVector_text_start = ABSOLUTE(.); 257 KEEP (*(.Level2InterruptVector.text)) 258 . = ALIGN (4); 259 _Level2InterruptVector_text_end = ABSOLUTE(.); 260 _memmap_seg_iram0_2_end = ALIGN(0x8); 261 } >iram0_2_seg :iram0_2_phdr 262 263 264 .Level3InterruptVector.text : ALIGN(4) 265 { 266 _Level3InterruptVector_text_start = ABSOLUTE(.); 267 KEEP (*(.Level3InterruptVector.text)) 268 . = ALIGN (4); 269 _Level3InterruptVector_text_end = ABSOLUTE(.); 270 _memmap_seg_iram0_3_end = ALIGN(0x8); 271 } >iram0_3_seg :iram0_3_phdr 272 273 274 .DebugExceptionVector.text : ALIGN(4) 275 { 276 _DebugExceptionVector_text_start = ABSOLUTE(.); 277 KEEP (*(.DebugExceptionVector.text)) 278 . = ALIGN (4); 279 _DebugExceptionVector_text_end = ABSOLUTE(.); 280 _memmap_seg_iram0_4_end = ALIGN(0x8); 281 } >iram0_4_seg :iram0_4_phdr 282 283 284 .NMIExceptionVector.text : ALIGN(4) 285 { 286 _NMIExceptionVector_text_start = ABSOLUTE(.); 287 KEEP (*(.NMIExceptionVector.text)) 288 . = ALIGN (4); 289 _NMIExceptionVector_text_end = ABSOLUTE(.); 290 _memmap_seg_iram0_5_end = ALIGN(0x8); 291 } >iram0_5_seg :iram0_5_phdr 292 293 294 .KernelExceptionVector.text : ALIGN(4) 295 { 296 _KernelExceptionVector_text_start = ABSOLUTE(.); 297 KEEP (*(.KernelExceptionVector.text)) 298 . = ALIGN (4); 299 _KernelExceptionVector_text_end = ABSOLUTE(.); 300 _memmap_seg_iram0_6_end = ALIGN(0x8); 301 } >iram0_6_seg :iram0_6_phdr 302 303 304 .UserExceptionVector.text : ALIGN(4) 305 { 306 _UserExceptionVector_text_start = ABSOLUTE(.); 307 KEEP (*(.UserExceptionVector.text)) 308 . = ALIGN (4); 309 _UserExceptionVector_text_end = ABSOLUTE(.); 310 _memmap_seg_iram0_7_end = ALIGN(0x8); 311 } >iram0_7_seg :iram0_7_phdr 312 313 314 .DoubleExceptionVector.text : ALIGN(4) 315 { 316 _DoubleExceptionVector_text_start = ABSOLUTE(.); 317 KEEP (*(.DoubleExceptionVector.text)) 318 . = ALIGN (4); 319 _DoubleExceptionVector_text_end = ABSOLUTE(.); 320 } >iram0_8_seg :iram0_8_phdr 321 322 .iram0.text : ALIGN(4) 323 { 324 _iram0_text_start = ABSOLUTE(.); 325 *(.iram0.text) 326 *(.iram.text) 327 . = ALIGN (4); 328 _iram0_text_end = ABSOLUTE(.); 329 _memmap_seg_iram0_8_end = ALIGN(0x8); 330 } >iram0_8_seg :iram0_8_phdr 331 332 _memmap_mem_iram0_max = ABSOLUTE(.); 333 334 .clib.rodata : ALIGN(4) 335 { 336 _clib_rodata_start = ABSOLUTE(.); 337 *(.clib.rodata) 338 . = ALIGN (4); 339 _clib_rodata_end = ABSOLUTE(.); 340 } >dsp_core_seg :dsp_core_phdr 341 342 .rtos.rodata : ALIGN(4) 343 { 344 _rtos_rodata_start = ABSOLUTE(.); 345 *(.rtos.rodata) 346 . = ALIGN (4); 347 _rtos_rodata_end = ABSOLUTE(.); 348 } >dsp_core_seg :dsp_core_phdr 349 350 .rodata : ALIGN(4) 351 { 352 _rodata_start = ABSOLUTE(.); 353 *(.rodata) 354 *(SORT(.rodata.sort.*)) 355 KEEP (*(SORT(.rodata.keepsort.*) .rodata.keep.*)) 356 *(.rodata.*) 357 *(.gnu.linkonce.r.*) 358 *(.rodata1) 359 __XT_EXCEPTION_TABLE__ = ABSOLUTE(.); 360 KEEP (*(.xt_except_table)) 361 KEEP (*(.gcc_except_table)) 362 *(.gnu.linkonce.e.*) 363 *(.gnu.version_r) 364 KEEP (*(.eh_frame)) 365 /* C++ constructor and destructor tables, properly ordered: */ 366 KEEP (*crtbegin.o(.ctors)) 367 KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors)) 368 KEEP (*(SORT(.ctors.*))) 369 KEEP (*(.ctors)) 370 KEEP (*crtbegin.o(.dtors)) 371 KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors)) 372 KEEP (*(SORT(.dtors.*))) 373 KEEP (*(.dtors)) 374 /* C++ exception handlers table: */ 375 __XT_EXCEPTION_DESCS__ = ABSOLUTE(.); 376 *(.xt_except_desc) 377 *(.gnu.linkonce.h.*) 378 __XT_EXCEPTION_DESCS_END__ = ABSOLUTE(.); 379 *(.xt_except_desc_end) 380 *(.dynamic) 381 *(.gnu.version_d) 382 . = ALIGN(4); /* this table MUST be 4-byte aligned */ 383 _bss_table_start = ABSOLUTE(.); 384 LONG(_dram0_bss_start) 385 LONG(_dram0_bss_end) 386 LONG(_bss_start) 387 LONG(_bss_end) 388 _bss_table_end = ABSOLUTE(.); 389 . = ALIGN (4); 390 _rodata_end = ABSOLUTE(.); 391 } >dsp_core_seg :dsp_core_phdr 392 393 .text : ALIGN(4) 394 { 395 _stext = .; 396 _text_start = ABSOLUTE(.); 397 *(.entry.text) 398 *(.init.literal) 399 KEEP(*(.init)) 400 *(.literal.sort.* SORT(.text.sort.*)) 401 KEEP (*(.literal.keepsort.* SORT(.text.keepsort.*) .literal.keep.* .text.keep.* .literal.*personality* .text.*personality*)) 402 *(.literal .text .literal.* .text.* .stub .gnu.warning .gnu.linkonce.literal.* .gnu.linkonce.t.*.literal .gnu.linkonce.t.*) 403 *(.fini.literal) 404 KEEP(*(.fini)) 405 *(.gnu.version) 406 . = ALIGN (4); 407 _text_end = ABSOLUTE(.); 408 _etext = .; 409 } >dsp_core_seg :dsp_core_phdr 410 411 .clib.text : ALIGN(4) 412 { 413 _clib_text_start = ABSOLUTE(.); 414 *(.clib.literal .clib.text) 415 . = ALIGN (4); 416 _clib_text_end = ABSOLUTE(.); 417 } >dsp_core_seg :dsp_core_phdr 418 419 .rtos.text : ALIGN(4) 420 { 421 _rtos_text_start = ABSOLUTE(.); 422 *(.rtos.literal .rtos.text) 423 . = ALIGN (4); 424 _rtos_text_end = ABSOLUTE(.); 425 } >dsp_core_seg :dsp_core_phdr 426 427 .clib.data : ALIGN(4) 428 { 429 _clib_data_start = ABSOLUTE(.); 430 *(.clib.data) 431 . = ALIGN (4); 432 _clib_data_end = ABSOLUTE(.); 433 } >dsp_core_seg :dsp_core_phdr 434 435 .clib.percpu.data : ALIGN(4) 436 { 437 _clib_percpu_data_start = ABSOLUTE(.); 438 *(.clib.percpu.data) 439 . = ALIGN (4); 440 _clib_percpu_data_end = ABSOLUTE(.); 441 } >dsp_core_seg :dsp_core_phdr 442 443 .rtos.percpu.data : ALIGN(4) 444 { 445 _rtos_percpu_data_start = ABSOLUTE(.); 446 *(.rtos.percpu.data) 447 . = ALIGN (4); 448 _rtos_percpu_data_end = ABSOLUTE(.); 449 } >dsp_core_seg :dsp_core_phdr 450 451 .rtos.data : ALIGN(4) 452 { 453 _rtos_data_start = ABSOLUTE(.); 454 *(.rtos.data) 455 . = ALIGN (4); 456 _rtos_data_end = ABSOLUTE(.); 457 } >dsp_core_seg :dsp_core_phdr 458 459 .data : ALIGN(4) 460 { 461 _data_start = ABSOLUTE(.); 462 *(.data) 463 *(SORT(.data.sort.*)) 464 KEEP (*(SORT(.data.keepsort.*) .data.keep.*)) 465 *(.data.*) 466 *(.gnu.linkonce.d.*) 467 KEEP(*(.gnu.linkonce.d.*personality*)) 468 *(.data1) 469 *(.sdata) 470 *(.sdata.*) 471 *(.gnu.linkonce.s.*) 472 *(.sdata2) 473 *(.sdata2.*) 474 *(.gnu.linkonce.s2.*) 475 KEEP(*(.jcr)) 476 *(__llvm_prf_cnts) 477 *(__llvm_prf_data) 478 *(__llvm_prf_vnds) 479 . = ALIGN (4); 480 _data_end = ABSOLUTE(.); 481 } >dsp_core_seg :dsp_core_phdr 482 483 __llvm_prf_names : ALIGN(4) 484 { 485 __llvm_prf_names_start = ABSOLUTE(.); 486 *(__llvm_prf_names) 487 . = ALIGN (4); 488 __llvm_prf_names_end = ABSOLUTE(.); 489 } >dsp_core_seg :dsp_core_phdr 490 491 .bss (NOLOAD) : ALIGN(8) 492 { 493 . = ALIGN (8); 494 _bss_start = ABSOLUTE(.); 495 *(.dynsbss) 496 *(.sbss) 497 *(.sbss.*) 498 *(.gnu.linkonce.sb.*) 499 *(.scommon) 500 *(.sbss2) 501 *(.sbss2.*) 502 *(.gnu.linkonce.sb2.*) 503 *(.dynbss) 504 *(.bss) 505 *(SORT(.bss.sort.*)) 506 KEEP (*(SORT(.bss.keepsort.*) .bss.keep.*)) 507 *(.bss.*) 508 *(.gnu.linkonce.b.*) 509 *(COMMON) 510 *(.clib.bss) 511 *(.clib.percpu.bss) 512 *(.rtos.percpu.bss) 513 *(.rtos.bss) 514 . = ALIGN (8); 515 _bss_end = ABSOLUTE(.); 516 _end = ALIGN(0x8); 517 PROVIDE(end = ALIGN(0x8)); 518 _stack_sentry = ALIGN(0x8); 519 _memmap_seg_dsp_core_end = ALIGN(0x8); 520 } >dsp_core_seg :dsp_core_bss_phdr 521 522 PROVIDE(__stack = 0x480000); 523 _heap_sentry = 0x480000; 524 525 _memmap_mem_dsp_core_max = ABSOLUTE(.); 526 527 .debug 0 : { *(.debug) } 528 .line 0 : { *(.line) } 529 .debug_srcinfo 0 : { *(.debug_srcinfo) } 530 .debug_sfnames 0 : { *(.debug_sfnames) } 531 .debug_aranges 0 : { *(.debug_aranges) } 532 .debug_pubnames 0 : { *(.debug_pubnames) } 533 .debug_info 0 : { *(.debug_info) } 534 .debug_abbrev 0 : { *(.debug_abbrev) } 535 .debug_line 0 : { *(.debug_line) } 536 .debug_frame 0 : { *(.debug_frame) } 537 .debug_str 0 : { *(.debug_str) } 538 .debug_loc 0 : { *(.debug_loc) } 539 .debug_macinfo 0 : { *(.debug_macinfo) } 540 .debug_weaknames 0 : { *(.debug_weaknames) } 541 .debug_funcnames 0 : { *(.debug_funcnames) } 542 .debug_typenames 0 : { *(.debug_typenames) } 543 .debug_varnames 0 : { *(.debug_varnames) } 544 .xt.insn 0 : 545 { 546 KEEP (*(.xt.insn)) 547 KEEP (*(.gnu.linkonce.x.*)) 548 } 549 .xt.prop 0 : 550 { 551 KEEP (*(.xt.prop)) 552 KEEP (*(.xt.prop.*)) 553 KEEP (*(.gnu.linkonce.prop.*)) 554 } 555 .xt.lit 0 : 556 { 557 KEEP (*(.xt.lit)) 558 KEEP (*(.xt.lit.*)) 559 KEEP (*(.gnu.linkonce.p.*)) 560 } 561 .debug.xt.callgraph 0 : 562 { 563 KEEP (*(.debug.xt.callgraph .debug.xt.callgraph.* .gnu.linkonce.xt.callgraph.*)) 564 } 565 .note.gnu.build-id 0 : 566 { 567 KEEP(*(.note.gnu.build-id)) 568 } 569} 570 571