keil5编译时报错error: L6235E: More than one section matches selector - cannot all be FIRST/LAST.的问题解决方法
遇到这个问题的小伙伴们不要急,跟着我做,让我们来一步一步解决吧!
首先我们通过有道翻译,如下图:
来看看section matches selector又是什么意思
ps:每个小括号都是解答前面术词或句子的意思。
通过翻译我们知道这个错误是由于有多个“部分(段)匹配选择器”(用于段分配的代码文件)同时存在(通过这句话“不能都是第一/最后”我们能知道是由于它们同时存在所以出问题了),或是文件里的内容(代码)起的作用是相同的(作用相同,起了冲突),所以导致了这个错误。
部分匹配选择器说的是段分配选择器,这个选择器说的是那些起到内存分配(选择)作用的文件。
一般来讲出现这种错误是因为有多个起段分配作用的文件里的内容相同了,所以导致编译时,这些起配置并具有启动作用的文件起冲突了(重复了),这些文件一般都是后缀为.s的启动代码文件。
那既然我们知道这个部分匹配选择器就是启动代码文件,那根据keil5报的错误,我们可以知道,这个错误是因为我们有多个启动代码文件,它们同时存在在同一个工程里才导致的错误。那么我们就来解决这个问题吧!
所以,如果添加了多个启动代码就会出现这种情况,如下图:
我有两个启动代码文件,一个是S3C2440.s,一个是2440init.s。
可以看到,现在它们都被我添加到工程里了,下面也报出了这个错误。
那按照我们的方法试着将其中一个去掉,然后再编译链接看看能不能成功通过,结果如下图:
这可以看到,我去掉了S3C2440.s这个启动代码,只用一个启动代码文件2440init.s,但是编译时又给我报错了,不用急,我们先去翻译一下这个错误是啥意思先,如下图:
我们可以看到,这里说在我们的2440init.s文件通过编译生成的2440init.o中,用了两个未定义的标识符(函数或变量),那目标文件2440init.o我们肯定是不会先去看的,我们先去看看2440init.s文件,看看是哪里用了,如下图:
不知道怎么找了吧,不用急,这里教你们怎么在工程里使用关键字搜索你想要的。
打开2440init.s文件,按Ctrl+F,也可以点击Edit–>Find,在弹出的窗口最上方选项卡栏点击Find in Files,如下图:
在弹出的窗口最上方选项卡栏点击Find in Files,在 Find what 里输入你想找的关键字,然后点击 Find All。
这里我们就输入我们想要找到的那个标识符就行了,如下图:
然后下面就会显示找到的信息,它们都在哪里出现过,双击任意一条都能跳到它出现的位置。
果然!这里我们可以看到确实两条没有定义的标识符都在这里被引用了!而且从上面的注释可以看出,这两个标识符还是从其他文件引进来用的!如下图:
那它们是在哪里被定义的呢~?
哦~!我记起来了,我还有一个配套的文件忘记添加进来了,这个启动代码还需要一个文件才行,它俩是配套形成启动文件的!
那文件是2440slib.s赶紧把它加进来再编译看看!如下图:
果然!通过了!没有错误,那我们就再去2440slib.s文件里搜索一下这两个标记符,看看是不是在这里定义的!验证一波!如下图:
果然就是在这里面定义的两个函数!而且还挨在一起!
那么,接下来我们就换另外那个启动代码来试试看吧,看看能不能编译通过吧!如下图:
耶✌!很顺利的就通过了!没有错误!
总结:去掉工程里多余的启动代码,留下一个启动代码就行,最好就用新建项目时自动添加的启动代码就行!
注意:启动代码要用对应芯片类型一致的,别拿了其他芯片的启动代码用在另一个芯片上,那样又会有其他的错误哦!
对了!附加一个添加和移除工程内文件的操作教程给你们,操作步骤如下图:
添加目录操作
选中右键
添加文件操作
选中右键
删除文件操作
选中右键