security: Fix libvirtd crash possibility
authorMartin Kletzander <mkletzan@redhat.com>
Wed, 12 Sep 2012 21:43:26 +0000 (23:43 +0200)
committerGuido Günther <agx@sigxcpu.org>
Wed, 11 Sep 2013 12:44:34 +0000 (14:44 +0200)
commitaddf5e1b3160cbc91cf0f56cd97d1a38a6fb91e8
tree0290758157812a08379c79594db627e33372015f
parent11568ec854413629ca28c4d64dbcda29337ae3e9
security: Fix libvirtd crash possibility

Fix for CVE-2012-4423.

When generating RPC protocol messages, it's strictly needed to have a
continuous line of numbers or RPC messages. However in case anyone
tries backporting some functionality and will skip a number, there is
a possibility to make the daemon segfault with newer virsh (version of
the library, rpc call, etc.) even unintentionally.

The problem is that the skipped numbers will get func filled with
NULLs, but there is no check whether these are set before the daemon
tries to run them. This patch very simply enhances one check and fixes
that.

(cherry picked from commit b7ff9e696063189a715802d081d55a398663c15a)
src/rpc/virnetserverprogram.c