summaryrefslogtreecommitdiff
path: root/source4/lib/registry/util.c
diff options
context:
space:
mode:
authorMatthias Dieter Wallnöfer <mwallnoefer@yahoo.de>2010-03-15 11:07:36 +0100
committerMatthias Dieter Wallnöfer <mwallnoefer@yahoo.de>2010-03-15 13:27:34 +0100
commit80300af278d346049f9bfd48f013bc2055dc104b (patch)
tree665e49d32e4c1d1aa8a2f812109261fd2c91199f /source4/lib/registry/util.c
parentc3eb509dea715620da086f3dc8e5702fb9d03e1c (diff)
downloadsamba-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.c18
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;