mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-13 11:40:25 +03:00
Fix module probe failure on 32-bit systems
Previous commit 7ef5e54e2e
caused
module probe failure on 32-bit systems, dmesg showed
Unknown symbol __moddi3
This was caused by the modulo operation 'gethrtime() % tqs->stqs_count'
in the committed code. Instead of implementing __moddi3 for all 32-bit
systems, Behlendorf advised we can just cast the return value of
gethrtime() into a uint64_t, since gethrtime does not return negative
value on all circumstances we need not care about the potential overflow.
Signed-off-by: Ying Zhu <casualfisher@gmail.com>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #1551
This commit is contained in:
parent
88c283952f
commit
c12936b141
@ -920,7 +920,7 @@ spa_taskq_dispatch_ent(spa_t *spa, zio_type_t t, zio_taskq_type_t q,
|
|||||||
if (tqs->stqs_count == 1) {
|
if (tqs->stqs_count == 1) {
|
||||||
tq = tqs->stqs_taskq[0];
|
tq = tqs->stqs_taskq[0];
|
||||||
} else {
|
} else {
|
||||||
tq = tqs->stqs_taskq[gethrtime() % tqs->stqs_count];
|
tq = tqs->stqs_taskq[((uint64_t)gethrtime()) % tqs->stqs_count];
|
||||||
}
|
}
|
||||||
|
|
||||||
taskq_dispatch_ent(tq, func, arg, flags, ent);
|
taskq_dispatch_ent(tq, func, arg, flags, ent);
|
||||||
@ -943,7 +943,7 @@ spa_taskq_dispatch_sync(spa_t *spa, zio_type_t t, zio_taskq_type_t q,
|
|||||||
if (tqs->stqs_count == 1) {
|
if (tqs->stqs_count == 1) {
|
||||||
tq = tqs->stqs_taskq[0];
|
tq = tqs->stqs_taskq[0];
|
||||||
} else {
|
} else {
|
||||||
tq = tqs->stqs_taskq[gethrtime() % tqs->stqs_count];
|
tq = tqs->stqs_taskq[((uint64_t)gethrtime()) % tqs->stqs_count];
|
||||||
}
|
}
|
||||||
|
|
||||||
id = taskq_dispatch(tq, func, arg, flags);
|
id = taskq_dispatch(tq, func, arg, flags);
|
||||||
|
Loading…
Reference in New Issue
Block a user