[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[PATCH v9 4/4] xen: enable dom0less guests to use console_io hypercalls


  • To: <xen-devel@xxxxxxxxxxxxxxxxxxxx>
  • From: Stefano Stabellini <stefano.stabellini@xxxxxxx>
  • Date: Tue, 3 Feb 2026 15:07:57 -0800
  • Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=lists.xenproject.org smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none (0)
  • Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=8qQtk1b20aG/kh9W246LWa03j2XOhWS+O5knVRy/lLE=; b=Cv5ZyW1JjwnUqOyUHSk9NVIUMsAR3Q0OWPJX9GJsi+DkFWcMm/PfkwZ4TasDdvOqRjJSBHWWE8RX2S1go3hAqVJ5x7PUnR6VOW5yCDeWuNg1Be9Yu5kw7iUcYrIptm/i5oSrmOwqF0cAV2/ZtpiJMS5XvILgxbyVjDzxS2W0U36khMTX17FXY25+IXuZGu6m9E7uiZ2RE2NkqzMcsuSWecIjnjaJi+lCsdnZQuJQQS9/iQ6r4Tf70C96K7IT3uzL2BjIU5JWc1iuQztiMyc8PV49OKflNuT0frOSV1WCzgMFLSuvUJy9Btg5/pTl7RU9RIRw0YoCQkFWCx3QpV6pCQ==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=zCzu5gv3hrH7mMw8LprQZ6inysWDAuF+c2MyuO9VrHZvlyiwIFV0v2OVTSowMmIEmvqNyr3lizTEyO7nqidsnKPSXmSV7LzlLr1qPBZhF9UlXbR6ZOztBtWsBKMwy+Fo92pADkvLKW8ehrrL3RzPLKhkXUgq8TWhut6lfjR+5zbwzorJgnZt1qBpZGER+ruhvNKAsj6B4Swv43xi/oPK11xsRWB7npZGHkPNwD5TW1dOIS/7anlMtuXXg13tWgrkWQStYp7VyJI2zhoWQEpbhZ6KHkWutbJsYAHKLsqphCtwnW7TEXj8ElnHoAawtNXcD2NGei6iXL8Xd4JiTfuCvQ==
  • Cc: <grygorii_strashko@xxxxxxxx>, <anthony.perard@xxxxxxxxxx>, <michal.orzel@xxxxxxx>, <julien@xxxxxxx>, <roger.pau@xxxxxxxxxx>, <jason.andryuk@xxxxxxx>, <victorm.lira@xxxxxxx>, <andrew.cooper3@xxxxxxxxxx>, <jbeulich@xxxxxxxx>, <sstabellini@xxxxxxxxxx>, Stefano Stabellini <stefano.stabellini@xxxxxxx>
  • Delivery-date: Tue, 03 Feb 2026 23:08:14 +0000
  • List-id: Xen developer discussion <xen-devel.lists.xenproject.org>

Enable dom0less guests on ARM to use console_io hypercalls:
- set input_allow = true for dom0less domains
- update the in-code comment in console.c
- prioritize the VUART check to retain the same behavior as today

Signed-off-by: Stefano Stabellini <stefano.stabellini@xxxxxxx>
---
 xen/common/device-tree/dom0less-build.c |  2 ++
 xen/drivers/char/console.c              | 16 ++++++++++------
 2 files changed, 12 insertions(+), 6 deletions(-)

diff --git a/xen/common/device-tree/dom0less-build.c 
b/xen/common/device-tree/dom0less-build.c
index 840d14419d..cb7026fa7e 100644
--- a/xen/common/device-tree/dom0less-build.c
+++ b/xen/common/device-tree/dom0less-build.c
@@ -829,6 +829,8 @@ static int __init construct_domU(struct kernel_info *kinfo,
 
     rangeset_destroy(kinfo->xen_reg_assigned);
 
+    d->console->input_allowed = true;
+
     return rc;
 }
 
diff --git a/xen/drivers/char/console.c b/xen/drivers/char/console.c
index b59ebdeddb..7afe9cfd41 100644
--- a/xen/drivers/char/console.c
+++ b/xen/drivers/char/console.c
@@ -610,11 +610,20 @@ static void __serial_rx(char c)
     if ( ACCESS_ONCE(console_rx) == 0 )
         return handle_keypress(c, false);
 
+    /* Includes an is_focus_domain() check. */
     d = console_get_domain();
     if ( !d )
         return;
 
-    if ( is_hardware_domain(d) )
+#ifdef CONFIG_SBSA_VUART_CONSOLE
+    /* Prioritize vpl011 if enabled for this domain */
+    if ( d->arch.vpl011.base_addr )
+    {
+        /* Deliver input to the emulated UART. */
+        rc = vpl011_rx_char_xen(d, c);
+    }
+    else
+#endif
     {
         unsigned long flags;
 
@@ -633,11 +642,6 @@ static void __serial_rx(char c)
          */
         send_guest_domain_virq(d, VIRQ_CONSOLE);
     }
-#ifdef CONFIG_SBSA_VUART_CONSOLE
-    else
-        /* Deliver input to the emulated UART. */
-        rc = vpl011_rx_char_xen(d, c);
-#endif
 
     if ( consoled_is_enabled() )
         /* Deliver input to the PV shim console. */
-- 
2.25.1




 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.