检测该进程当前所在处理器是否可以执行该进程,如果可以则返回1,否则返回0
#define cpus_equal(src1, src2) __cpus_equal(&(src1), &(src2), NR_CPUS)
static inline int __cpus_equal(const cpumask_t *src1p,
const cpumask_t *src2p, int nbits)
{
return bitmap_equal(src1p->bits, src2p->bits, nbits);
}
static inline int bitmap_equal(const unsigned long *src1,
const unsigned long *src2, int nbits)
{
if (nbits <= BITS_PER_LONG)
return ! ((*src1 ^ *src2) & BITMAP_LAST_WORD_MASK(nbits));
else
return __bitmap_equal(src1, src2, nbits);
}
#define BITMAP_LAST_WORD_MASK(nbits) /
( /
((nbits) % BITS_PER_LONG) ? /
(1UL<<((nbits) % BITS_PER_LONG))-1 : ~0UL /
)
假设nbits = 5; 则
1UL<<((nbits) % BITS_PER_LONG) 100000
(1UL<<((nbits) % BITS_PER_LONG))-1 11111
注:
(1)
-----------------------------------
^ 位异或 对应的两位相异为1,相同为0
(2)
-----------------------------------
src1中有多位为1 -- 可以执行该进程的CPU掩码集
src2中只有1位为1 -- 该进程当前所在处理器的位图
*src1 ^ *src2 运算结果,如果src2中的1所在位为0,表明该进程可以在该当前处理器上运行
(*src1 ^ *src2) & BITMAP_LAST_WORD_MASK(nbits) 运算结果为0
#define cpus_equal(src1, src2) __cpus_equal(&(src1), &(src2), NR_CPUS)
static inline int __cpus_equal(const cpumask_t *src1p,
const cpumask_t *src2p, int nbits)
{
return bitmap_equal(src1p->bits, src2p->bits, nbits);
}
static inline int bitmap_equal(const unsigned long *src1,
const unsigned long *src2, int nbits)
{
if (nbits <= BITS_PER_LONG)
return ! ((*src1 ^ *src2) & BITMAP_LAST_WORD_MASK(nbits));
else
return __bitmap_equal(src1, src2, nbits);
}
#define BITMAP_LAST_WORD_MASK(nbits) /
( /
((nbits) % BITS_PER_LONG) ? /
(1UL<<((nbits) % BITS_PER_LONG))-1 : ~0UL /
)
假设nbits = 5; 则
1UL<<((nbits) % BITS_PER_LONG) 100000
(1UL<<((nbits) % BITS_PER_LONG))-1 11111
注:
(1)
-----------------------------------
^ 位异或 对应的两位相异为1,相同为0
(2)
-----------------------------------
src1中有多位为1 -- 可以执行该进程的CPU掩码集
src2中只有1位为1 -- 该进程当前所在处理器的位图
*src1 ^ *src2 运算结果,如果src2中的1所在位为0,表明该进程可以在该当前处理器上运行
(*src1 ^ *src2) & BITMAP_LAST_WORD_MASK(nbits) 运算结果为0
974

被折叠的 条评论
为什么被折叠?



