从armcc迁移到armclang会导致节类型冲突

由于ARM Keil µVision将其默认编译器从armcc更改为armclang,所以我试图迁移现有项目。通过简单地切换编译器而产生的大多数新错误已在其迁移指南的帮助下轻松清除。但我似乎无法修复以下错误:

Display/icons.c(54): error: 'iconBitMapArray' causes a section type conflict with 'pNULL'
XRAM_VAR GUI_CONST_STORAGE  GUI_BITMAP *iconBitMapArray[] =  // bitmaps for icons
                                        ^
Display/icons.c(44): note: declared here
XRAM_VAR GUI_CONST_STORAGE GUI_BITMAP pNULL =  // used for returning a pointer to a NULL image

以下是相关代码:

#define XRAM_VAR                __attribute__((section("XRAM_DATA")))

XRAM_VAR uint32_t icon_status_internal;
XRAM_VAR GUI_CONST_STORAGE GUI_BITMAP pNULL =  // used for returning a pointer to a NULL image
{
    0,/* XSize */
    0,/* YSize */
    0,/* BytesPerLine */
    0,/* BitsPerPixel */
    0,/* Pointer to picture data (indices) */
    0  /* Pointer to palette */
};

XRAM_VAR GUI_CONST_STORAGE GUI_BITMAP *iconBitMapArray[] =  // bitmaps for icons
{
        &pNULL,&bmIcon1,&bmIcon2,// ...etc.
};

变量icon_status_internal也会导致相同的错误。

这里有几个类似的问题,该错误似乎来自尝试将零初始化数据与被初始化为非零值的数据放在同一部分中。经常提到标志-fno-zero-initialized-in-bss。我尝试将其添加到编译器字符串和链接器字符串中,但这没有帮助。

migration guide的第8页上,当使用链接时间优化(LTO)时,他们建议了两种可能的解决方案。我们没有使用LTO,但无论如何我都尝试过。我尝试将内存分配从默认更改为我们的外部RAM。

从armcc迁移到armclang会导致节类型冲突

这也没有帮助。另一个建议是将部分名称添加到已经存在的分散文件中。

; Just the variables declared using __attribute__((section("XRAM_DATA")))
  RW_XRAM1 0x70000000 0x00010000  {  ; External Ram
   *.o(XRAM_DATA)
  }

使用armcc时,变量被放置在标有“ XRAM_DATA”的Data类型的部分中,没有任何特殊的编译器选项,如在.map文件中所示:>

pNULL                                    0x70000000   Data          20  icons.o(XRAM_DATA)
icon_status_internal                     0x70000014   Data           4  icons.o(XRAM_DATA)
iconBitMapArray                          0x70000018   Data         352  icons.o(XRAM_DATA)

Data一样使用armclang时,如何将所有这些变量放置在外部RAM的armcc类型节中?我可以尝试其他解决方法吗?我是否需要在外部RAM中创建单独的bssdata部分?我还能尝试什么?

jp1004 回答:从armcc迁移到armclang会导致节类型冲突

暂时没有好的解决方案,如果你有好的解决方案,请发邮件至:iooj@foxmail.com
本文链接:https://www.f2er.com/3100436.html

大家都在问