diff options
author | Andrew Tridgell <tridge@samba.org> | 2010-02-07 18:11:42 +1100 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2010-02-07 18:41:59 +1100 |
commit | 5ab6a8d077712c789bbd245f5f7cac7fc71cba81 (patch) | |
tree | e4709f3b2a0fef25279fc812fe2df906b3f62215 /source4/lib/registry/util.c | |
parent | 70534adee10fc6f5bba2d9304668dc6508e5de5a (diff) | |
download | samba-5ab6a8d077712c789bbd245f5f7cac7fc71cba81.tar.gz samba-5ab6a8d077712c789bbd245f5f7cac7fc71cba81.tar.bz2 samba-5ab6a8d077712c789bbd245f5f7cac7fc71cba81.zip |
s4-registry: fixed byte order assumptions
the registry tests were broken on big-endian systems
Diffstat (limited to 'source4/lib/registry/util.c')
-rw-r--r-- | source4/lib/registry/util.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/source4/lib/registry/util.c b/source4/lib/registry/util.c index 5d451df33a..ba739c4921 100644 --- a/source4/lib/registry/util.c +++ b/source4/lib/registry/util.c @@ -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: |