• Tero Kristo's avatar
    crypto: omap-sham - fix closing of hash with separate finalize call · 898d86a5
    Tero Kristo authored
    Currently there is an interesting corner case failure with omap-sham
    driver, if the finalize call is done separately with no data, but
    all previous data has already been processed. In this case, it is not
    possible to close the hash with the hardware without providing any data,
    so we get incorrect results. Fix this by adjusting the size of data
    sent to the hardware crypto engine in case the non-final data size falls
    on the block size boundary, by reducing the amount of data sent by one
    full block. This makes it sure that we always have some data available
    for the finalize call and we can close the hash properly.
    Signed-off-by: default avatarTero Kristo <t-kristo@ti.com>
    Reported-by: default avatarAparna Balasubramanian <aparnab@ti.com>
    Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
    898d86a5
omap-sham.c 52.2 KB