summaryrefslogtreecommitdiffstats
path: root/crypto/curve25519_openssl.cc
diff options
context:
space:
mode:
Diffstat (limited to 'crypto/curve25519_openssl.cc')
-rw-r--r--crypto/curve25519_openssl.cc25
1 files changed, 25 insertions, 0 deletions
diff --git a/crypto/curve25519_openssl.cc b/crypto/curve25519_openssl.cc
new file mode 100644
index 0000000..067e19c
--- /dev/null
+++ b/crypto/curve25519_openssl.cc
@@ -0,0 +1,25 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "crypto/curve25519.h"
+
+#include <openssl/curve25519.h>
+
+namespace crypto {
+
+namespace curve25519 {
+
+bool ScalarMult(const uint8_t* private_key,
+ const uint8_t* peer_public_key,
+ uint8_t* shared_key) {
+ return !!X25519(shared_key, private_key, peer_public_key);
+}
+
+void ScalarBaseMult(const uint8_t* private_key, uint8_t* public_key) {
+ X25519_public_from_private(public_key, private_key);
+}
+
+} // namespace curve25519
+
+} // namespace crypto