[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v3 2/7] gcov: introduce hooks for the sysctl
So that other implementations of the sysctl can be added. Signed-off-by: Roger Pau Monné <roger.pau@xxxxxxxxxx> Acked-by: Jan Beulich <jbeulich@xxxxxxxx> --- Cc: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> Cc: George Dunlap <George.Dunlap@xxxxxxxxxxxxx> Cc: Ian Jackson <ian.jackson@xxxxxxxxxxxxx> Cc: Jan Beulich <jbeulich@xxxxxxxx> Cc: Konrad Rzeszutek Wilk <konrad.wilk@xxxxxxxxxx> Cc: Stefano Stabellini <sstabellini@xxxxxxxxxx> Cc: Tim Deegan <tim@xxxxxxx> Cc: Wei Liu <wei.liu2@xxxxxxxxxx> --- Changes since v2: - Add editor block. Changes since v1: - Constify cov_ops. - Introduce a local coverage.h provate header and place the definition of cov_sysctl_ops there. --- xen/common/coverage/coverage.h | 22 ++++++++++++++++++++++ xen/common/coverage/gcov.c | 13 ++++++++++--- 2 files changed, 32 insertions(+), 3 deletions(-) create mode 100644 xen/common/coverage/coverage.h diff --git a/xen/common/coverage/coverage.h b/xen/common/coverage/coverage.h new file mode 100644 index 0000000000..9991939b70 --- /dev/null +++ b/xen/common/coverage/coverage.h @@ -0,0 +1,22 @@ +#ifndef _XEN_COV_PRIV_H +#define _XEN_COV_PRIV_H + +#include <xen/types.h> + +struct cov_sysctl_ops { + uint32_t (*get_size)(void); + void (*reset_counters)(void); + int (*dump)(XEN_GUEST_HANDLE_PARAM(char), uint32_t *); +}; + +#endif + +/* + * Local variables: + * mode: C + * c-file-style: "BSD" + * c-basic-offset: 4 + * tab-width: 4 + * indent-tabs-mode: nil + * End: + */ diff --git a/xen/common/coverage/gcov.c b/xen/common/coverage/gcov.c index 798032cbbb..8627ef3355 100644 --- a/xen/common/coverage/gcov.c +++ b/xen/common/coverage/gcov.c @@ -22,6 +22,7 @@ #include <public/sysctl.h> +#include "coverage.h" #include "gcov.h" /** @@ -209,6 +210,12 @@ static int gcov_dump_all(XEN_GUEST_HANDLE_PARAM(char) buffer, return ret; } +static const struct cov_sysctl_ops cov_ops = { + .get_size = gcov_get_size, + .reset_counters = gcov_reset_all_counters, + .dump = gcov_dump_all, +}; + int sysctl_cov_op(struct xen_sysctl_coverage_op *op) { int ret; @@ -216,7 +223,7 @@ int sysctl_cov_op(struct xen_sysctl_coverage_op *op) switch ( op->cmd ) { case XEN_SYSCTL_COVERAGE_get_size: - op->size = gcov_get_size(); + op->size = cov_ops.get_size(); ret = 0; break; @@ -227,14 +234,14 @@ int sysctl_cov_op(struct xen_sysctl_coverage_op *op) buf = guest_handle_cast(op->buffer, char); - ret = gcov_dump_all(buf, &size); + ret = cov_ops.dump(buf, &size); op->size = size; break; } case XEN_SYSCTL_COVERAGE_reset: - gcov_reset_all_counters(); + cov_ops.reset_counters(); ret = 0; break; -- 2.15.1 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |