提交 95ec01ba 编写于 作者: J James Bottomley 提交者: Herbert Xu

crypto: ecdh - fix to allow multi segment scatterlists

Apparently the ecdh use case was in bluetooth which always has single
element scatterlists, so the ecdh module was hard coded to expect
them.  Now we're using this in TPM, we need multi-element
scatterlists, so remove this limitation.
Signed-off-by: NJames Bottomley <James.Bottomley@HansenPartnership.com>
Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
上级 a7d85e06
...@@ -89,12 +89,19 @@ static int ecdh_compute_value(struct kpp_request *req) ...@@ -89,12 +89,19 @@ static int ecdh_compute_value(struct kpp_request *req)
if (!shared_secret) if (!shared_secret)
goto free_pubkey; goto free_pubkey;
copied = sg_copy_to_buffer(req->src, 1, public_key, /* from here on it's invalid parameters */
public_key_sz);
if (copied != public_key_sz) {
ret = -EINVAL; ret = -EINVAL;
/* must have exactly two points to be on the curve */
if (public_key_sz != req->src_len)
goto free_all;
copied = sg_copy_to_buffer(req->src,
sg_nents_for_len(req->src,
public_key_sz),
public_key, public_key_sz);
if (copied != public_key_sz)
goto free_all; goto free_all;
}
ret = crypto_ecdh_shared_secret(ctx->curve_id, ctx->ndigits, ret = crypto_ecdh_shared_secret(ctx->curve_id, ctx->ndigits,
ctx->private_key, public_key, ctx->private_key, public_key,
...@@ -111,7 +118,11 @@ static int ecdh_compute_value(struct kpp_request *req) ...@@ -111,7 +118,11 @@ static int ecdh_compute_value(struct kpp_request *req)
if (ret < 0) if (ret < 0)
goto free_all; goto free_all;
copied = sg_copy_from_buffer(req->dst, 1, buf, nbytes); /* might want less than we've got */
nbytes = min_t(size_t, nbytes, req->dst_len);
copied = sg_copy_from_buffer(req->dst, sg_nents_for_len(req->dst,
nbytes),
buf, nbytes);
if (copied != nbytes) if (copied != nbytes)
ret = -EINVAL; ret = -EINVAL;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册