summaryrefslogtreecommitdiff
path: root/src/lib/libc/stdlib/lrand48.c
diff options
context:
space:
mode:
authorjsing <>2023-01-31 05:48:39 +0000
committerjsing <>2023-01-31 05:48:39 +0000
commit71b4fbce2cf289a907bfac8e3abd6b7282d66981 (patch)
treeef7e412f740877e380f978d13e04e25f0af2bb54 /src/lib/libc/stdlib/lrand48.c
parent1577bb088bd6ac8a2578ab2e8af7f0ed8cbb1584 (diff)
downloadopenbsd-71b4fbce2cf289a907bfac8e3abd6b7282d66981.tar.gz
openbsd-71b4fbce2cf289a907bfac8e3abd6b7282d66981.tar.bz2
openbsd-71b4fbce2cf289a907bfac8e3abd6b7282d66981.zip
Provide bn_umul_hilo().
The bignum code needs to be able to multiply two words, producing a double word result. Some architectures do not have native support for this, hence a pure C version is required. bn_umul_hilo() provides this functionality. There are currently two implementations, both of which are branch free. The first uses bitwise operations for the carry, while the second uses accumulators. The accumulator version uses fewer instructions, however requires more variables/registers and seems to be slower, at least on amd64/i386. The accumulator version may be faster on architectures that have more registers available. Further testing can be performed and one of the two implementations can be removed at a later date. ok tb@
Diffstat (limited to 'src/lib/libc/stdlib/lrand48.c')
0 files changed, 0 insertions, 0 deletions