aboutsummaryrefslogtreecommitdiff
path: root/libcmix-bignum/bignum.h
diff options
context:
space:
mode:
authorDennis Brentjes <d.brentjes@gmail.com>2016-10-04 12:18:35 +0200
committerDennis Brentjes <d.brentjes@gmail.com>2016-10-04 12:18:35 +0200
commit4f2c980343b321e7fccf48190c32bfb4bca426f4 (patch)
treee08d299dc9da1976c8924207f9cbfbc8bd06709a /libcmix-bignum/bignum.h
parentad3d46b0b6ca285bbaf1540e9805714addfeb9af (diff)
downloadcmix-4f2c980343b321e7fccf48190c32bfb4bca426f4.tar.gz
cmix-4f2c980343b321e7fccf48190c32bfb4bca426f4.tar.bz2
cmix-4f2c980343b321e7fccf48190c32bfb4bca426f4.zip
Added a bignum library to abstract possible implementations.
Diffstat (limited to 'libcmix-bignum/bignum.h')
-rw-r--r--libcmix-bignum/bignum.h40
1 files changed, 40 insertions, 0 deletions
diff --git a/libcmix-bignum/bignum.h b/libcmix-bignum/bignum.h
new file mode 100644
index 0000000..02efcf7
--- /dev/null
+++ b/libcmix-bignum/bignum.h
@@ -0,0 +1,40 @@
+#pragma once
+
+#include <stddef.h>
+#include <stdlib.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+enum bignum_error {
+ NoError = 0,
+ error = -1
+};
+
+struct Bignum {
+ unsigned char* data;
+ size_t len;
+};
+
+struct Bignum allocate_bignum(size_t len) {
+ return (struct Bignum){
+ (unsigned char*) malloc(len),
+ len
+ };
+}
+
+void free_bignum(struct Bignum* b) {
+ free(b->data);
+ b->data = 0;
+ b->len = 0;
+}
+
+extern enum bignum_error get_curve25519_mod(struct Bignum* result);
+
+extern enum bignum_error multiply_mod(struct Bignum* result, struct Bignum const lh, struct Bignum const rh, struct Bignum const mod);
+
+
+#ifdef __cplusplus
+}
+#endif \ No newline at end of file