[发明专利]一种用于众核系统的数据相关性线程分组映射方法有效

专利信息
申请号: 201610188032.8 申请日: 2016-03-29
公开(公告)号: CN105808358B 公开(公告)日: 2019-10-18
发明(设计)人: 董小社;巨涛;张兴军;陈衡;党博超;吴树森 申请(专利权)人: 西安交通大学
主分类号: G06F9/50 分类号: G06F9/50
代理公司: 西安通大专利代理有限责任公司 61200 代理人: 陆万寿
地址: 710049 陕*** 国省代码: 陕西;61
权利要求书: 查看更多 说明书: 查看更多
摘要: 发明公开了一种用于众核系统的线程数据相关性分组映射方法,该方法通过计算数据重用距离分析应用程序线程内部数据局部性,用线程相关性矩阵度量不同线程间的数据相关性;根据应用程序的数据相关性及众核处理器架构特点,利用最小生成树将应用线程分为能反映不同线程数据相关性逻辑组。最终实现线程到具体处理器不同处理核硬件线程的合理映射,降低线程间共享存储访问冲突,减少额外传输开销,为充分利用众核系统计算资源,提升程序计算性能提供了一个有效的解决方法。
搜索关键词: 一种 用于 系统 数据 相关性 线程 分组 映射 方法
【主权项】:
1.一种用于众核系统的线程数据相关性分组映射方法,其特征在于,包括如下步骤:1)根据运行平台所支持的最大硬件线程数,采用均匀分配的方法将应用程序划分为相应数量的应用线程;2)并行统计每个线程的存储访问数据,采用将访问数据插入平衡二叉树的方式,在插入数据结点的同时计算数据重用距离,并将相应数据重用信息记录在对应的数据结点内;线程数据重用距离指相同访问数据最近两次访问间隔内不同访问数据的个数;3)遍历生成的平衡二叉树,计算反映整个线程数据局部性的线程平均数据重用距离;4)根据线程平均数据重用距离,标识出不同线程的局部性模式,不同的局部性模式反映不同线程内部数据局部性特点;数据局部性模式定义如下:DSP:RDj<Dmin,该模式为数据共享模式,数据重用距离RDj小于阈值Dmin线程所访问数据的时间局部性好;DIP:RDj>Dmax,该模式为数据无关模式,数据重用距离RDj大于阈值Dmax,线程所访问数据的时间局部性差,数据之间相互独立,无数据相关性;DDP:Dmin≤RDj≤Dmax,该模式为数据相关模式,数据重用距离RDj介于阈值Dmin与Dmax之间,线程所访问数据之间存在数据依赖关系;其中Dmin及Dmax为反映不同数据访存特点的数据重用距离阈值;5)以线程数据局部性模式为依据,将线程归并为不同的模式类;统计同一模式类内不同线程间相同数据的访问量,用线程相关性矩阵Affinity Matrix度量不同线程之间的数据相关性;线程相关性矩阵反映了不同线程间的数据共享特性,矩阵行和列标分别代表不同的线程ID,矩阵中的每个元素值代表对应行列所指线程间的数据共享量;6)将相关性矩阵转化成能直观反映线程之间局部性的相关性图AffinityGraph;7)将线程相关性图和具体的硬件运行平台存储层次架构图相结合,将线程相关性图分解成K棵子树,实现将具有高数据共享的线程划分到同一个线程组内,将具有较强数据访问争用关系的线程划分到不同的线程组内;8)根据众核处理器架构特点,通过静态绑定线程组到处理核的方法,实现应用线程到众核处理器处理核不同硬件线程的映射;具体映射方法为:8‑1)将同一线程组中的应用线程尽量分配到同一个处理核的不同硬件线程之上;如果该处理核线程已经全部分配,则将应用线程分配到相邻处理核的硬件线程之上;8‑2)将不同线程组中的应用线程分配到不同处理核的硬件线程之上,使无共享数据的线程分散到具有独立cache空间的不同处理核。
下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于西安交通大学,未经西安交通大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/patent/201610188032.8/,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top