From 80300af278d346049f9bfd48f013bc2055dc104b Mon Sep 17 00:00:00 2001 From: Matthias Dieter Wallnöfer Date: Mon, 15 Mar 2010 11:07:36 +0100 Subject: s4:registry - add support for REG_QWORD values Basically the same as REG_DWORD but these are eight byte long. --- source4/lib/registry/util.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) (limited to 'source4/lib/registry/util.c') 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; -- cgit