mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-04 20:15:19 +00:00
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 b7ff9e6960
)
This commit is contained in:
parent
d6bce88ca3
commit
b2c5a91197
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* virnetserverprogram.c: generic network RPC server program
|
* virnetserverprogram.c: generic network RPC server program
|
||||||
*
|
*
|
||||||
* Copyright (C) 2006-2011 Red Hat, Inc.
|
* Copyright (C) 2006-2012 Red Hat, Inc.
|
||||||
* Copyright (C) 2006 Daniel P. Berrange
|
* Copyright (C) 2006 Daniel P. Berrange
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
@ -101,12 +101,19 @@ int virNetServerProgramMatches(virNetServerProgramPtr prog,
|
|||||||
static virNetServerProgramProcPtr virNetServerProgramGetProc(virNetServerProgramPtr prog,
|
static virNetServerProgramProcPtr virNetServerProgramGetProc(virNetServerProgramPtr prog,
|
||||||
int procedure)
|
int procedure)
|
||||||
{
|
{
|
||||||
|
virNetServerProgramProcPtr proc;
|
||||||
|
|
||||||
if (procedure < 0)
|
if (procedure < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
if (procedure >= prog->nprocs)
|
if (procedure >= prog->nprocs)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
return &prog->procs[procedure];
|
proc = &prog->procs[procedure];
|
||||||
|
|
||||||
|
if (!proc->func)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return proc;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int
|
unsigned int
|
||||||
|
Loading…
Reference in New Issue
Block a user