2 * Unix SMB/CIFS implementation.
3 * Virtual Windows Registry Layer
4 * Copyright (C) Gerald Carter 2002-2005
5 * Copyright (C) Michael Adam 2008
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 3 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, see <http://www.gnu.org/licenses/>.
22 * perflib registry backend.
24 * This is a virtual overlay, dynamically presenting perflib values.
30 #define DBGC_CLASS DBGC_REGISTRY
32 extern struct registry_ops regdb_ops
;
34 #define KEY_PERFLIB_NORM "HKLM/SOFTWARE/MICROSOFT/WINDOWS NT/CURRENTVERSION/PERFLIB"
35 #define KEY_PERFLIB_009_NORM "HKLM/SOFTWARE/MICROSOFT/WINDOWS NT/CURRENTVERSION/PERFLIB/009"
37 static int perflib_params(struct regval_ctr
*regvals
)
40 int last_counter
= -1;
42 int version
= 0x00010001;
44 base_index
= reg_perfcount_get_base_index();
45 regval_ctr_addvalue(regvals
, "Base Index", REG_DWORD
, (char *)&base_index
, sizeof(base_index
));
46 last_counter
= reg_perfcount_get_last_counter(base_index
);
47 regval_ctr_addvalue(regvals
, "Last Counter", REG_DWORD
, (char *)&last_counter
, sizeof(last_counter
));
48 last_help
= reg_perfcount_get_last_help(last_counter
);
49 regval_ctr_addvalue(regvals
, "Last Help", REG_DWORD
, (char *)&last_help
, sizeof(last_help
));
50 regval_ctr_addvalue(regvals
, "Version", REG_DWORD
, (char *)&version
, sizeof(version
));
52 return regval_ctr_numvals( regvals
);
55 static int perflib_009_params(struct regval_ctr
*regvals
)
61 base_index
= reg_perfcount_get_base_index();
62 buffer_size
= reg_perfcount_get_counter_names(base_index
, &buffer
);
63 regval_ctr_addvalue(regvals
, "Counter", REG_MULTI_SZ
, buffer
, buffer_size
);
66 buffer_size
= reg_perfcount_get_counter_help(base_index
, &buffer
);
67 regval_ctr_addvalue(regvals
, "Help", REG_MULTI_SZ
, buffer
, buffer_size
);
71 return regval_ctr_numvals( regvals
);
74 static int perflib_fetch_values(const char *key
, struct regval_ctr
*regvals
)
77 TALLOC_CTX
*ctx
= talloc_tos();
79 path
= talloc_strdup(ctx
, key
);
83 path
= normalize_reg_path(ctx
, path
);
88 if (strncmp(path
, KEY_PERFLIB_NORM
, strlen(path
)) == 0) {
89 return perflib_params(regvals
);
90 } else if (strncmp(path
, KEY_PERFLIB_009_NORM
, strlen(path
)) == 0) {
91 return perflib_009_params(regvals
);
97 static int perflib_fetch_subkeys(const char *key
,
98 struct regsubkey_ctr
*subkey_ctr
)
100 return regdb_ops
.fetch_subkeys(key
, subkey_ctr
);
103 struct registry_ops perflib_reg_ops
= {
104 .fetch_values
= perflib_fetch_values
,
105 .fetch_subkeys
= perflib_fetch_subkeys
,