-
公开(公告)号:CN101482851A
公开(公告)日:2009-07-15
申请号:CN200810247438.4
申请日:2008-12-31
Applicant: 中国科学院计算技术研究所
Abstract: 本发明涉及二进制翻译器中线程共享code cache的替换方法及系统。该方法包括:步骤10,将本地码空间划分成N个相同大小的可替换单元和一个永不替换单元,N为自然数;可替换单元用于进行普通本地码的分配以及实施替换策略,永不替换单元用来保存与线程同步相关的本地码;步骤20,从当前可替换单元中分配本地码,直到当前可替换单元的容量达到上限时再从下一个可替换单元开始分配本地码;步骤30,当本地码空间达到容量的上限时,以可替换单元为单位按照先进先出策略进行本地码替换。本发明提出并实现了多线程code cache的替换方案,这种替换方案可广泛适用于各种体系结构之上的二进制翻译器中,在开销较小的同时保证了线程的并发性。
-
公开(公告)号:CN101482851B
公开(公告)日:2011-02-16
申请号:CN200810247438.4
申请日:2008-12-31
Applicant: 中国科学院计算技术研究所
Abstract: 本发明涉及二进制翻译器中线程共享code?cache的替换方法及系统。该方法包括:步骤10,将本地码空间划分成N个相同大小的可替换单元和一个永不替换单元,N为自然数;可替换单元用于进行普通本地码的分配以及实施替换策略,永不替换单元用来保存与线程同步相关的本地码;步骤20,从当前可替换单元中分配本地码,直到当前可替换单元的容量达到上限时再从下一个可替换单元开始分配本地码;步骤30,当本地码空间达到容量的上限时,以可替换单元为单位按照先进先出策略进行本地码替换。本发明提出并实现了多线程code?cache的替换方案,这种替换方案可广泛适用于各种体系结构之上的二进制翻译器中,在开销较小的同时保证了线程的并发性。
-