]> git.proxmox.com Git - qemu.git/commit - block.c
block: prevent snapshot mode $TMPDIR symlink attack
authorJim Meyering <jim@meyering.net>
Mon, 28 May 2012 07:27:54 +0000 (09:27 +0200)
committerAnthony Liguori <aliguori@us.ibm.com>
Wed, 30 May 2012 06:48:40 +0000 (14:48 +0800)
commiteba25057b9a5e19d10ace2bc7716667a31297169
treef2089af96ada2209b292255240e09b8bdd0cc1fc
parente78bd5ab07d65fec77fcae468b2836c79a836d49
block: prevent snapshot mode $TMPDIR symlink attack

In snapshot mode, bdrv_open creates an empty temporary file without
checking for mkstemp or close failure, and ignoring the possibility
of a buffer overrun given a surprisingly long $TMPDIR.
Change the get_tmp_filename function to return int (not void),
so that it can inform its two callers of those failures.
Also avoid the risk of buffer overrun and do not ignore mkstemp
or close failure.
Update both callers (in block.c and vvfat.c) to propagate
temp-file-creation failure to their callers.

get_tmp_filename creates and closes an empty file, while its
callers later open that presumed-existing file with O_CREAT.
The problem was that a malicious user could provoke mkstemp failure
and race to create a symlink with the selected temporary file name,
thus causing the qemu process (usually root owned) to open through
the symlink, overwriting an attacker-chosen file.

This addresses CVE-2012-2652.
http://bugzilla.redhat.com/CVE-2012-2652

Reviewed-by: Stefan Hajnoczi <stefanha@linux.vnet.ibm.com>
Signed-off-by: Jim Meyering <meyering@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
block.c
block/vvfat.c
block_int.h