It recently came to my attention, while trying to optimize performance of some linux code, that setting CPU affinity with "taskset" was helpful.
But one sets affinity to a processor by CPU number and that made me wonder:
reading/writing 2,000,000 times between two processes on core 0 real 0m3.916s user 0m0.643s sys 0m3.275s reading/writing 2,000,000 times between a processes on core 0 and core 1 real 0m5.911s user 0m0.607s sys 0m6.508s reading/writing 2,000,000 times between a processes on core 0 and core 2 real 0m12.159s user 0m0.716s sys 0m12.054s reading/writing 2,000,000 times between a processes on core 0 and core 3 real 0m11.882s user 0m0.690s sys 0m11.830s
The microbenchmark consists of two processes connected bi-directionally by pipes where the first writes one byte to the second and the second writes it back to the first. If these processes are assigned to different CPUs (or cores) there are clearly significant (and significantly differing) overheads involved. Probably for many real workloads, the differences are less significant.
Email -- corey @ u.washington.edu
Web -- http://staff.washington.edu/co rey/
Date -- Mon May 21 13:29:16 PDT 2007