mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-06 04:46:16 +01:00
7c4e6e9fbe
Previously, GVariant has allowed ‘arbitrary’ recursion on GVariantTypes, but this isn’t really feasible. We have to deal with GVariants from untrusted sources, and the nature of GVariantType means that another level of recursion (and hence, for example, another stack frame in your application) can be added with a single byte in a variant type signature in the input. This gives malicious input sources far too much leverage to cause deep stack recursion or massive memory allocations which can DoS an application. Limit recursion to 128 levels (which should be more than enough for anyone™), document it and add a test. This is, handily, also the limit of 64 applied by the D-Bus specification (§(Valid Signatures)), plus a bit to allow wrapping of D-Bus messages in additional layers of variants. oss-fuzz#9857 Signed-off-by: Philip Withnall <withnall@endlessm.com>
69 lines
2.7 KiB
C
69 lines
2.7 KiB
C
/*
|
|
* Copyright © 2007, 2008 Ryan Lortie
|
|
* Copyright © 2009, 2010 Codethink Limited
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* Author: Ryan Lortie <desrt@desrt.ca>
|
|
*/
|
|
|
|
|
|
/* The purpose of this header is to allow certain internal symbols of
|
|
* GVariant to be put under test cases.
|
|
*/
|
|
|
|
#ifndef __G_VARIANT_INTERNAL_H__
|
|
#define __G_VARIANT_INTERNAL_H__
|
|
|
|
/* Hack */
|
|
#define __GLIB_H_INSIDE__
|
|
|
|
#include <glib/gvarianttype.h>
|
|
#include <glib/gtypes.h>
|
|
|
|
#include "gvariant-serialiser.h"
|
|
#include "gvarianttypeinfo.h"
|
|
|
|
#undef __GLIB_H_INSIDE__
|
|
|
|
GLIB_AVAILABLE_IN_ALL
|
|
gboolean g_variant_format_string_scan (const gchar *string,
|
|
const gchar *limit,
|
|
const gchar **endptr);
|
|
|
|
GLIB_AVAILABLE_IN_ALL
|
|
GVariantType * g_variant_format_string_scan_type (const gchar *string,
|
|
const gchar *limit,
|
|
const gchar **endptr);
|
|
|
|
/* The maximum number of levels of nested container which this implementation
|
|
* of #GVariant will handle.
|
|
*
|
|
* The limit must be at least 64 + 1, to allow D-Bus messages to be wrapped in
|
|
* a top-level #GVariant. This comes from the D-Bus specification (§(Valid
|
|
* Signatures)), but also seems generally reasonable. #GDBusMessage wraps its
|
|
* payload in a top-level tuple.
|
|
*
|
|
* The limit is actually set to be a lot greater than 64, to allow much greater
|
|
* nesting of values off D-Bus. It cannot be set over around 80000, or the risk
|
|
* of overflowing the stack when parsing type strings becomes too great.
|
|
*
|
|
* Aside from those constraints, the choice of this value is arbitrary. The
|
|
* only restrictions on it from the API are that it has to be greater than 64
|
|
* (due to D-Bus).
|
|
*/
|
|
#define G_VARIANT_MAX_RECURSION_DEPTH ((gsize) 128)
|
|
|
|
#endif /* __G_VARIANT_INTERNAL_H__ */
|