[Spice-devel] [PATCH spice-server 03/10] char-device: Avoid to use unaligned memory

Frediano Ziglio fziglio at redhat.com
Mon Jan 22 17:54:55 UTC 2018


This causes some warnings with clang:

char-device.c:898:29: error: cast from 'uint8_t *' (aka 'unsigned char *') to 'uint32_t *' (aka 'unsigned int *') increases required alignment from 1 to 4 [-Werror,-Wcast-align]
    write_to_dev_size_ptr = (uint32_t *)spice_marshaller_reserve_space(m, sizeof(uint32_t));
                            ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
char-device.c:899:31: error: cast from 'uint8_t *' (aka 'unsigned char *') to 'uint32_t *' (aka 'unsigned int *') increases required alignment from 1 to 4 [-Werror,-Wcast-align]
    write_to_dev_tokens_ptr = (uint32_t *)spice_marshaller_reserve_space(m, sizeof(uint32_t));
                              ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

This also fixes some minor endianness issue (on big endian machine
integers were not properly encoded).

Signed-off-by: Frediano Ziglio <fziglio at redhat.com>
---
 server/char-device.c | 24 +++++++++++++-----------
 1 file changed, 13 insertions(+), 11 deletions(-)

diff --git a/server/char-device.c b/server/char-device.c
index 2f8d3821..242d8782 100644
--- a/server/char-device.c
+++ b/server/char-device.c
@@ -880,8 +880,9 @@ void red_char_device_migrate_data_marshall(RedCharDevice *dev,
 {
     RedCharDeviceClient *dev_client;
     GList *item;
-    uint32_t *write_to_dev_size_ptr;
-    uint32_t *write_to_dev_tokens_ptr;
+    uint8_t *write_to_dev_sizes_ptr;
+    uint32_t write_to_dev_size;
+    uint32_t write_to_dev_tokens;
     SpiceMarshaller *m2;
 
     /* multi-clients are not supported */
@@ -895,10 +896,9 @@ void red_char_device_migrate_data_marshall(RedCharDevice *dev,
     spice_marshaller_add_uint8(m, 1); /* connected */
     spice_marshaller_add_uint32(m, dev_client->num_client_tokens);
     spice_marshaller_add_uint32(m, dev_client->num_send_tokens);
-    write_to_dev_size_ptr = (uint32_t *)spice_marshaller_reserve_space(m, sizeof(uint32_t));
-    write_to_dev_tokens_ptr = (uint32_t *)spice_marshaller_reserve_space(m, sizeof(uint32_t));
-    *write_to_dev_size_ptr = 0;
-    *write_to_dev_tokens_ptr = 0;
+    write_to_dev_sizes_ptr = spice_marshaller_reserve_space(m, sizeof(uint32_t)*2);
+    write_to_dev_size = 0;
+    write_to_dev_tokens = 0;
 
     m2 = spice_marshaller_get_ptr_submarshaller(m, 0);
     if (dev->priv->cur_write_buf) {
@@ -908,10 +908,10 @@ void red_char_device_migrate_data_marshall(RedCharDevice *dev,
                                          migrate_data_marshaller_write_buffer_free,
                                          red_char_device_write_buffer_ref(dev->priv->cur_write_buf)
                                          );
-        *write_to_dev_size_ptr += buf_remaining;
+        write_to_dev_size += buf_remaining;
         if (dev->priv->cur_write_buf->priv->origin == WRITE_BUFFER_ORIGIN_CLIENT) {
             spice_assert(dev->priv->cur_write_buf->priv->client == dev_client->client);
-            (*write_to_dev_tokens_ptr) += dev->priv->cur_write_buf->priv->token_price;
+            write_to_dev_tokens += dev->priv->cur_write_buf->priv->token_price;
         }
     }
 
@@ -922,14 +922,16 @@ void red_char_device_migrate_data_marshall(RedCharDevice *dev,
                                          migrate_data_marshaller_write_buffer_free,
                                          red_char_device_write_buffer_ref(write_buf)
                                          );
-        *write_to_dev_size_ptr += write_buf->buf_used;
+        write_to_dev_size += write_buf->buf_used;
         if (write_buf->priv->origin == WRITE_BUFFER_ORIGIN_CLIENT) {
             spice_assert(write_buf->priv->client == dev_client->client);
-            (*write_to_dev_tokens_ptr) += write_buf->priv->token_price;
+            write_to_dev_tokens += write_buf->priv->token_price;
         }
     }
     spice_debug("migration data dev %p: write_queue size %u tokens %u",
-                dev, *write_to_dev_size_ptr, *write_to_dev_tokens_ptr);
+                dev, write_to_dev_size, write_to_dev_tokens);
+    spice_marshaller_set_uint32(m, write_to_dev_sizes_ptr, write_to_dev_size);
+    spice_marshaller_set_uint32(m, write_to_dev_sizes_ptr + sizeof(uint32_t), write_to_dev_tokens);
 }
 
 bool red_char_device_restore(RedCharDevice *dev,
-- 
2.14.3



More information about the Spice-devel mailing list