diff options
author | Matthias Dieter Wallnöfer <mwallnoefer@yahoo.de> | 2010-03-15 11:07:36 +0100 |
---|---|---|
committer | Matthias Dieter Wallnöfer <mwallnoefer@yahoo.de> | 2010-03-15 13:27:34 +0100 |
commit | 80300af278d346049f9bfd48f013bc2055dc104b (patch) | |
tree | 665e49d32e4c1d1aa8a2f812109261fd2c91199f /source4/lib/registry/util.c | |
parent | c3eb509dea715620da086f3dc8e5702fb9d03e1c (diff) | |
download | samba-80300af278d346049f9bfd48f013bc2055dc104b.tar.gz samba-80300af278d346049f9bfd48f013bc2055dc104b.tar.bz2 samba-80300af278d346049f9bfd48f013bc2055dc104b.zip |
s4:registry - add support for REG_QWORD values
Basically the same as REG_DWORD but these are eight byte long.
Diffstat (limited to 'source4/lib/registry/util.c')
-rw-r--r-- | source4/lib/registry/util.c | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/source4/lib/registry/util.c b/source4/lib/registry/util.c index 6ff61942f9..c7f4c0844e 100644 --- a/source4/lib/registry/util.c +++ b/source4/lib/registry/util.c @@ -94,6 +94,16 @@ _PUBLIC_ char *reg_val_data_string(TALLOC_CTX *mem_ctx, } } break; + case REG_QWORD: + if (data.length == sizeof(uint64_t)) { + if (BVAL(data.data, 0) == 0) { + ret = talloc_strdup(mem_ctx, "0"); + } else { + ret = talloc_asprintf(mem_ctx, "0x%llx", + BVAL(data.data, 0)); + } + } + break; case REG_NONE: /* "NULL" is the right return value */ break; @@ -159,10 +169,16 @@ _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, NULL, 4); + *data = data_blob_talloc(mem_ctx, NULL, sizeof(uint32_t)); SIVAL(data->data, 0, tmp); } break; + case REG_QWORD: { + uint64_t tmp = strtoll(data_str, NULL, 0); + *data = data_blob_talloc(mem_ctx, NULL, sizeof(uint64_t)); + SBVAL(data->data, 0, tmp); + } + break; case REG_NONE: ZERO_STRUCTP(data); break; |