]> git.ipfire.org Git - thirdparty/ipxe.git/commitdiff
[vmware] Add VMware logfile console (CONSOLE_VMWARE)
authorMichael Brown <mcb30@ipxe.org>
Tue, 28 Feb 2012 23:09:06 +0000 (23:09 +0000)
committerMichael Brown <mcb30@ipxe.org>
Tue, 28 Feb 2012 23:10:02 +0000 (23:10 +0000)
Allow iPXE console output to be sent to the VMware logfile via the
GuestRPC mechanism.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
src/arch/i386/interface/vmware/vmconsole.c [new file with mode: 0644]
src/config/config.c
src/config/console.h

diff --git a/src/arch/i386/interface/vmware/vmconsole.c b/src/arch/i386/interface/vmware/vmconsole.c
new file mode 100644 (file)
index 0000000..930c088
--- /dev/null
@@ -0,0 +1,117 @@
+/*
+ * Copyright (C) 2012 Michael Brown <mbrown@fensystems.co.uk>.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of the
+ * License, or any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+FILE_LICENCE ( GPL2_OR_LATER );
+
+/** @file
+ *
+ * VMware logfile console
+ *
+ */
+
+#include <string.h>
+#include <ipxe/console.h>
+#include <ipxe/lineconsole.h>
+#include <ipxe/init.h>
+#include <ipxe/guestrpc.h>
+
+/** VMware logfile console buffer size */
+#define VMCONSOLE_BUFSIZE 128
+
+/** VMware logfile console GuestRPC channel */
+static int vmconsole_channel;
+
+/** VMware logfile console line buffer */
+static struct {
+       char prefix[4];
+       char message[VMCONSOLE_BUFSIZE];
+} vmconsole_buffer = {
+       .prefix = "log ",
+};
+
+/** VMware logfile line console */
+static struct line_console vmconsole_line = {
+       .buffer = vmconsole_buffer.message,
+       .len = sizeof ( vmconsole_buffer.message ),
+};
+
+/** VMware logfile console recursion marker */
+static int vmconsole_entered;
+
+/**
+ * Print a character to VMware logfile console
+ *
+ * @v character                Character to be printed
+ */
+static void vmconsole_putchar ( int character ) {
+       int rc;
+
+       /* Ignore if we are already mid-logging */
+       if ( vmconsole_entered )
+               return;
+
+       /* Fill line buffer */
+       if ( line_putchar ( &vmconsole_line, character ) == 0 )
+               return;
+
+       /* Guard against re-entry */
+       vmconsole_entered = 1;
+
+       /* Send log message */
+       if ( ( rc = guestrpc_command ( vmconsole_channel,
+                                      vmconsole_buffer.prefix, NULL, 0 ) ) <0){
+               DBG ( "VMware console could not send log message: %s\n",
+                     strerror ( rc ) );
+       }
+
+       /* Clear re-entry flag */
+       vmconsole_entered = 0;
+}
+
+/** VMware logfile console driver */
+struct console_driver vmconsole __console_driver = {
+       .putchar = vmconsole_putchar,
+       .disabled = 1,
+};
+
+/**
+ * Initialise VMware logfile console
+ *
+ */
+static void vmconsole_init ( void ) {
+       int rc;
+
+       /* Attempt to open console */
+       vmconsole_channel = guestrpc_open();
+       if ( vmconsole_channel < 0 ) {
+               rc = vmconsole_channel;
+               DBG ( "VMware console could not be initialised: %s\n",
+                     strerror ( rc ) );
+               return;
+       }
+
+       /* Mark console as available */
+       vmconsole.disabled = 0;
+}
+
+/**
+ * VMware logfile console initialisation function
+ */
+struct init_fn vmconsole_init_fn __init_fn ( INIT_CONSOLE ) = {
+       .initialise = vmconsole_init,
+};
index 2c3555ead414e846c4e6dcb154f2f61a5eb35c30..bdf6b5ceab1b6e0fb461a5bd32e151c116759f52 100644 (file)
@@ -86,6 +86,9 @@ REQUIRE_OBJECT ( efi_console );
 #ifdef CONSOLE_LINUX
 REQUIRE_OBJECT ( linux_console );
 #endif
+#ifdef CONSOLE_VMWARE
+REQUIRE_OBJECT ( vmconsole );
+#endif
 
 /*
  * Drag in all requested network protocols
index afc89569c517e903dc4d89562f92d7584d6bd770..bf7ea0507bbcdcb337f826719ca674ade38dba64 100644 (file)
@@ -20,6 +20,7 @@ FILE_LICENCE ( GPL2_OR_LATER );
 //#define      CONSOLE_BTEXT           /* Who knows what this does? */
 //#define      CONSOLE_PC_KBD          /* Direct access to PC keyboard */
 //#define      CONSOLE_SYSLOG          /* Syslog console */
+//#define      CONSOLE_VMWARE          /* VMware logfile console */
 
 #define        KEYBOARD_MAP    us