xen/console: Introduce a new console driver for Xen guest
authorroyger <royger@FreeBSD.org>
Thu, 8 Oct 2015 16:39:43 +0000 (16:39 +0000)
committerroyger <royger@FreeBSD.org>
Thu, 8 Oct 2015 16:39:43 +0000 (16:39 +0000)
commit375ecc42dee993e895968c47a125336d3205abcb
tree4d554b6933c62f969ce512c3c8dce2e0ef744afd
parent0412e2f18cedb7c9016cfa6c110f6ed609b8b3cc
xen/console: Introduce a new console driver for Xen guest

The current Xen console driver is crashing very quickly when using it on
an ARM guest. This is because the console lock is recursive and it may
lead to recursion on the tty lock and/or corrupt the ring pointer.

Furthermore, the console lock is not always taken where it should be and has
to be released too early because of the way the console has been designed.

Over the years, code has been modified to support various new features but
the driver has not been reworked.

This new driver has been rewritten with the idea of only having a small set
of specific function to write either via the shared ring or the hypercall
interface.

Note that HVM support has been left aside for now because it requires
additional features which are not yet supported. A follow-up patch will be
sent with HVM guest support.

List of items that may be good to have but not mandatory:
 - Avoid to flush for each character written when using the tty
 - Support multiple consoles

Submitted by: Julien Grall <julien.grall@citrix.com>
Reviewed by: royger
Differential Revision: https://reviews.freebsd.org/D3698
Sponsored by: Citrix Systems R&D
sys/amd64/include/xen/hypercall.h
sys/conf/files
sys/dev/xen/console/console.c [deleted file]
sys/dev/xen/console/xen_console.c [new file with mode: 0644]
sys/dev/xen/console/xencons_ring.c [deleted file]
sys/dev/xen/console/xencons_ring.h [deleted file]
sys/i386/include/xen/hypercall.h
sys/xen/hypervisor.h