aboutsummaryrefslogtreecommitdiff
path: root/softfloat/s_shortShift128Right.c
diff options
context:
space:
mode:
authorAndrew Waterman <waterman@s144.Millennium.Berkeley.EDU>2010-10-15 16:17:53 -0700
committerAndrew Waterman <waterman@s144.Millennium.Berkeley.EDU>2010-10-15 16:17:53 -0700
commitab928baadbfd3316988a3ad5b5d9b84693a8636f (patch)
treeb464ce729d53aeff072ed2c341b06194e9ea174b /softfloat/s_shortShift128Right.c
parentd3cb781e165427412b299b6034289b8458472790 (diff)
downloadspike-ab928baadbfd3316988a3ad5b5d9b84693a8636f.zip
spike-ab928baadbfd3316988a3ad5b5d9b84693a8636f.tar.gz
spike-ab928baadbfd3316988a3ad5b5d9b84693a8636f.tar.bz2
[sim] made softfloat files C instead of C++
Diffstat (limited to 'softfloat/s_shortShift128Right.c')
-rwxr-xr-xsoftfloat/s_shortShift128Right.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/softfloat/s_shortShift128Right.c b/softfloat/s_shortShift128Right.c
new file mode 100755
index 0000000..f7f4ce8
--- /dev/null
+++ b/softfloat/s_shortShift128Right.c
@@ -0,0 +1,16 @@
+
+#include <stdint.h>
+#include "platform.h"
+#include "primitives.h"
+
+struct uint128
+ softfloat_shortShift128Right( uint64_t a64, uint64_t a0, unsigned int count )
+{
+ struct uint128 z;
+
+ z.v64 = a64>>count;
+ z.v0 = a64<<( ( - count ) & 63 ) | a0>>count;
+ return z;
+
+}
+