Commit c1c6fe6c authored by Olof Johansson's avatar Olof Johansson

Merge tag 'tee-drv-fixes-for-4.17' of...

Merge tag 'tee-drv-fixes-for-4.17' of git://git.linaro.org/people/jens.wiklander/linux-tee into fixes

Small fixes for tee subsystem

* Fixes for use-after-free via temporarily dropped reference
* Checks that passed shm references are consistent in offset/size
  with regards to the shm object

* tag 'tee-drv-fixes-for-4.17' of git://git.linaro.org/people/jens.wiklander/linux-tee:
  tee: check shm references are consistent in offset/size
  tee: shm: fix use-after-free via temporarily dropped reference
Signed-off-by: default avatarOlof Johansson <olof@lixom.net>
parents 0d463d84 ab9d3db5
...@@ -238,6 +238,17 @@ static int params_from_user(struct tee_context *ctx, struct tee_param *params, ...@@ -238,6 +238,17 @@ static int params_from_user(struct tee_context *ctx, struct tee_param *params,
if (IS_ERR(shm)) if (IS_ERR(shm))
return PTR_ERR(shm); return PTR_ERR(shm);
/*
* Ensure offset + size does not overflow offset
* and does not overflow the size of the referred
* shared memory object.
*/
if ((ip.a + ip.b) < ip.a ||
(ip.a + ip.b) > shm->size) {
tee_shm_put(shm);
return -EINVAL;
}
params[n].u.memref.shm_offs = ip.a; params[n].u.memref.shm_offs = ip.a;
params[n].u.memref.size = ip.b; params[n].u.memref.size = ip.b;
params[n].u.memref.shm = shm; params[n].u.memref.shm = shm;
......
...@@ -360,9 +360,10 @@ int tee_shm_get_fd(struct tee_shm *shm) ...@@ -360,9 +360,10 @@ int tee_shm_get_fd(struct tee_shm *shm)
if (!(shm->flags & TEE_SHM_DMA_BUF)) if (!(shm->flags & TEE_SHM_DMA_BUF))
return -EINVAL; return -EINVAL;
get_dma_buf(shm->dmabuf);
fd = dma_buf_fd(shm->dmabuf, O_CLOEXEC); fd = dma_buf_fd(shm->dmabuf, O_CLOEXEC);
if (fd >= 0) if (fd < 0)
get_dma_buf(shm->dmabuf); dma_buf_put(shm->dmabuf);
return fd; return fd;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment