Received: by 10.223.185.116 with SMTP id b49csp627219wrg; Wed, 21 Feb 2018 04:24:02 -0800 (PST) X-Google-Smtp-Source: AH8x226+aU0f3Nd7O+JrFoX1h/OolOB5LxiKyAZyzwZDtTTSApMmv1kYBsCQ6b1K2lQ9uS6GFZJO X-Received: by 2002:a17:902:b417:: with SMTP id x23-v6mr2979596plr.339.1519215842480; Wed, 21 Feb 2018 04:24:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519215842; cv=none; d=google.com; s=arc-20160816; b=F2DAyrjJdA2/mhtkeYcMOx8cuLxmDzCVlF6W6O4dqOxHrGwrRxaFy36F/d3SbSNLGG oTgQiQaBiF+FM8Y8vxYHE02cH+6wFOcrgIXPzbFbz1brQq2R3UBeCL69eM9EhbGyhmNG H8wrt0Hbm6afII7LKvTLIOJ8svjlLdltHerY4Tsuw8KVWCfuz+lIGn9YAXsRvmsj/OO7 jr+8TDlwHKCnj7hd3cMvo4KwZ47sNswJZDj6/62Eea4bD+NcRlmSl103N3X/WqI2QMda zhSZwxK+I28VpKQL9Lstm92/kjgE4ZBFtDPvo2vYf+lPTP+zxLPCaroSIeRKnIDrg9oV fi4w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature :arc-authentication-results; bh=eLhcSm/laK6/YPGvf+KzB8ek9+kRQ0ldQeCcFl3G1fY=; b=jk2LF/zw2Jg2HNQxiSL1QOGG4sX41AAAHa4iL23BmJdH7Q+wDNFWcFP0rJ2eLnPqiW qaioikUyMZkoN3YINiHxKjNs9gsA+PsZzWMr+jEunMuQ87T9gPk0/S9S8dcuNWs1l1p4 A2dMn2ZvVn9MCoWhjB53ks/e1F4+SDgLKiT6wtoGixlbqL5ud1NXrR8f8zLti4Hazsoe vu3+O2gQuolN7OwOgTj+XeeRsIexAxpbpnWSP6LFAqtTOl84ulj2qae0v2K00mqt2NsX JFuexkm7MpgCg0vL+JxMyTeY2ZV8k/2J2JcAAdbNm9qdeop0ZlvBbbhOM+JWrIETY98X 0QqA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=H8EHKQqO; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m123si4745511pgm.698.2018.02.21.04.23.47; Wed, 21 Feb 2018 04:24:02 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=H8EHKQqO; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751608AbeBUIrq (ORCPT + 99 others); Wed, 21 Feb 2018 03:47:46 -0500 Received: from mail-lf0-f68.google.com ([209.85.215.68]:41008 "EHLO mail-lf0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750831AbeBUIrp (ORCPT ); Wed, 21 Feb 2018 03:47:45 -0500 Received: by mail-lf0-f68.google.com with SMTP id m69so1218346lfe.8 for ; Wed, 21 Feb 2018 00:47:44 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=eLhcSm/laK6/YPGvf+KzB8ek9+kRQ0ldQeCcFl3G1fY=; b=H8EHKQqOMdHJZp5LA7yMzfqpHbWYzKBsc+FG1Lmv477/FD6sQpQqwTD1hrlVNYshCq EjeWhMG2VNEdtnN0vfyWPnTrxrlr4uGdOMFlDXZ0U4/r3ZntXff3Gm8umagnUjlh1nnR Jk8g0/i6g79ap4/XuCpxMCXSFrln7BHWcaNg7ca1/b+jgMKPuiOCCq67oPBFGd367L17 VBgNvMVsi42s0Dotd6omptU6nP7EJxGdzNP9R2/YGNluNkLDQcTERZKZktWirC+6SSQK DyMsO3zacsoxg/iEGyBcAxhMW7FWYrP2Q9uxKBklGvJX0jsjoYqpbSDHqhn1ENxIwEqn yN/w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=eLhcSm/laK6/YPGvf+KzB8ek9+kRQ0ldQeCcFl3G1fY=; b=WVEnRkZIXMpf/VrsTJKsmImFI6oi96WTZW4/sBNPAWc1Uog8Q48JJv8rSPokI84qye wNne7qWMDAIvH3ADHU9kbjsXkz0hInokRXQiaYuPrRI5hn6A9QEXARWupgwrJ6yKHAS4 7qNVEEdkvIzFWz751dyvRIxu5HySt+6KGPj9LChkkQfG6y5dl1yS2IhuK/gkcJlikwA7 lEx7AUGQCf2soCCpZ3qrLitcOUbA3AT2NGetXJdMV6fRrjUlbk+tmI8Dw6m+iawIfhx0 pA2gFhpj2M13aj5dBmBNAG+v9eVQCZEHTJKBD5BmVkO3qOBbfVMyrDp/qufrY2XTdZCO dv/w== X-Gm-Message-State: APf1xPBc9YUe6gDTsDpnTxuEejyKhRf5tA2KhxANzT7WjSB2byLbkXgO eqO2wv3was/f10O9xuUabq4= X-Received: by 10.25.42.81 with SMTP id f78mr1972536lfl.100.1519202863249; Wed, 21 Feb 2018 00:47:43 -0800 (PST) Received: from [10.17.182.9] (ll-53.209.223.85.sovam.net.ua. [85.223.209.53]) by smtp.gmail.com with ESMTPSA id v6sm3229969ljc.85.2018.02.21.00.47.41 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 21 Feb 2018 00:47:42 -0800 (PST) Subject: Re: [PATCH 1/9] drm/xen-front: Introduce Xen para-virtualized frontend driver To: Juergen Gross , xen-devel@lists.xenproject.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, airlied@linux.ie, daniel.vetter@intel.com, seanpaul@chromium.org, gustavo@padovan.org, boris.ostrovsky@oracle.com, konrad.wilk@oracle.com Cc: Oleksandr Andrushchenko References: <1519200222-20623-1-git-send-email-andr2000@gmail.com> <1519200222-20623-2-git-send-email-andr2000@gmail.com> From: Oleksandr Andrushchenko Message-ID: <91386840-c34a-31a4-2bb3-14a27ececa9c@gmail.com> Date: Wed, 21 Feb 2018 10:47:40 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/21/2018 10:19 AM, Juergen Gross wrote: > On 21/02/18 09:03, Oleksandr Andrushchenko wrote: >> From: Oleksandr Andrushchenko >> >> Introduce skeleton of the para-virtualized Xen display >> frontend driver. This patch only adds required >> essential stubs. >> >> Signed-off-by: Oleksandr Andrushchenko >> --- >> drivers/gpu/drm/Kconfig | 2 + >> drivers/gpu/drm/Makefile | 1 + >> drivers/gpu/drm/xen/Kconfig | 17 ++++++++ >> drivers/gpu/drm/xen/Makefile | 5 +++ >> drivers/gpu/drm/xen/xen_drm_front.c | 83 +++++++++++++++++++++++++++++++++++++ >> 5 files changed, 108 insertions(+) >> create mode 100644 drivers/gpu/drm/xen/Kconfig >> create mode 100644 drivers/gpu/drm/xen/Makefile >> create mode 100644 drivers/gpu/drm/xen/xen_drm_front.c >> >> diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig >> index deeefa7a1773..757825ac60df 100644 >> --- a/drivers/gpu/drm/Kconfig >> +++ b/drivers/gpu/drm/Kconfig >> @@ -289,6 +289,8 @@ source "drivers/gpu/drm/pl111/Kconfig" >> >> source "drivers/gpu/drm/tve200/Kconfig" >> >> +source "drivers/gpu/drm/xen/Kconfig" >> + >> # Keep legacy drivers last >> >> menuconfig DRM_LEGACY >> diff --git a/drivers/gpu/drm/Makefile b/drivers/gpu/drm/Makefile >> index 50093ff4479b..9d66657ea117 100644 >> --- a/drivers/gpu/drm/Makefile >> +++ b/drivers/gpu/drm/Makefile >> @@ -103,3 +103,4 @@ obj-$(CONFIG_DRM_MXSFB) += mxsfb/ >> obj-$(CONFIG_DRM_TINYDRM) += tinydrm/ >> obj-$(CONFIG_DRM_PL111) += pl111/ >> obj-$(CONFIG_DRM_TVE200) += tve200/ >> +obj-$(CONFIG_DRM_XEN) += xen/ >> diff --git a/drivers/gpu/drm/xen/Kconfig b/drivers/gpu/drm/xen/Kconfig >> new file mode 100644 >> index 000000000000..4cca160782ab >> --- /dev/null >> +++ b/drivers/gpu/drm/xen/Kconfig >> @@ -0,0 +1,17 @@ >> +config DRM_XEN >> + bool "DRM Support for Xen guest OS" >> + depends on XEN >> + help >> + Choose this option if you want to enable DRM support >> + for Xen. >> + >> +config DRM_XEN_FRONTEND >> + tristate "Para-virtualized frontend driver for Xen guest OS" >> + depends on DRM_XEN >> + depends on DRM >> + select DRM_KMS_HELPER >> + select VIDEOMODE_HELPERS >> + select XEN_XENBUS_FRONTEND >> + help >> + Choose this option if you want to enable a para-virtualized >> + frontend DRM/KMS driver for Xen guest OSes. >> diff --git a/drivers/gpu/drm/xen/Makefile b/drivers/gpu/drm/xen/Makefile >> new file mode 100644 >> index 000000000000..967074d348f6 >> --- /dev/null >> +++ b/drivers/gpu/drm/xen/Makefile >> @@ -0,0 +1,5 @@ >> +# SPDX-License-Identifier: GPL-2.0 >> + >> +drm_xen_front-objs := xen_drm_front.o >> + >> +obj-$(CONFIG_DRM_XEN_FRONTEND) += drm_xen_front.o >> diff --git a/drivers/gpu/drm/xen/xen_drm_front.c b/drivers/gpu/drm/xen/xen_drm_front.c >> new file mode 100644 >> index 000000000000..fd372fb464a1 >> --- /dev/null >> +++ b/drivers/gpu/drm/xen/xen_drm_front.c >> @@ -0,0 +1,83 @@ >> +/* >> + * Xen para-virtual DRM device >> + * >> + * 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 >> + * (at your option) 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. > Use SPDX identifier instead (same applies for all other new > sources): > > // SPDX-License-Identifier: GPL-2.0 Will update, thank you >> + * >> + * Copyright (C) 2016-2018 EPAM Systems Inc. >> + * >> + * Author: Oleksandr Andrushchenko >> + */ >> + >> +#include >> + >> +#include >> +#include >> +#include >> + >> +#include >> + >> +static void backend_on_changed(struct xenbus_device *xb_dev, >> + enum xenbus_state backend_state) >> +{ >> +} >> + >> +static int xen_drv_probe(struct xenbus_device *xb_dev, >> + const struct xenbus_device_id *id) >> +{ >> + return 0; >> +} >> + >> +static int xen_drv_remove(struct xenbus_device *dev) >> +{ >> + return 0; >> +} >> + >> +static const struct xenbus_device_id xen_drv_ids[] = { >> + { XENDISPL_DRIVER_NAME }, >> + { "" } >> +}; >> + >> +static struct xenbus_driver xen_driver = { >> + .ids = xen_drv_ids, >> + .probe = xen_drv_probe, >> + .remove = xen_drv_remove, >> + .otherend_changed = backend_on_changed, >> +}; >> + >> +static int __init xen_drv_init(void) >> +{ >> + if (!xen_domain()) >> + return -ENODEV; >> + >> + if (xen_initial_domain()) { >> + DRM_ERROR(XENDISPL_DRIVER_NAME " cannot run in initial domain\n"); >> + return -ENODEV; >> + } > Why not? Wouldn't that be possible in case of the backend living in a > driver domain? It is possible (and in my use-case backend indeed runs in a driver domain). I was just not sure if it is really a good idea to allow that. If you think this is ok, then I'll remove this check > > Juergen Thank you, Oleksandr