aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Haller <thaller@redhat.com>2014-10-06 15:15:33 +0200
committerAleksander Morgado <aleksander@aleksander.es>2014-10-08 10:37:23 +0200
commitc744b04814098ea3647de8d618bd88e5554e1a26 (patch)
treead4b6de814b1c5da8f8b4f140a2f0e805b03af30
parent471d038fe38f7b99383f9654dcc8f6662d96e6f8 (diff)
downloadexternal_libqmi-c744b04814098ea3647de8d618bd88e5554e1a26.zip
external_libqmi-c744b04814098ea3647de8d618bd88e5554e1a26.tar.gz
external_libqmi-c744b04814098ea3647de8d618bd88e5554e1a26.tar.bz2
libqmi,utils: assert input buffer size when writing strings to buffer
Signed-off-by: Thomas Haller <thaller@redhat.com>
-rw-r--r--src/libqmi-glib/qmi-utils.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/src/libqmi-glib/qmi-utils.c b/src/libqmi-glib/qmi-utils.c
index f85970d..3875a0b 100644
--- a/src/libqmi-glib/qmi-utils.c
+++ b/src/libqmi-glib/qmi-utils.c
@@ -956,7 +956,7 @@ qmi_utils_write_string_to_buffer (guint8 **buffer,
guint8 length_prefix_size,
const gchar *in)
{
- guint16 len;
+ gsize len;
guint8 len_8;
guint16 len_16;
@@ -967,20 +967,26 @@ qmi_utils_write_string_to_buffer (guint8 **buffer,
length_prefix_size == 8 ||
length_prefix_size == 16);
- len = (guint16) strlen (in);
+ len = strlen (in);
+
+ g_assert ( len + (length_prefix_size/8) <= *buffer_size
+ || (length_prefix_size==8 && ((int) G_MAXUINT8 + 1) < *buffer_size));
switch (length_prefix_size) {
case 0:
break;
case 8:
- g_warn_if_fail (len <= G_MAXUINT8);
+ if (len > G_MAXUINT8) {
+ g_warn_if_reached ();
+ len = G_MAXUINT8;
+ }
len_8 = (guint8)len;
qmi_utils_write_guint8_to_buffer (buffer,
buffer_size,
&len_8);
break;
case 16:
- g_warn_if_fail (len <= G_MAXUINT16);
+ /* already asserted that @len is no larger then @buffer_size */
len_16 = (guint16)len;
qmi_utils_write_guint16_to_buffer (buffer,
buffer_size,
@@ -1021,6 +1027,7 @@ qmi_utils_write_fixed_size_string_to_buffer (guint8 **buffer,
g_assert (buffer != NULL);
g_assert (buffer_size != NULL);
g_assert (fixed_size > 0);
+ g_assert (fixed_size <= *buffer_size);
memcpy (*buffer, in, fixed_size);
*buffer = &((*buffer)[fixed_size]);