求助:关于多线程同步的问题
phpskycn2011/01/30软件综合 IP:广东
处理器提供8个逻辑处理器,其中CPU0-3是物理核心,CPU4-7是SMT技术虚拟出来的。原本采用8线程同步工作的方式,但是CPU4-7性能普遍要弱一些,却同样要占用一定的L1、L2、L3 Cache。现在希望能让运行于同一核心上的线程去完成同一个任务。但是需要知道如何得知线程运行在哪个逻辑处理器。以确保正确分配,并避免跨核心调用缓存造成的延迟。
来自:计算机科学 / 软件综合
4
已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
小俊
14年0个月前 IP:未同步
277647
SMT虚拟出来的核较弱?应该不会有这样的情况。实际上SMT是把一个物理核模拟成两个逻辑核,两个之间应该是对等的。
要指定线程在哪个核中执行的话,可以用SetThreadAffinityMask函数设定线程亲核性(带两个参数,第一个是线程句柄,第二个是mask,每个位代表一个核)。不过距我试验,指定线程在某个核上运行,比操作系统自行分配时的性能要稍低,一般还是不推荐使用,除非遇到必须依赖线程亲核性的情况,例如线程里用到Time Stamp等CPU核私有的资源。
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
phpskycn作者
14年0个月前 IP:未同步
277914
SMT虚拟出来的核性能低基于Fritz Benchmark测试的结果。当时开启8个Fritz Benchmark,每个设定为使用1个线程,再指定每个进程使用一个CPU。测试表明运行于CPU0-3时性能比运行为CPU4-7时高出不少。不过由于内存可能不足(空余1600MB)造成影响。现在有4GB了明天重新测试一下。我是希望避免跨核心调用L2缓存。。。
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
phpskycn作者
14年0个月前 IP:未同步
278291
基于Linpack的测试
限制每个程序只能使用1CPU,1线程
捕获02.jpg
很明显测试结果有比较大的波动,平时测试100次时波动在+-2GFlops内
内存足够使用
捕获01.jpg
( 只运行一个测试的结果,此时CPU频率略微提高……)
以前使用Fritz Benchmark结果亦然
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论

想参与大家的讨论?现在就 登录 或者 注册

所属专业
上级专业
同级专业
phpskycn
专家 老干部 学者 机友 笔友
文章
402
回复
4591
学术分
8
2009/03/15注册,2个月6天前活动

CV

主体类型:个人
所属领域:无
认证方式:手机号
IP归属地:未同步
文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
支持的图片格式:jpg, jpeg, png
插入公式
评论控制
加载中...
文号:{{pid}}
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}