gem5的pyton文件和c++文件很多,不同层级的文件让人很困扰,这里根据armgem5的作者提供的教程做一个统一的划分: python script, python objects, c++ objects.
如下图.
很多时候,一个fs.py的python script会调用很多其他的scritpt.py的文件的设置,然后才是python objects的调用.
script 在cofigs/ 文件夹下.
python objects则在src文件夹下.
很多时候, script文件不好读是因为它并没有一个强逻辑关系,每个作者的自定义程度比较高. python objects的api又没有很好的提供,我们就得遵循已有的script的思路去调整.
不然就得从下往上 读懂所有python object 才能调整,这样事倍功半.
还有一个很关键的因素,所有的c++objects是用pybind11和python交互的,也就是python不会有c++的细节,但是每个c++在pyton object里都有名字,这样才能用python调用.
关系是: 用户自定义的 python script 调用了gem5 作者们写好的python objects 文件,其中一部分(或者说大部分)python objects的细节功能不在python里,而是用c++ object实现.
如果改python script,更像是做一些学习实验,如果改python object,相当于改一些调用方式,但还是复用了gem5 已有的功能,如果要加新功能,就得去改c++的objects.