diff options
author | MITSUNARI Shigeo <herumi@nifty.com> | 2016-09-14 14:37:17 +0800 |
---|---|---|
committer | MITSUNARI Shigeo <herumi@nifty.com> | 2016-09-14 14:37:17 +0800 |
commit | b68d2820825b3e90302d452fed9f28bfed9668fe (patch) | |
tree | dde435ac75fd88a492fcac3947b612627d5dc675 | |
parent | 11557e8e6001d28afdca1b5aa78b075e0c8defc3 (diff) | |
download | dexon-bls-b68d2820825b3e90302d452fed9f28bfed9668fe.tar dexon-bls-b68d2820825b3e90302d452fed9f28bfed9668fe.tar.gz dexon-bls-b68d2820825b3e90302d452fed9f28bfed9668fe.tar.bz2 dexon-bls-b68d2820825b3e90302d452fed9f28bfed9668fe.tar.lz dexon-bls-b68d2820825b3e90302d452fed9f28bfed9668fe.tar.xz dexon-bls-b68d2820825b3e90302d452fed9f28bfed9668fe.tar.zst dexon-bls-b68d2820825b3e90302d452fed9f28bfed9668fe.zip |
bls_if stack version
-rw-r--r-- | include/bls_if.h | 20 | ||||
-rw-r--r-- | src/bls_if.cpp | 4 | ||||
-rw-r--r-- | test/bls_if_test.cpp | 22 |
3 files changed, 41 insertions, 5 deletions
diff --git a/include/bls_if.h b/include/bls_if.h index 7872778..79885a0 100644 --- a/include/bls_if.h +++ b/include/bls_if.h @@ -14,15 +14,27 @@ extern "C" { #endif -typedef struct blsSecretKey blsSecretKey; -typedef struct blsPublicKey blsPublicKey; -typedef struct blsSign blsSign; -typedef struct blsId blsId; +typedef struct { + uint64_t buf[4]; +} blsId; + +typedef struct { + uint64_t buf[4]; +} blsSecretKey; + +typedef struct { + uint64_t buf[4 * 2 * 3]; +} blsPublicKey; + +typedef struct { + uint64_t buf[4 * 3]; +} blsSign; void blsInit(void); blsId *blsIdCreate(void); void blsIdDestroy(blsId *id); +void blsIdPut(const blsId *id); void blsIdCopy(blsId *dst, const blsId *src); // return 0 if success diff --git a/src/bls_if.cpp b/src/bls_if.cpp index 7576c93..c64e868 100644 --- a/src/bls_if.cpp +++ b/src/bls_if.cpp @@ -57,6 +57,10 @@ void blsIdDestroy(blsId *id) { delete (bls::Id*)id; } +void blsIdPut(const blsId *id) +{ + std::cout << *(const bls::Id*)id << std::endl; +} void blsIdCopy(blsId *dst, const blsId *src) { *((bls::Id*)dst) = *((const bls::Id*)src); diff --git a/test/bls_if_test.cpp b/test/bls_if_test.cpp index 6c6e549..c2dc0a9 100644 --- a/test/bls_if_test.cpp +++ b/test/bls_if_test.cpp @@ -7,7 +7,6 @@ CYBOZU_TEST_AUTO(bls_if) blsSecretKey *sec; blsPublicKey *pub; blsSign *sign; -// blsId *id; const char *msg = "this is a pen"; const size_t msgSize = strlen(msg); @@ -30,3 +29,24 @@ CYBOZU_TEST_AUTO(bls_if) blsPublicKeyDestroy(pub); blsSecretKeyDestroy(sec); } + +CYBOZU_TEST_AUTO(bls_if_use_stack) +{ + blsSecretKey sec; + blsPublicKey pub; + blsSign sign; + const char *msg = "this is a pen"; + const size_t msgSize = strlen(msg); + + blsInit(); + blsSecretKeyInit(&sec); + blsSecretKeyPut(&sec); + + blsSecretKeyGetPublicKey(&sec, &pub); + blsPublicKeyPut(&pub); + + blsSecretKeySign(&sec, &sign, msg, msgSize); + blsSignPut(&sign); + + printf("verify %d\n", blsSignVerify(&sign, &pub, msg, msgSize)); +} |