diff --git a/client/gatt.c b/client/gatt.c
index 7a6035a..3fa490b 100644
--- a/client/gatt.c
+++ b/client/gatt.c
parse_offset(&iter, &offset);
+ if (offset > chrc->value_len)
+ return g_dbus_create_error(msg, "org.bluez.Error.InvalidOffset",
+ NULL);
+
return read_value(msg, &chrc->value[offset], chrc->value_len - offset);
}
parse_offset(&iter, &offset);
+ if (offset > desc->value_len)
+ return g_dbus_create_error(msg, "org.bluez.Error.InvalidOffset",
+ NULL);
+
return read_value(msg, &desc->value[offset], desc->value_len - offset);
}