X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=crypto%2Fdigest.c;h=61a767698e2bcea8f8a50c2ac15b4c073a6ef7e5;hb=9464c7cf61b9433057924c36e6e02f303a00e768;hp=30dabe203d30e7c2c938b279b8866d5aea4822bc;hpb=daddc0d38b3571bed170afa273a49a0eba090c1e;p=linux-2.6.git diff --git a/crypto/digest.c b/crypto/digest.c index 30dabe203..61a767698 100644 --- a/crypto/digest.c +++ b/crypto/digest.c @@ -27,16 +27,38 @@ static void update(struct crypto_tfm *tfm, struct scatterlist *sg, unsigned int nsg) { unsigned int i; - + for (i = 0; i < nsg; i++) { - char *p = crypto_kmap(sg[i].page, 0) + sg[i].offset; - tfm->__crt_alg->cra_digest.dia_update(crypto_tfm_ctx(tfm), - p, sg[i].length); - crypto_kunmap(p, 0); - crypto_yield(tfm); + + struct page *pg = sg[i].page; + unsigned int offset = sg[i].offset; + unsigned int l = sg[i].length; + + do { + unsigned int bytes_from_page = min(l, ((unsigned int) + (PAGE_SIZE)) - + offset); + char *p = crypto_kmap(pg, 0) + offset; + + tfm->__crt_alg->cra_digest.dia_update + (crypto_tfm_ctx(tfm), p, + bytes_from_page); + crypto_kunmap(p, 0); + crypto_yield(tfm); + offset = 0; + pg++; + l -= bytes_from_page; + } while (l > 0); } } +static void update_kernel(struct crypto_tfm *tfm, + const void *data, size_t count) +{ + tfm->__crt_alg->cra_digest.dia_update(crypto_tfm_ctx(tfm), data, count); + crypto_yield(tfm); +} + static void final(struct crypto_tfm *tfm, u8 *out) { tfm->__crt_alg->cra_digest.dia_final(crypto_tfm_ctx(tfm), out); @@ -79,6 +101,7 @@ int crypto_init_digest_ops(struct crypto_tfm *tfm) ops->dit_init = init; ops->dit_update = update; + ops->dit_update_kernel = update_kernel; ops->dit_final = final; ops->dit_digest = digest; ops->dit_setkey = setkey;