if (body_size > 0)
{
const char* body_data = _dbus_string_get_const_data (body);
+ size_t body_offsets_size;
+ const char *footer_ptr;
+
+ /* determine body offsets size */
+ if (ret_size <= 0xFF)
+ body_offsets_size = 1;
+ else if (ret_size <= 0xFFFF)
+ body_offsets_size = 2;
+ else if (ret_size <= 0xFFFFFFFF)
+ body_offsets_size = 4;
+ else
+ body_offsets_size = 8;
+
+ /* check footer size */
+ footer_ptr = body_data + body_size - body_offsets_size -1;
+ while (footer_ptr >= body_data && (*footer_ptr) != 0)
+ footer_ptr--;
+
+ if (footer_ptr < body_data)
+ {
+ ret_size = -1;
+ goto out;
+ }
#ifdef DBUS_ENABLE_VERBOSE_MODE
if (-1 != debug)
if (memfd >= 0)
{
-
- size_t body_offsets_size;
- const char *footer_ptr;
-
- /* determine body offsets size */
- if (ret_size <= 0xFF)
- body_offsets_size = 1;
- else if (ret_size <= 0xFFFF)
- body_offsets_size = 2;
- else if (ret_size <= 0xFFFFFFFF)
- body_offsets_size = 4;
- else
- body_offsets_size = 8;
-
- /* check footer size */
- footer_ptr = body_data + body_size - body_offsets_size -1;
- while (footer_ptr >= body_data && (*footer_ptr) != 0)
- footer_ptr--;
-
- if (footer_ptr < body_data)
- {
- ret_size = -1;
- goto out;
- }
-
/* prepare memfd for body */
if (prepare_mfd (memfd,
body_data,
goto out;
}
- /* body */
+ /* body */
item = _kdbus_item_add_payload_memfd (item,
0,
(footer_ptr - body_data) * sizeof(char),
memfd);
- /* footer */
+ /* footer */
item = _kdbus_item_add_payload_vec (item,
(body_data + body_size - footer_ptr) * sizeof(char),
(uintptr_t)footer_ptr);
if (part_size > KDBUS_MSG_MAX_PAYLOAD_VEC_SIZE)
part_size = KDBUS_MSG_MAX_PAYLOAD_VEC_SIZE;
+ /* we need to adjust part size if footer does not fit as a whole */
+ if (body_size - part_size > 0 && footer_ptr < (body_data + part_size))
+ part_size = footer_ptr - body_data;
+
_dbus_verbose ("attaching body part\n");
item = _kdbus_item_add_payload_vec (item,
part_size,