昨天帮新人同事解决了一个文件编译的问题,在此做下记录
SV中提供了一种基于package生成编译单元的方式,通常用于将某一功能集中的uvc封装在一个package中,这样便于在其他环境中复用。
为了避免在文件中可能出现的多次重复包含同一头文件导致的编译失败,sv中也使用了头文件保护宏的方式,避免同一个类被多次声明产生编译错误。然而有的时候,由于验证人员的疏忽,在需要产生一个新的uvc的情况下,可能会采用copy代码的方式,从另一个相似的uvc来产生新的uvc,但是却忘记修改头文件的保护宏。这样就会导致在一个同时需要这两个uvc的验证环境中,因为头文件保护宏的相同,总会有一个uvc无法被环境吃进来,从而导致例化的时候失败,提示例化使用的名字不是一个有效的类名。然而在debug的时候发现,环境所需的文件列表里面明明是把两个uvc的filelist都吃进来了,但是却出现了无法识别类名的情况。原因就是因为在前一个宏定义有效之后,第二个类名uvc_name2就根本不会被声明,环境也就不知道uvc_name2是一个类,自然就是无效的。