diff mbox

[API-NEXT,PATCHv2,3/4] linux-generic: crypto: implement crypto capabilities and random kind

Message ID 1477432992-21770-3-git-send-email-bill.fischofer@linaro.org
State Superseded
Headers show

Commit Message

Bill Fischofer Oct. 25, 2016, 10:03 p.m. UTC
Add random kind related values to odp_crypto_capability() and implement
this selector field in odp_random_data(). Since odp-linux uses the
OpenSSL RAND_bytes() API, the highest kind of random data supported by
this implementation is ODP_RAND_CRYPTO.

Signed-off-by: Bill Fischofer <bill.fischofer@linaro.org>

---
 platform/linux-generic/odp_crypto.c | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)

-- 
2.7.4
diff mbox

Patch

diff --git a/platform/linux-generic/odp_crypto.c b/platform/linux-generic/odp_crypto.c
index c7431e6..f7e380e 100644
--- a/platform/linux-generic/odp_crypto.c
+++ b/platform/linux-generic/odp_crypto.c
@@ -618,6 +618,9 @@  int odp_crypto_capability(odp_crypto_capability_t *capa)
 
 	capa->max_sessions = MAX_SESSIONS;
 
+	capa->max_kind      = ODP_RAND_CRYPTO;
+	capa->max_kind_size = 0;
+
 	return 0;
 }
 
@@ -872,9 +875,13 @@  int odp_crypto_term_global(void)
 }
 
 int32_t
-odp_random_data(uint8_t *buf, int32_t len, odp_bool_t use_entropy ODP_UNUSED)
+odp_random_data(uint8_t *buf, int32_t len, odp_rand_kind_t kind)
 {
 	int32_t rc;
+
+	if (kind > ODP_RAND_CRYPTO)
+		return -1;
+
 	rc = RAND_bytes(buf, len);
 	return (1 == rc) ? len /*success*/: -1 /*failure*/;
 }