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

📄 adsp-bf535_c.ldf

📁 Analog公司的ADSP_BF532上面实现以太网接口的源码
💻 LDF
字号:
/*
** LDF for ADSP-BF535.
**
** There are a number of configuration options that can be specified
** either by compiler flags, or by linker flags directly. The options are:
**
** USE_PROFILER0
**      Enabled by -p. Link in profiling library, and write results to
**      both stdout and mon.out.
** USE_PROFILER1
**      Enabled by -p1. Only write profiling data to mon.out.
** USE_PROFILER2
**      Enabled by -p2. Only write profiling data to stdout.
** USE_PROFILER
**      Equivalent to USE_PROFILER0.
** __WORKAROUNDS_ENABLED
**    Defined by compiler when -workaround is used to direct LDF to
**    link with libraries that have been built with work-arounds
**    enabled.
** USE_FILEIO
**      Link in support for file I/O (fopen, etc). Also necessary
**      for argc/argv handling.
** USE_CACHE
**      Makes use of Some L1 memory as cache. Implies the presence
**      of at least some external memory.
*/

ARCHITECTURE(ADSP-BF535)

#ifndef __NO_STD_LIB
SEARCH_DIR( $ADI_DSP/Blackfin/lib )
#endif

/* Moving to primIO means that we must always include the FileIO support,
** so that printf() will work.
*/

#ifndef USE_FILEIO      /* { */
#define USE_FILEIO 1
#endif  /* } */

#ifdef USE_PROFILER     /* { */
#define USE_PROFILER0
#endif  /* } */

#ifdef USE_PROFILER0    /* { */
#ifdef __WORKAROUNDS_ENABLED    /* { */
#define PROFFLAG prfflg0_535y.doj
#else
#define PROFFLAG prfflg0_535.doj
#endif  /* } */
// The profiler needs File I/O to write its results.
#define USE_FILEIO 1
#ifndef USE_PROFILER    /* { */
#define USE_PROFILER
#endif  /* } */
#endif  /* } */

#ifdef USE_PROFILER1    /* { */
#ifdef __WORKAROUNDS_ENABLED    /* { */
#define PROFFLAG prfflg1_535y.doj
#else
#define PROFFLAG prfflg1_535.doj
#endif  /* } */
#define USE_FILEIO 1
#ifndef USE_PROFILER    /* { */
#define USE_PROFILER
#endif  /* } */
#endif  /* } */

#ifdef USE_PROFILER2    /* { */
#ifdef __WORKAROUNDS_ENABLED    /* { */
#define PROFFLAG prfflg2_535y.doj
#else
#define PROFFLAG prfflg2_535.doj
#endif  /* } */
#define USE_FILEIO 1
#ifndef USE_PROFILER    /* { */
#define USE_PROFILER
#endif  /* } */
#endif  /* } */

#ifdef __WORKAROUNDS_ENABLED    /* { */
#define OMEGA idle535y.doj
#else
#define OMEGA idle535.doj
#endif  /* } */

#define MEMINIT __initsbsz535.doj,

#define LIBSMALL libsmall535.dlb,

#ifdef M3_RESERVED      /* { */
#ifdef __WORKAROUNDS_ENABLED    /* { */
#define LIBM3 libm3res535y.dlb
#define LIBDSP libdspm3res535y.dlb
#define SFTFLT libsftflt535y.dlb
#else
#define LIBM3 libm3res535.dlb
#define LIBDSP libdspm3res535.dlb
#define SFTFLT libsftflt535.dlb
#endif  /* } */
#else
#ifdef __WORKAROUNDS_ENABLED    /* { */
#define LIBM3 libm3free535y.dlb
#define LIBDSP libdsp535y.dlb
#define SFTFLT libsftflt535y.dlb
#else
#define LIBM3 libm3free535.dlb
#define LIBDSP libdsp535.dlb
#define SFTFLT libsftflt535.dlb
#endif  /* } */
#endif  /* } */

#ifdef IEEEFP   /* { */
#define FPLIBS SFTFLT, LIBDSP
#else
#define FPLIBS LIBDSP, SFTFLT
#endif  /* } */

#ifdef __WORKAROUNDS_ENABLED    /* { */
#ifdef __ADI_LIBEH__ /* { */
#define LIBS LIBSMALL MEMINIT libc535y.dlb, LIBM3, libevent535y.dlb, libx535y.dlb, libio535y.dlb, libcpp535yx.dlb, libcpprt535yx.dlb, FPLIBS, libetsi535.dlb, OMEGA
#else
#define LIBS LIBSMALL MEMINIT libc535y.dlb, LIBM3, libevent535y.dlb, libx535y.dlb, libio535y.dlb, libcpp535y.dlb, libcpprt535y.dlb, FPLIBS, libetsi535.dlb, OMEGA
#endif /* } */
#else
#ifdef __ADI_LIBEH__ /* { */
#define LIBS LIBSMALL MEMINIT libc535.dlb, LIBM3, libevent535.dlb, libx535.dlb, libio535.dlb, libcpp535x.dlb, libcpprt535x.dlb, FPLIBS, libetsi535.dlb, OMEGA
#else
#define LIBS LIBSMALL MEMINIT libc535.dlb, LIBM3, libevent535.dlb, libx535.dlb, libio535.dlb, libcpp535.dlb, libcpprt535.dlb, FPLIBS, libetsi535.dlb, OMEGA
#endif /* } */
#endif  /* } */
#if defined(USE_FILEIO) || defined(USE_PROFGUIDE)
#ifdef __WORKAROUNDS_ENABLED    /* { */
$LIBRARIES = LIBS, librt_fileio535y.dlb;
#else
$LIBRARIES = LIBS, librt_fileio535.dlb;
#endif  /* } */
#else
#ifdef __WORKAROUNDS_ENABLED    /* { */
$LIBRARIES = LIBS, librt535y.dlb;
#else
$LIBRARIES = LIBS, librt535.dlb;
#endif  /* } */
#endif  /* } */

// Libraries from the command line are included in COMMAND_LINE_OBJECTS.

#ifdef USE_PROFILER     /* { */
#ifdef USE_FILEIO       /* { */
#ifdef __WORKAROUNDS_ENABLED    /* { */
#define CRT crtsfpc535y.doj, libprofile535y.dlb, PROFFLAG
#else
#define CRT crtsfpc535.doj, libprofile535.dlb, PROFFLAG
#endif  /* } */
#else
#ifdef __WORKAROUNDS_ENABLED    /* { */
#define CRT crtscp535y.doj, libprofile535y.dlb, PROFFLAG
#else
#define CRT crtscp535.doj, libprofile535.dlb, PROFFLAG
#endif  /* } */
#endif  /* USE_FILEIO */        /* } */
#else
#ifdef USE_FILEIO       /* { */
#ifdef __WORKAROUNDS_ENABLED    /* { */
#define CRT  crtsfc535y.doj
#else
#define CRT  crtsfc535.doj
#endif  /* } */
#else
#ifdef __WORKAROUNDS_ENABLED    /* { */
#define CRT  crtsc535y.doj
#else
#define CRT  crtsc535.doj
#endif  /* } */
#endif  /* USE_FILEIO */        /* } */
#endif  /* USE_PROFILER */      /* } */

#ifdef __WORKAROUNDS_ENABLED    /* { */
#define ENDCRT , crtn535y.doj
#else
#define ENDCRT , crtn535.doj
#endif  /* } */

$OBJECTS = CRT, $COMMAND_LINE_OBJECTS ,cplbtab535.doj ENDCRT;

MEMORY
{
   MEM_PROGRAM          { TYPE(RAM) WIDTH(8) START(0xF0000000) END(0xF002FFFF) }
   MEM_HEAP             { TYPE(RAM) WIDTH(8) START(0xF0030000) END(0xF0037FFF) }

   MEM_PCI_CONFIG       { TYPE(RAM) WIDTH(8) START(0xEEFFFF00) END(0xEEFFFFFF) }
   MEM_PCI_IO_SPACE     { TYPE(RAM) WIDTH(8) START(0xEEFE0000) END(0xEEFEFFFF) }
   MEM_PCI_MEMORY_SPACE { TYPE(RAM) WIDTH(8) START(0xE0000000) END(0xE7FFFFFF) }

   MEM_STACK            { TYPE(RAM) WIDTH(8) START(0xF0038000) END(0xF003FFFF) }

   MEM_SYS_MMRS         { TYPE(RAM) WIDTH(8) START(0xFFC00000) END(0xFFDFFFFF) }
   MEM_L1_SCRATCH       { TYPE(RAM) WIDTH(8) START(0xFFB00000) END(0xFFB00FFF) }
   MEM_L1_CODE          { TYPE(RAM) WIDTH(8) START(0xFFA00000) END(0xFFA03FFF) }
   MEM_L1_DATA_B        { TYPE(RAM) WIDTH(8) START(0xFF900000) END(0xFF903FFF) }
   MEM_L1_DATA_A        { TYPE(RAM) WIDTH(8) START(0xFF800000) END(0xFF803FFF) }
   MEM_ASYNC3           { TYPE(RAM) WIDTH(8) START(0x2C000000) END(0x2FFFFFFF) }
   MEM_ASYNC2           { TYPE(RAM) WIDTH(8) START(0x28000000) END(0x2BFFFFFF) }
   MEM_ASYNC1           { TYPE(RAM) WIDTH(8) START(0x24000000) END(0x27FFFFFF) }
   MEM_ASYNC0           { TYPE(RAM) WIDTH(8) START(0x20000000) END(0x23FFFFFF) }
   MEM_SDRAM3           { TYPE(RAM) WIDTH(8) START(0x18000000) END(0x1FFFFFFF) }
   MEM_SDRAM2           { TYPE(RAM) WIDTH(8) START(0x10000000) END(0x17FFFFFF) }
   MEM_SDRAM1           { TYPE(RAM) WIDTH(8) START(0x08000000) END(0x0FFFFFFF) }
   MEM_SDRAM0           { TYPE(RAM) WIDTH(8) START(0x00000004) END(0x07FFFFFF) }
}


PROCESSOR p0
{
    OUTPUT( $COMMAND_LINE_OUTPUT_FILE )

    RESOLVE(start,0xF0000000)
    KEEP(start,_main)

    SECTIONS
    {
        L1_code
        {
            // Align all code sections on 2 byte boundary
            INPUT_SECTION_ALIGN(2)
            INPUT_SECTIONS( $OBJECTS(L1_code) $LIBRARIES(L1_code))
        } >MEM_L1_CODE

        L1_data_a
        {
            INPUT_SECTION_ALIGN(1)
            INPUT_SECTIONS( $OBJECTS(L1_data_a) $LIBRARIES(L1_data_a))
        } >MEM_L1_DATA_A

        L1_data_b
        {
            INPUT_SECTION_ALIGN(1)
            INPUT_SECTIONS( $OBJECTS(L1_data_b) $LIBRARIES(L1_data_b))
            INPUT_SECTION_ALIGN(4)
            INPUT_SECTIONS( $OBJECTS(.edt) $LIBRARIES(.edt) )
            INPUT_SECTION_ALIGN(4)
            INPUT_SECTIONS( $OBJECTS(.cht) $LIBRARIES(.cht) )
            INPUT_SECTION_ALIGN(4)
            INPUT_SECTIONS( $OBJECTS(.frt) $LIBRARIES(.frt) )
            INPUT_SECTION_ALIGN(4)
            INPUT_SECTIONS( $OBJECTS(.frtl) $LIBRARIES(.frtl) )
        } >MEM_L1_DATA_B

        program
        {
            // Align all code sections on 2 byte boundary
            INPUT_SECTION_ALIGN(4)
            INPUT_SECTIONS( $OBJECTS(program) $LIBRARIES(program))
            INPUT_SECTIONS( $OBJECTS(data1) $LIBRARIES(data1))
            INPUT_SECTIONS( $OBJECTS(cplb) $LIBRARIES(cplb))
            INPUT_SECTIONS( $OBJECTS(cplb_code) $LIBRARIES(cplb_code))
            INPUT_SECTIONS( $OBJECTS(cplb_data) $LIBRARIES(cplb_data))
            INPUT_SECTIONS( $OBJECTS(constdata) $LIBRARIES(constdata))
            INPUT_SECTIONS( $OBJECTS(voldata) $LIBRARIES(voldata))

            INPUT_SECTIONS( $OBJECTS(ctor) $LIBRARIES(ctor) )
            INPUT_SECTIONS( $OBJECTS(ctorl) $LIBRARIES(ctorl) )
            INPUT_SECTION_ALIGN(4)
            INPUT_SECTIONS( $OBJECTS(.gdt) $LIBRARIES(.gdt) )
            INPUT_SECTION_ALIGN(4)
            INPUT_SECTIONS( $OBJECTS(.gdtl) $LIBRARIES(.gdtl) )
        } >MEM_PROGRAM

        bsz ZERO_INIT
        {
            INPUT_SECTION_ALIGN(4)
            INPUT_SECTIONS( $OBJECTS(bsz) $LIBRARIES(bsz))
        } >MEM_L1_DATA_A

        bsz_init
        {
            INPUT_SECTION_ALIGN(4)
            INPUT_SECTIONS( $OBJECTS(bsz_init) $LIBRARIES(bsz_init))
        } >MEM_PROGRAM

        .meminit {} >MEM_PROGRAM

        stack
        {
            ldf_stack_space = .;
            ldf_stack_end = ldf_stack_space + MEMORY_SIZEOF(MEM_STACK);
        } >MEM_STACK

        heap
        {
            // Allocate a heap for the application
            ldf_heap_space = .;
            ldf_heap_end = ldf_heap_space + MEMORY_SIZEOF(MEM_HEAP) - 1;
            ldf_heap_length = ldf_heap_end - ldf_heap_space;
        } >MEM_HEAP

        sdram
        {
        
        } >MEM_SDRAM0

    }
}

⌨️ 快捷键说明

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