[kernel] r17902 - in dists/sid/linux-2.6/debian: . patches/bugfix/x86 patches/series

Ben Hutchings benh at alioth.debian.org
Wed Aug 10 12:13:46 UTC 2011


Author: benh
Date: Wed Aug 10 12:13:44 2011
New Revision: 17902

Log:
[x86] xen: allow enable use of VGA console on dom0

Added:
   dists/sid/linux-2.6/debian/patches/bugfix/x86/xen-allow-enable-use-of-VGA-console-on-dom0.patch
Modified:
   dists/sid/linux-2.6/debian/changelog
   dists/sid/linux-2.6/debian/patches/series/2

Modified: dists/sid/linux-2.6/debian/changelog
==============================================================================
--- dists/sid/linux-2.6/debian/changelog	Tue Aug  9 13:47:15 2011	(r17901)
+++ dists/sid/linux-2.6/debian/changelog	Wed Aug 10 12:13:44 2011	(r17902)
@@ -11,6 +11,7 @@
     (Closes: #636854):
     - Various drivers replaced as for x86 in 2.6.32-10
     - pata_macio replaces ide_pmac
+  * [x86] xen: allow enable use of VGA console on dom0
 
   [ maximilian attems ]
   * Add stable 3.0.1 including:

Added: dists/sid/linux-2.6/debian/patches/bugfix/x86/xen-allow-enable-use-of-VGA-console-on-dom0.patch
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ dists/sid/linux-2.6/debian/patches/bugfix/x86/xen-allow-enable-use-of-VGA-console-on-dom0.patch	Wed Aug 10 12:13:44 2011	(r17902)
@@ -0,0 +1,203 @@
+From: Jeremy Fitzhardinge <jeremy.fitzhardinge at citrix.com>
+Date: Tue, 31 May 2011 10:50:10 -0400
+Subject: [PATCH] xen: allow enable use of VGA console on dom0
+
+commit c2419b4a4727f67af2fc2cd68b0d878b75e781bb upstream.
+
+Get the information about the VGA console hardware from Xen, and put
+it into the form the bootloader normally generates, so that the rest
+of the kernel can deal with VGA as usual.
+
+[ Impact: make VGA console work in dom0 ]
+
+Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge at citrix.com>
+[v1: Rebased on 2.6.39]
+[v2: Removed incorrect comments and fixed compile warnings]
+Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk at oracle.com>
+---
+ arch/x86/xen/Makefile       |    2 +-
+ arch/x86/xen/enlighten.c    |    8 +++++
+ arch/x86/xen/vga.c          |   67 +++++++++++++++++++++++++++++++++++++++++++
+ arch/x86/xen/xen-ops.h      |   11 +++++++
+ include/xen/interface/xen.h |   39 +++++++++++++++++++++++++
+ 5 files changed, 126 insertions(+), 1 deletions(-)
+ create mode 100644 arch/x86/xen/vga.c
+
+diff --git a/arch/x86/xen/Makefile b/arch/x86/xen/Makefile
+index 17c565d..a6575b9 100644
+--- a/arch/x86/xen/Makefile
++++ b/arch/x86/xen/Makefile
+@@ -18,5 +18,5 @@ obj-y		:= enlighten.o setup.o multicalls.o mmu.o irq.o \
+ obj-$(CONFIG_SMP)		+= smp.o
+ obj-$(CONFIG_PARAVIRT_SPINLOCKS)+= spinlock.o
+ obj-$(CONFIG_XEN_DEBUG_FS)	+= debugfs.o
+-
++obj-$(CONFIG_XEN_DOM0)		+= vga.o
+ obj-$(CONFIG_SWIOTLB_XEN)	+= pci-swiotlb-xen.o
+diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c
+index e3c6a06..4abd2d5 100644
+--- a/arch/x86/xen/enlighten.c
++++ b/arch/x86/xen/enlighten.c
+@@ -1241,6 +1241,14 @@ asmlinkage void __init xen_start_kernel(void)
+ 		if (pci_xen)
+ 			x86_init.pci.arch_init = pci_xen_init;
+ 	} else {
++		const struct dom0_vga_console_info *info =
++			(void *)((char *)xen_start_info +
++				 xen_start_info->console.dom0.info_off);
++
++		xen_init_vga(info, xen_start_info->console.dom0.info_size);
++		xen_start_info->console.domU.mfn = 0;
++		xen_start_info->console.domU.evtchn = 0;
++
+ 		/* Make sure ACS will be enabled */
+ 		pci_request_acs();
+ 	}
+diff --git a/arch/x86/xen/vga.c b/arch/x86/xen/vga.c
+new file mode 100644
+index 0000000..1cd7f4d
+--- /dev/null
++++ b/arch/x86/xen/vga.c
+@@ -0,0 +1,67 @@
++#include <linux/screen_info.h>
++#include <linux/init.h>
++
++#include <asm/bootparam.h>
++#include <asm/setup.h>
++
++#include <xen/interface/xen.h>
++
++#include "xen-ops.h"
++
++void __init xen_init_vga(const struct dom0_vga_console_info *info, size_t size)
++{
++	struct screen_info *screen_info = &boot_params.screen_info;
++
++	/* This is drawn from a dump from vgacon:startup in
++	 * standard Linux. */
++	screen_info->orig_video_mode = 3;
++	screen_info->orig_video_isVGA = 1;
++	screen_info->orig_video_lines = 25;
++	screen_info->orig_video_cols = 80;
++	screen_info->orig_video_ega_bx = 3;
++	screen_info->orig_video_points = 16;
++	screen_info->orig_y = screen_info->orig_video_lines - 1;
++
++	switch (info->video_type) {
++	case XEN_VGATYPE_TEXT_MODE_3:
++		if (size < offsetof(struct dom0_vga_console_info, u.text_mode_3)
++		    + sizeof(info->u.text_mode_3))
++			break;
++		screen_info->orig_video_lines = info->u.text_mode_3.rows;
++		screen_info->orig_video_cols = info->u.text_mode_3.columns;
++		screen_info->orig_x = info->u.text_mode_3.cursor_x;
++		screen_info->orig_y = info->u.text_mode_3.cursor_y;
++		screen_info->orig_video_points =
++			info->u.text_mode_3.font_height;
++		break;
++
++	case XEN_VGATYPE_VESA_LFB:
++		if (size < offsetof(struct dom0_vga_console_info,
++				    u.vesa_lfb.gbl_caps))
++			break;
++		screen_info->orig_video_isVGA = VIDEO_TYPE_VLFB;
++		screen_info->lfb_width = info->u.vesa_lfb.width;
++		screen_info->lfb_height = info->u.vesa_lfb.height;
++		screen_info->lfb_depth = info->u.vesa_lfb.bits_per_pixel;
++		screen_info->lfb_base = info->u.vesa_lfb.lfb_base;
++		screen_info->lfb_size = info->u.vesa_lfb.lfb_size;
++		screen_info->lfb_linelength = info->u.vesa_lfb.bytes_per_line;
++		screen_info->red_size = info->u.vesa_lfb.red_size;
++		screen_info->red_pos = info->u.vesa_lfb.red_pos;
++		screen_info->green_size = info->u.vesa_lfb.green_size;
++		screen_info->green_pos = info->u.vesa_lfb.green_pos;
++		screen_info->blue_size = info->u.vesa_lfb.blue_size;
++		screen_info->blue_pos = info->u.vesa_lfb.blue_pos;
++		screen_info->rsvd_size = info->u.vesa_lfb.rsvd_size;
++		screen_info->rsvd_pos = info->u.vesa_lfb.rsvd_pos;
++		if (size >= offsetof(struct dom0_vga_console_info,
++				     u.vesa_lfb.gbl_caps)
++		    + sizeof(info->u.vesa_lfb.gbl_caps))
++			screen_info->capabilities = info->u.vesa_lfb.gbl_caps;
++		if (size >= offsetof(struct dom0_vga_console_info,
++				     u.vesa_lfb.mode_attrs)
++		    + sizeof(info->u.vesa_lfb.mode_attrs))
++			screen_info->vesa_attributes = info->u.vesa_lfb.mode_attrs;
++		break;
++	}
++}
+diff --git a/arch/x86/xen/xen-ops.h b/arch/x86/xen/xen-ops.h
+index 3112f55..e14c54e 100644
+--- a/arch/x86/xen/xen-ops.h
++++ b/arch/x86/xen/xen-ops.h
+@@ -88,6 +88,17 @@ static inline void xen_uninit_lock_cpu(int cpu)
+ }
+ #endif
+ 
++struct dom0_vga_console_info;
++
++#ifdef CONFIG_XEN_DOM0
++void __init xen_init_vga(const struct dom0_vga_console_info *, size_t size);
++#else
++static inline void __init xen_init_vga(const struct dom0_vga_console_info *info,
++				       size_t size)
++{
++}
++#endif
++
+ /* Declare an asm function, along with symbols needed to make it
+    inlineable */
+ #define DECL_ASM(ret, name, ...)		\
+diff --git a/include/xen/interface/xen.h b/include/xen/interface/xen.h
+index b33257b..29b362e 100644
+--- a/include/xen/interface/xen.h
++++ b/include/xen/interface/xen.h
+@@ -449,6 +449,45 @@ struct start_info {
+ 	int8_t cmd_line[MAX_GUEST_CMDLINE];
+ };
+ 
++struct dom0_vga_console_info {
++	uint8_t video_type;
++#define XEN_VGATYPE_TEXT_MODE_3 0x03
++#define XEN_VGATYPE_VESA_LFB    0x23
++
++	union {
++		struct {
++			/* Font height, in pixels. */
++			uint16_t font_height;
++			/* Cursor location (column, row). */
++			uint16_t cursor_x, cursor_y;
++			/* Number of rows and columns (dimensions in characters). */
++			uint16_t rows, columns;
++		} text_mode_3;
++
++		struct {
++			/* Width and height, in pixels. */
++			uint16_t width, height;
++			/* Bytes per scan line. */
++			uint16_t bytes_per_line;
++			/* Bits per pixel. */
++			uint16_t bits_per_pixel;
++			/* LFB physical address, and size (in units of 64kB). */
++			uint32_t lfb_base;
++			uint32_t lfb_size;
++			/* RGB mask offsets and sizes, as defined by VBE 1.2+ */
++			uint8_t  red_pos, red_size;
++			uint8_t  green_pos, green_size;
++			uint8_t  blue_pos, blue_size;
++			uint8_t  rsvd_pos, rsvd_size;
++
++			/* VESA capabilities (offset 0xa, VESA command 0x4f00). */
++			uint32_t gbl_caps;
++			/* Mode attributes (offset 0x0, VESA command 0x4f01). */
++			uint16_t mode_attrs;
++		} vesa_lfb;
++	} u;
++};
++
+ /* These flags are passed in the 'flags' field of start_info_t. */
+ #define SIF_PRIVILEGED    (1<<0)  /* Is the domain privileged? */
+ #define SIF_INITDOMAIN    (1<<1)  /* Is this the initial control domain? */
+-- 
+1.7.5.4
+

Modified: dists/sid/linux-2.6/debian/patches/series/2
==============================================================================
--- dists/sid/linux-2.6/debian/patches/series/2	Tue Aug  9 13:47:15 2011	(r17901)
+++ dists/sid/linux-2.6/debian/patches/series/2	Wed Aug 10 12:13:44 2011	(r17902)
@@ -1,3 +1,4 @@
 - features/all/rt2x00-Add-device-ID-for-RT539F-device.patch
 + bugfix/all/stable/3.0.1.patch
 + bugfix/all/perf-do-not-look-at-.-config-for-configuration.patch
++ bugfix/x86/xen-allow-enable-use-of-VGA-console-on-dom0.patch



More information about the Kernel-svn-changes mailing list