偶然刷到这个问题,我研究生期间写过SMT的乱序核,我来答! ***设有一个核:这个核上有四个Function Unit,暂且就理解成,两个整数ALU,两个浮点ALU好了。
有一个程序正在运行,这个程序因为ILP(instruction level parallelis)不够多,或者是这个程序只有整数运算,没有浮点运算,所以只能部分的占用核上的***,浪费掉另一部分***(我们把它叫做horizontal waste)。
又比如说,这个程序有很多很多的cache miss,造成了 运行一…。
偶然刷到这个问题,我研究生期间写过SMT的乱序核,我来答! ***设有一个核:这个核上有四个Function Unit,暂且就理解成,两个整数ALU,两个浮点ALU好了。
有一个程序正在运行,这个程序因为ILP(instruction level parallelis)不够多,或者是这个程序只有整数运算,没有浮点运算,所以只能部分的占用核上的***,浪费掉另一部分***(我们把它叫做horizontal waste)。
又比如说,这个程序有很多很多的cache miss,造成了 运行一…。