图1
如图1,IAR提示 E2PROM_Fifo_Type 类型未定义,但是从 source insight 看 E2PROM_Fifo_Type是有定义的(如图2)
图2
这个问题排查了好久,最后发现,我之前在从 AC6 文件夹中,把 event.h 拷贝到 Positec 文件夹后,忘记删除 AC6 文件夹中的 event.h(如图3),AC6/event.h(如图4)E2PROM_Fifo_Type 被 #if 0 屏蔽掉了
图3
图4
如图5,图6,IAR识别头文件,是通过 option 中的头文件路径,优先识别排在前面的头文件路径,并以排在前面的头文件路径为准。也就是是说,AC6/event.h 和 Positec/event.h ,由于在IAR中的option 中的头文件路径中,AC6文件夹,排在 Positec 文件夹前面,所以 AC6/event.h 为准,Positec/event.h 被屏蔽了(虽然 Positec 文件夹也有 event.h,但是该 event.h 是被编译器忽略,或者说略过了),编译器认定编译的 event.h 就是 AC6文件夹的 event.h,其他同名的 event.h 全部被编译器忽略。
图5
图6
为了验证上述结论,我们在 IAR 的 option 中,把 AC6头文件路径,和 Positec头文件路径 对换一下现后顺序,如图7,这样编译就通过了(编译 0个 错误)。也就是说,现在编译器认定的是 Positec/event.h,编译器编译的是 Positec/event.h,而不是 AC6/event.h。
图7