[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v6 20/24] xsplice: Print build_id in keyhandler and on bootup.
As it should be an useful debug mechanism. Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@xxxxxxxxxx> Acked-by: Jan Beulich <jbeulich@xxxxxxxx> -- Cc: Ian Jackson <ian.jackson@xxxxxxxxxxxxx> Cc: Jan Beulich <jbeulich@xxxxxxxx> Cc: Keir Fraser <keir@xxxxxxx> Cc: Tim Deegan <tim@xxxxxxx> v2: s/char */const void * v5: s/ssize_t/unsigned int/ v6: Remove pointless initializers, use string literal instead of %s, add Jan's Ack. --- --- xen/common/xsplice.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/xen/common/xsplice.c b/xen/common/xsplice.c index fea184c..1c1727e 100644 --- a/xen/common/xsplice.c +++ b/xen/common/xsplice.c @@ -16,6 +16,7 @@ #include <xen/spinlock.h> #include <xen/string.h> #include <xen/symbols.h> +#include <xen/version.h> #include <xen/virtual_region.h> #include <xen/vmap.h> #include <xen/wait.h> @@ -1331,8 +1332,13 @@ static const char *state2str(uint32_t state) static void xsplice_printall(unsigned char key) { struct payload *data; + const void *binary_id = NULL; + unsigned int len = 0; unsigned int i; + if ( !xen_build_id(&binary_id, &len) ) + printk("build-id: %*phN\n", len, binary_id); + if ( !spin_trylock(&payload_lock) ) { printk("Lock held. Try again.\n"); @@ -1365,11 +1371,17 @@ static void xsplice_printall(unsigned char key) static int __init xsplice_init(void) { + const void *binary_id; + unsigned int len; + BUILD_BUG_ON( sizeof(struct xsplice_patch_func) != 64 ); BUILD_BUG_ON( sizeof(struct xsplice_patch_func_internal) != 64 ); BUILD_BUG_ON( offsetof(struct xsplice_patch_func, new_addr) != 8 ); BUILD_BUG_ON( offsetof(struct xsplice_patch_func, new_size) != 24 ); + if ( !xen_build_id(&binary_id, &len) ) + printk(XENLOG_INFO XSPLICE ": build-id: %*phN\n", len, binary_id); + register_keyhandler('x', xsplice_printall, "print xsplicing info", 1); arch_xsplice_init(); -- 2.5.0 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |