mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-09-30 22:26:55 +00:00
crypto: ccree - don't attempt 0 len DMA mappings
Refuse to try mapping zero bytes as this may cause a fault
on some configurations / platforms and it seems the prev.
attempt is not enough and we need to be more explicit.
Signed-off-by: Gilad Ben-Yossef <gilad@benyossef.com>
Reported-by: Corentin Labbe <clabbe.montjoie@gmail.com>
Fixes: ce0fc6db38
("crypto: ccree - protect against empty or NULL
scatterlists")
Tested-by: Corentin Labbe <clabbe.montjoie@gmail.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
This commit is contained in:
parent
c143a603c9
commit
1fb37b5692
1 changed files with 7 additions and 0 deletions
|
@ -258,6 +258,13 @@ static int cc_map_sg(struct device *dev, struct scatterlist *sg,
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
|
if (!nbytes) {
|
||||||
|
*mapped_nents = 0;
|
||||||
|
*lbytes = 0;
|
||||||
|
*nents = 0;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
*nents = cc_get_sgl_nents(dev, sg, nbytes, lbytes);
|
*nents = cc_get_sgl_nents(dev, sg, nbytes, lbytes);
|
||||||
if (*nents > max_sg_nents) {
|
if (*nents > max_sg_nents) {
|
||||||
*nents = 0;
|
*nents = 0;
|
||||||
|
|
Loading…
Reference in a new issue