All of lore.kernel.org
 help / color / mirror / Atom feed
* [uml-devel] [PATCH 2/2] um: add a kmsg_dumper
@ 2014-10-09 17:55 Thomas Meyer
  2014-10-10 15:14 ` Daniel Walter
  0 siblings, 1 reply; 2+ messages in thread
From: Thomas Meyer @ 2014-10-09 17:55 UTC (permalink / raw)
  To: user-mode-linux-devel; +Cc: Richard Weinberger


Add a kmsg_dumper, that dumps the kmsg buffer to stderr, when no
console is available.
This an enables the printing of early panic() calls triggered in
uml_postsetup().

Signed-off-by: Thomas Meyer <thomas@m3y3r.de>
---
 arch/um/drivers/ubd_kern.c  |  5 +++--
 arch/um/include/shared/os.h |  1 +
 arch/um/kernel/Makefile     |  2 +-
 arch/um/kernel/kmsg_dump.c  | 44 ++++++++++++++++++++++++++++++++++++++++++++
 arch/um/kernel/um_arch.c    |  2 ++
 arch/um/os-Linux/util.c     | 12 ++++++++++++
 6 files changed, 63 insertions(+), 3 deletions(-)
 create mode 100644 arch/um/kernel/kmsg_dump.c

diff --git a/arch/um/include/shared/os.h b/arch/um/include/shared/os.h
index 08eec0b..36741f4 100644
--- a/arch/um/include/shared/os.h
+++ b/arch/um/include/shared/os.h
@@ -238,6 +238,7 @@ extern void setup_hostinfo(char *buf, int len);
 extern void os_dump_core(void) __attribute__ ((noreturn));
 extern void um_early_printk(const char *s, unsigned int n);
 extern void os_fix_helper_signals(void);
+extern int os_printf_stderr(const char *fmt, ...);
 
 /* time.c */
 extern void idle_sleep(unsigned long long nsecs);
diff --git a/arch/um/kernel/Makefile b/arch/um/kernel/Makefile
index d8b78a0..572e781 100644
--- a/arch/um/kernel/Makefile
+++ b/arch/um/kernel/Makefile
@@ -13,7 +13,7 @@ clean-files :=
 obj-y = config.o exec.o exitcode.o irq.o ksyms.o mem.o \
 	physmem.o process.o ptrace.o reboot.o sigio.o \
 	signal.o smp.o syscall.o sysrq.o time.o tlb.o trap.o \
-	um_arch.o umid.o maccess.o skas/
+	um_arch.o umid.o maccess.o kmsg_dump.o skas/
 
 obj-$(CONFIG_BLK_DEV_INITRD) += initrd.o
 obj-$(CONFIG_GPROF)	+= gprof_syms.o
diff --git a/arch/um/kernel/kmsg_dump.c b/arch/um/kernel/kmsg_dump.c
new file mode 100644
index 0000000..8047ca5a3
--- /dev/null
+++ b/arch/um/kernel/kmsg_dump.c
@@ -0,0 +1,44 @@
+#include <linux/kmsg_dump.h>
+#include <linux/console.h>
+#include <shared/init.h>
+#include <shared/kern.h>
+#include <os.h>
+
+static struct kmsg_dumper kmsg_dumper;
+
+static void kmsg_dumper_stderr(struct kmsg_dumper *dumper,
+				enum kmsg_dump_reason reason)
+{
+	static char line[1024];
+
+	size_t len = 0;
+	int con_count = 0;
+	struct console *con = NULL;
+
+	/* only dump kmsg when no console is available */
+	if (!console_trylock()) {
+		return;
+	}
+	for_each_console(con) {
+		con_count++;
+	}
+	console_unlock();
+
+	if (con_count > 0) {
+		return;
+	}
+
+	os_printf_stderr("kmsg_dump:\n");
+	while (kmsg_dump_get_line(dumper, true, line, sizeof(line), &len)) {
+		line[len] = '\0';
+		os_printf_stderr("%s", line);
+	}
+}
+
+int __init kmsg_dumper_stderr_init(void)
+{
+	kmsg_dumper.dump = kmsg_dumper_stderr;
+	return kmsg_dump_register(&kmsg_dumper);
+}
+
+__uml_initcall(kmsg_dumper_stderr_init);
diff --git a/arch/um/kernel/um_arch.c b/arch/um/kernel/um_arch.c
index ab72560..4f6fc24 100644
--- a/arch/um/kernel/um_arch.c
+++ b/arch/um/kernel/um_arch.c
@@ -11,6 +11,7 @@
 #include <linux/string.h>
 #include <linux/utsname.h>
 #include <linux/sched.h>
+#include <linux/kmsg_dump.h>
 #include <asm/pgtable.h>
 #include <asm/processor.h>
 #include <asm/sections.h>
@@ -234,6 +235,7 @@ static void __init uml_postsetup(void)
 static int panic_exit(struct notifier_block *self, unsigned long unused1,
 		      void *unused2)
 {
+	kmsg_dump(KMSG_DUMP_PANIC);
 	bust_spinlocks(1);
 	bust_spinlocks(0);
 	uml_exitcode = 1;
diff --git a/arch/um/os-Linux/util.c b/arch/um/os-Linux/util.c
index faee55e..a4cc3a0 100644
--- a/arch/um/os-Linux/util.c
+++ b/arch/um/os-Linux/util.c
@@ -152,3 +152,15 @@ void um_early_printk(const char *s, unsigned int n)
 {
 	printf("%.*s", n, s);
 }
+
+int os_printf_stderr(const char *fmt, ...)
+{
+	va_list list;
+	int rc;
+
+	va_start(list, fmt);
+	rc = vfprintf(stderr, fmt, list);
+	va_end(list);
+
+	return rc;
+}
-- 
1.9.3



------------------------------------------------------------------------------
Meet PCI DSS 3.0 Compliance Requirements with EventLog Analyzer
Achieve PCI DSS 3.0 Compliant Status with Out-of-the-box PCI DSS Reports
Are you Audit-Ready for PCI DSS 3.0 Compliance? Download White paper
Comply to PCI DSS 3.0 Requirement 10 and 11.5 with EventLog Analyzer
http://pubads.g.doubleclick.net/gampad/clk?id=154622311&iu=/4140/ostg.clktrk
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [uml-devel] [PATCH 2/2] um: add a kmsg_dumper
  2014-10-09 17:55 [uml-devel] [PATCH 2/2] um: add a kmsg_dumper Thomas Meyer
@ 2014-10-10 15:14 ` Daniel Walter
  0 siblings, 0 replies; 2+ messages in thread
From: Daniel Walter @ 2014-10-10 15:14 UTC (permalink / raw)
  To: Thomas Meyer; +Cc: Richard Weinberger, user-mode-linux-devel

----- Original Message -----
> From: "Thomas Meyer" <thomas@m3y3r.de>
> To: "user-mode-linux-devel" <user-mode-linux-devel@lists.sourceforge.net>
> Cc: "Richard Weinberger" <richard@nod.at>, "Daniel Walter" <d.walter@0x90.at>
> Sent: Thursday, October 9, 2014 6:55:34 PM
> Subject: [PATCH 2/2] um: add a kmsg_dumper
> 
> 
> Add a kmsg_dumper, that dumps the kmsg buffer to stderr, when no
> console is available.
> This an enables the printing of early panic() calls triggered in
> uml_postsetup().
> 
> Signed-off-by: Thomas Meyer <thomas@m3y3r.de>
> ---
>  arch/um/drivers/ubd_kern.c  |  5 +++--
>  arch/um/include/shared/os.h |  1 +
>  arch/um/kernel/Makefile     |  2 +-
>  arch/um/kernel/kmsg_dump.c  | 44
>  ++++++++++++++++++++++++++++++++++++++++++++
>  arch/um/kernel/um_arch.c    |  2 ++
>  arch/um/os-Linux/util.c     | 12 ++++++++++++
>  6 files changed, 63 insertions(+), 3 deletions(-)
>  create mode 100644 arch/um/kernel/kmsg_dump.c
> 
> diff --git a/arch/um/include/shared/os.h
> b/arch/um/include/shared/os.h
> index 08eec0b..36741f4 100644
> --- a/arch/um/include/shared/os.h
> +++ b/arch/um/include/shared/os.h
> @@ -238,6 +238,7 @@ extern void setup_hostinfo(char *buf, int len);
>  extern void os_dump_core(void) __attribute__ ((noreturn));
>  extern void um_early_printk(const char *s, unsigned int n);
>  extern void os_fix_helper_signals(void);
> +extern int os_printf_stderr(const char *fmt, ...);
>  
>  /* time.c */
>  extern void idle_sleep(unsigned long long nsecs);
> diff --git a/arch/um/kernel/Makefile b/arch/um/kernel/Makefile
> index d8b78a0..572e781 100644
> --- a/arch/um/kernel/Makefile
> +++ b/arch/um/kernel/Makefile
> @@ -13,7 +13,7 @@ clean-files :=
>  obj-y = config.o exec.o exitcode.o irq.o ksyms.o mem.o \
>  	physmem.o process.o ptrace.o reboot.o sigio.o \
>  	signal.o smp.o syscall.o sysrq.o time.o tlb.o trap.o \
> -	um_arch.o umid.o maccess.o skas/
> +	um_arch.o umid.o maccess.o kmsg_dump.o skas/
>  
>  obj-$(CONFIG_BLK_DEV_INITRD) += initrd.o
>  obj-$(CONFIG_GPROF)	+= gprof_syms.o
> diff --git a/arch/um/kernel/kmsg_dump.c b/arch/um/kernel/kmsg_dump.c
> new file mode 100644
> index 0000000..8047ca5a3
> --- /dev/null
> +++ b/arch/um/kernel/kmsg_dump.c
> @@ -0,0 +1,44 @@
> +#include <linux/kmsg_dump.h>
> +#include <linux/console.h>
> +#include <shared/init.h>
> +#include <shared/kern.h>
> +#include <os.h>
> +
> +static struct kmsg_dumper kmsg_dumper;

can you make this const ?

> +
> +static void kmsg_dumper_stderr(struct kmsg_dumper *dumper,
> +				enum kmsg_dump_reason reason)
> +{
> +	static char line[1024];
> +
> +	size_t len = 0;
> +	int con_count = 0;
> +	struct console *con = NULL;
> +
> +	/* only dump kmsg when no console is available */
> +	if (!console_trylock()) {
> +		return;
> +	}
> +	for_each_console(con) {
> +		con_count++;
> +	}
> +	console_unlock();
> +
> +	if (con_count > 0) {
> +		return;
> +	}
> +

Would it be sufficient to check if a console exists, instead of iterating through all of
them and decide to return anyway as soon as one exists ? (I believe a check for console_drivers != NULL should be sufficient)

> +	os_printf_stderr("kmsg_dump:\n");
> +	while (kmsg_dump_get_line(dumper, true, line, sizeof(line), &len))
> {
> +		line[len] = '\0';
> +		os_printf_stderr("%s", line);
> +	}
> +}
> +
> +int __init kmsg_dumper_stderr_init(void)
> +{
> +	kmsg_dumper.dump = kmsg_dumper_stderr;
> +	return kmsg_dump_register(&kmsg_dumper);
> +}
> +
> +__uml_initcall(kmsg_dumper_stderr_init);
> diff --git a/arch/um/kernel/um_arch.c b/arch/um/kernel/um_arch.c
> index ab72560..4f6fc24 100644
> --- a/arch/um/kernel/um_arch.c
> +++ b/arch/um/kernel/um_arch.c
> @@ -11,6 +11,7 @@
>  #include <linux/string.h>
>  #include <linux/utsname.h>
>  #include <linux/sched.h>
> +#include <linux/kmsg_dump.h>
>  #include <asm/pgtable.h>
>  #include <asm/processor.h>
>  #include <asm/sections.h>
> @@ -234,6 +235,7 @@ static void __init uml_postsetup(void)
>  static int panic_exit(struct notifier_block *self, unsigned long
>  unused1,
>  		      void *unused2)
>  {
> +	kmsg_dump(KMSG_DUMP_PANIC);
>  	bust_spinlocks(1);
>  	bust_spinlocks(0);
>  	uml_exitcode = 1;
> diff --git a/arch/um/os-Linux/util.c b/arch/um/os-Linux/util.c
> index faee55e..a4cc3a0 100644
> --- a/arch/um/os-Linux/util.c
> +++ b/arch/um/os-Linux/util.c
> @@ -152,3 +152,15 @@ void um_early_printk(const char *s, unsigned int
> n)
>  {
>  	printf("%.*s", n, s);
>  }
> +
> +int os_printf_stderr(const char *fmt, ...)
> +{
> +	va_list list;
> +	int rc;
> +
> +	va_start(list, fmt);
> +	rc = vfprintf(stderr, fmt, list);
> +	va_end(list);
> +
> +	return rc;
> +}
Is there a reason why you want the dump to be on stderr ? It seems
the rest of uml just prints to stdout ?


> --
> 1.9.3
> 
> 
> 

------------------------------------------------------------------------------
Meet PCI DSS 3.0 Compliance Requirements with EventLog Analyzer
Achieve PCI DSS 3.0 Compliant Status with Out-of-the-box PCI DSS Reports
Are you Audit-Ready for PCI DSS 3.0 Compliance? Download White paper
Comply to PCI DSS 3.0 Requirement 10 and 11.5 with EventLog Analyzer
http://pubads.g.doubleclick.net/gampad/clk?id=154622311&iu=/4140/ostg.clktrk
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2014-10-10 15:14 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-10-09 17:55 [uml-devel] [PATCH 2/2] um: add a kmsg_dumper Thomas Meyer
2014-10-10 15:14 ` Daniel Walter

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.