summaryrefslogtreecommitdiffstats
path: root/linux-user/syscall.c
diff options
context:
space:
mode:
authorzhanghailiang2014-08-14 09:29:18 +0200
committerRiku Voipio2014-08-22 14:06:35 +0200
commit29e03fcb62d413cf5fba06978346893ab72a1f64 (patch)
treeb7513ba75b7ee74c5ce4d184957cc91664abb1cc /linux-user/syscall.c
parentlinux-user: writev Partial Writes (diff)
downloadqemu-29e03fcb62d413cf5fba06978346893ab72a1f64.tar.gz
qemu-29e03fcb62d413cf5fba06978346893ab72a1f64.tar.xz
qemu-29e03fcb62d413cf5fba06978346893ab72a1f64.zip
linux-user: check return value of malloc()
Signed-off-by: zhanghailiang <zhang.zhanghailiang@huawei.com> Acked-by: Riku Voipio <riku.voipio@linaro.org> Signed-off-by: Riku Voipio <riku.voipio@linaro.org>
Diffstat (limited to 'linux-user/syscall.c')
-rw-r--r--linux-user/syscall.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/linux-user/syscall.c b/linux-user/syscall.c
index ebdc70e4ca..7ff7c21255 100644
--- a/linux-user/syscall.c
+++ b/linux-user/syscall.c
@@ -2904,6 +2904,10 @@ static inline abi_long do_msgsnd(int msqid, abi_long msgp,
if (!lock_user_struct(VERIFY_READ, target_mb, msgp, 0))
return -TARGET_EFAULT;
host_mb = malloc(msgsz+sizeof(long));
+ if (!host_mb) {
+ unlock_user_struct(target_mb, msgp, 0);
+ return -TARGET_ENOMEM;
+ }
host_mb->mtype = (abi_long) tswapal(target_mb->mtype);
memcpy(host_mb->mtext, target_mb->mtext, msgsz);
ret = get_errno(msgsnd(msqid, host_mb, msgsz, msgflg));