棋子 · 2019年12月16日

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

我正在尝试将现有项目从迁移armcc到armclang 使用Keil。通过简单地切换编译器而产生的大多数新错误已在其迁移指南的帮助下轻松清除。但我似乎无法修复以下错误:

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

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

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

; Just the variables declared using __attribute__((section("XRAM_DATA")))
RW_XRAM1 0x70000000 0x00010000 { ; External Ram
*.o(XRAM_DATA)
}
使用变量时,将其放置在标有“ XRAM_DATA” 的类型部分中,而没有任何特殊的编译器选项,如在文件中所示: armcc 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)
像那样使用时,如何将所有这些变量放置在外部RAM 的类型部分中?我可以尝试其他解决方法吗?我需要创建单独和我的外部RAM板块?我还能尝试什么?

1 个回答 得票排序 · 时间排序
极术小姐姐 · 2019年12月16日

如果你明确的initialise所有的变量 XRAM_DATA?例如 XRAM_VAR uint32_t icon_status_internal = 0;

从AC 6.10开始,我已经能够将所有项目从ARMCC迁移到armclang。

您也可以提供 XRAM_DATA的.map吗?

你的回答
关注数
1
收藏数
0
浏览数
2747
极术小姐姐
极术微信服务号
关注极术微信号
实时接收点赞提醒和评论通知
安谋科技学堂公众号
关注安谋科技学堂
实时获取安谋科技及 Arm 教学资源
安谋科技招聘公众号
关注安谋科技招聘
实时获取安谋科技中国职位信息