minix/lib/nbsd_libminlib/u64util.c
Gianluca Guida 878ba523ac Add libminlib for NBSD libc compilation.
This library includes various random and minix-specific functions
included in the Minix libc. Most of them should be part of libsys,
and in general it would be nice to extinguish this library over
time.
2011-03-22 13:47:35 +00:00

112 lines
1.5 KiB
C

/* Few u64 utils implemented in C
* Author: Gautam BT
*/
#include <minix/u64.h>
#if !defined(__LONG_LONG_SUPPORTED)
u64_t rrotate64(u64_t x, unsigned short b)
{
u64_t r, t;
b %= 64;
if(b == 32) {
r.lo = x.hi;
r.hi = x.lo;
return r;
}else if(b < 32) {
r.lo = (x.lo >> b) | (x.hi << (32 - b));
r.hi = (x.hi >> b) | (x.lo << (32 - b));
return r;
}else {
/* Rotate by 32 bits first then rotate by remaining */
t.lo = x.hi;
t.hi = x.lo;
b = b - 32;
r.lo = (t.lo >> b) | (t.hi << (32 - b));
r.hi = (t.hi >> b) | (t.lo << (32 - b));
return r;
}
}
u64_t rshift64(u64_t x, unsigned short b)
{
u64_t r;
if(b >= 64)
return make64(0,0);
if(b >= 32) {
r.hi = 0;
r.lo = x.hi >> (b - 32);
}else {
r.lo = (x.lo >> b) | (x.hi << (32 - b));
r.hi = (x.hi >> b);
}
return r;
}
u64_t xor64(u64_t a, u64_t b)
{
u64_t r;
r.hi = a.hi ^ b.hi;
r.lo = a.lo ^ b.lo;
return r;
}
u64_t and64(u64_t a, u64_t b)
{
u64_t r;
r.hi = a.hi & b.hi;
r.lo = a.lo & b.lo;
return r;
}
u64_t not64(u64_t a)
{
u64_t r;
r.hi = ~a.hi;
r.lo = ~a.lo;
return r;
}
#else
#if !defined(__LONG_LONG_SUPPORTED)
#error "ERROR: These functions require long long support"
#endif
u64_t rrotate64(u64_t x, unsigned short b)
{
b %= 64;
if ((b &= 63) == 0)
return x;
return (x >> b) | (x << (64 - b));
}
u64_t rshift64(u64_t x, unsigned short b)
{
if (b >= 64)
return 0;
return x >> b;
}
u64_t xor64(u64_t a, u64_t b)
{
return a ^ b;
}
u64_t and64(u64_t a, u64_t b)
{
return a & b;
}
u64_t not64(u64_t a)
{
return ~a;
}
#endif