zoukankan      html  css  js  c++  java
  • BREW AMR 编译错误 L6248E

           主要是由于使用全局变量造成的, 如果要使用全局数组,如 int a[ ] = {1,2,3 };

    请在前面加上const , 如下const static int a[ ] = {1,2,3 }; 请勿使用全局指针.

    This linker error can occur when trying to build "Position Independent" code. Consider a small example like:

    #include <stdio.h>
    char *str = "test";
    int main(void)
    {
    printf ("%s",str);
    }

    when compiled and linked with:

    armcc -c -apcs /ropi pi.c
    armlink -ropi pi.o

    the linker will report a message of the form:

    Error: L6248E: pi.o(.data) in ABSOLUTE region 'ER_RW' cannot have address/offset type
    relocation to .constdata in PI region 'ER_RO'.

    For the code above, the compiler generates a global pointer "str" to the char string "test". The global pointer "str" will need to be initialized to the address of the char string "test" in the .constdata section. However, absolute addresses cannot be used in a PI system, so the link step fails, because of the ABS32 relocations to (position independent) .constdata.

    To resolve this, you must re-write the code to avoid the explicit pointer. Two possible ways are shown below:

    1) Use a global array instead of a global pointer:

    #include <stdio.h>
    const char str[] = "test";
    int main(void)
    {
    printf ("%s",str);
    }

    2) Use a local pointer instead of a global pointer:

    #include <stdio.h>
    int main(void)
    {
    char *str = "test";
    printf ("%s",str);
    }

    Please note that if you are using a list with multiple elements, such as:

    char * list[] = {"zero", "one", "two"};

    You will get a separate link error for each element in the array. In this case, the recommended solution is:

    char list[3][5] = {"zero", "one", "two"};

    with the print instruction being (for example):

    printf("%s", list[1]);

    Note that you will need to declare a two dimensional array for the list, with the first dimension as the number of elements in the array, and the second dimension as the maximum size for an element in the array.

     
  • 相关阅读:
    中国剩余定理(普通+扩展)
    因子和(洛谷P1593)——约数和+分解质因数
    暑假考试题6:problem 题(Catlan + dp + 组合数)
    暑假考试题6:single 单(树上推理)
    暑假考试题5:tree 最小生成树(最小生成树+倍增)
    暑假考试题5:序列(分类讨论水题)
    暑假考试题5:工作 work(贪心+二分)
    暑假考试题4:砍树 cut(整除分块)
    4.8 作业
    面向对象编程
  • 原文地址:https://www.cnblogs.com/secbook/p/2655510.html
Copyright © 2011-2022 走看看