s4-registry: fixed byte order assumptions
authorAndrew Tridgell <tridge@samba.org>
Sun, 7 Feb 2010 07:11:42 +0000 (18:11 +1100)
committerAndrew Tridgell <tridge@samba.org>
Sun, 7 Feb 2010 07:41:59 +0000 (18:41 +1100)
the registry tests were broken on big-endian systems

source4/lib/registry/ldb.c
source4/lib/registry/patchfile_preg.c
source4/lib/registry/regf.c
source4/lib/registry/util.c

index 033fdcb780cc3c295876023addeb4665c3cae0a0..d70489ac03a53f4ebd491de1d370d3d90f33de25 100644 (file)
@@ -80,7 +80,8 @@ static void reg_ldb_unpack_value(TALLOC_CTX *mem_ctx,
 
        case REG_DWORD: {
                uint32_t tmp = strtoul((char *)val->data, NULL, 0);
-               *data = data_blob_talloc(mem_ctx, &tmp, 4);
+               *data = data_blob_talloc(mem_ctx, NULL, 4);
+               SIVAL(data->data, 0, tmp);
                }
                break;
 
index 30a9aea2a5cd8030c13fc80d1a16749a755f8352..d7b4bc3730819c1c142dedc1ee086b01d5567e8b 100644 (file)
@@ -109,7 +109,7 @@ static WERROR reg_preg_diff_del_value(void *_data, const char *key_name,
        val = talloc_asprintf(data->ctx, "**Del.%s", value_name);
 
        blob.data = (uint8_t *)talloc(data->ctx, uint32_t);
-       *(uint32_t *)blob.data = 0;
+       SIVAL(blob.data, 0, 0);
        blob.length = 4;
        return reg_preg_diff_set_value(data, key_name, val, REG_DWORD, blob);
 }
@@ -120,7 +120,7 @@ static WERROR reg_preg_diff_del_all_values(void *_data, const char *key_name)
        DATA_BLOB blob;
 
        blob.data = (uint8_t *)talloc(data->ctx, uint32_t);
-       *(uint32_t *)blob.data = 0;     
+       SIVAL(blob.data, 0, 0);
        blob.length = 4;
 
        return reg_preg_diff_set_value(data, key_name, "**DelVals.", REG_DWORD, blob);
index a96c7db0eeed8edd70da891c2b57bf29466f2606..b5b676f9d891deccd92b6b7fb236ec14847ee1be 100644 (file)
@@ -1816,7 +1816,7 @@ static WERROR regf_set_value(struct hive_key *key, const char *name,
        vk.data_type = type;
        if (type == REG_DWORD) {
                vk.data_length |= 0x80000000;
-               vk.data_offset = *(uint32_t *)data.data;
+               vk.data_offset = IVAL(data.data, 0);
        } else {
                /* Store data somewhere */
                vk.data_offset = hbin_store(regf, data);
index 5d451df33ace2b4871d32193e1f795fd28e3705a..ba739c4921afa5847b0ca2275b6a416dbe3039ca 100644 (file)
@@ -75,11 +75,11 @@ _PUBLIC_ char *reg_val_data_string(TALLOC_CTX *mem_ctx,
                        ret = data_blob_hex_string_upper(mem_ctx, &data);
                        break;
                case REG_DWORD:
-                       if (*(int *)data.data == 0) {
+                       if (IVAL(data.data, 0) == 0) {
                                ret = talloc_strdup(mem_ctx, "0");
                        } else {
                                ret = talloc_asprintf(mem_ctx, "0x%x",
-                                                     *(int *)data.data);
+                                                     IVAL(data.data, 0));
                        }
                        break;
                case REG_NONE:
@@ -147,7 +147,8 @@ _PUBLIC_ bool reg_string_to_val(TALLOC_CTX *mem_ctx,
                        break;
                case REG_DWORD: {
                        uint32_t tmp = strtol(data_str, NULL, 0);
-                       *data = data_blob_talloc(mem_ctx, &tmp, 4);
+                       *data = data_blob_talloc(mem_ctx, NULL, 4);
+                       SIVAL(data->data, 0, tmp);
                        }
                        break;
                case REG_NONE: