Check if the given area blongs to process virtul memory address space. Signed-off-by: Hiroshi DOYU <Hiroshi.DOYU@xxxxxxxxx> --- drivers/dsp/bridge/rmgr/proc.c | 32 ++++++++++++++++++++++++++++++++ 1 files changed, 32 insertions(+), 0 deletions(-) diff --git a/drivers/dsp/bridge/rmgr/proc.c b/drivers/dsp/bridge/rmgr/proc.c index 3a2879f..fe9dabf 100644 --- a/drivers/dsp/bridge/rmgr/proc.c +++ b/drivers/dsp/bridge/rmgr/proc.c @@ -735,6 +735,30 @@ DSP_STATUS PROC_EnumNodes(DSP_HPROCESSOR hProcessor, OUT DSP_HNODE *aNodeTab, return status; } +/* Check if the given area blongs to process virtul memory address space */ +static int memory_check_vma(unsigned long start, u32 len) +{ + int err = 0; + unsigned long end; + struct vm_area_struct *vma; + + len = PAGE_ALIGN(len); + end = start + len; + if (end <= start) + return -EINVAL; + + down_read(¤t->mm->mmap_sem); + + vma = find_vma(current->mm, start); + if (!vma || start < vma->vm_start) { + pr_err("%s: no vma for %08lx %08lx\n", __func__, start, end); + err = -EINVAL; + } + + up_read(¤t->mm->mmap_sem); + + return err; +} static DSP_STATUS proc_memory_sync(DSP_HPROCESSOR hProcessor, void *pMpuAddr, u32 ulSize, u32 ulFlags, @@ -757,6 +781,14 @@ static DSP_STATUS proc_memory_sync(DSP_HPROCESSOR hProcessor, void *pMpuAddr, goto err_out; } + if (memory_check_vma((u32)pMpuAddr, ulSize)) { + GT_3trace(PROC_DebugMask, GT_7CLASS, + "%s: InValid address parameters\n", + __func__, pMpuAddr, ulSize); + status = DSP_EHANDLE; + goto err_out; + } + (void)SYNC_EnterCS(hProcLock); MEM_FlushCache(pMpuAddr, ulSize, FlushMemType); (void)SYNC_LeaveCS(hProcLock); -- 1.6.0.4 -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html