A.J*_*.J. 7 performance multithreading intel simd
我有兴趣做一个关于面部识别的项目(使用SIMD指令集).但是在今年的第一学期,我学到了一些关于线程的知识,我想知道我是否可以将它们结合起来.
我什么时候应该避免结合多线程和SIMD指令?什么时候值得呢?
保存x87/MMX/XMM/YMM寄存器可能需要相当长的时间并导致显着的缓存抖动.通常,FP状态的保存和恢复是以惰性方式完成的:在上下文切换时,内核将当前线程记为FP状态的"所有者",并在CR0中设置TS标志 - 这将导致陷阱每当线程尝试执行FP insn时内核.此时,分别保存和恢复旧线程的FP状态和当前正在执行的线程的FP状态.
现在,如果延长的时间段(几个或多个上下文切换)没有其他线程使用FP insns - 惰性策略将导致无法保存/恢复任何FP状态,并且您不会受到性能影响.
由于我们显然是在讨论多处理器系统,因此并行执行算法的线程不会相互冲突,因为它们应该在自己的CPU/core/HT上执行并拥有一组私有寄存器.
TL;博士
您不应该关心保存和恢复FP寄存器的开销.
| 归档时间: | 
 | 
| 查看次数: | 1092 次 | 
| 最近记录: |