Received: by 10.223.185.116 with SMTP id b49csp2389675wrg; Mon, 5 Mar 2018 01:55:14 -0800 (PST) X-Google-Smtp-Source: AG47ELtWPuo6EpmDJTapbX25IJBbu3zv2cgDMenXS40DdqVntS+0Bm0gqR41bdL1eTaogO1B4YUR X-Received: by 10.98.212.80 with SMTP id u16mr14857196pfl.58.1520243714142; Mon, 05 Mar 2018 01:55:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520243714; cv=none; d=google.com; s=arc-20160816; b=gBfklDrfsjiSuHwPea0NbCaJAB2svpBWnetmKIJZCoNLJvl24qJ7IPJ29jL8uVwZJo Wj/Ol+wHDEeXUD9lymSeGhvXACGgwzTZjFjnlGk5fMUX4l4bN9tfld9rLE5MDlfIPIz7 lb6qvH7G06Tlingnf9NOlBIYJnFpgRy/h5BPyXZ49jdtWZzsMDGhmx2sAWH1BfObuNp/ 5Xc/Dmx4a0MKUxi2ps0bjhdJCsaCTUGkDJFTuNdEXkt9t3sQux1lLeJu5GiNfZv3NbI2 5+LLPDJytNKoWkh884NWC9YyNFtmawkAPCYCqUgCNZqMIHUgr16Wr+uw2xSzy7+UJmfB uWoA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:mail-followup-to :message-id:subject:cc:to:from:date:dkim-signature :arc-authentication-results; bh=9Bo2k+8BspUVlY8pfpjit5KTFekDr4/F+NC5X+OWWSU=; b=BdszCSWNH/9WQAqx9Rblcu5sWbl2O6CDcJfcJ0ohLzBXVdjgCKb/TZ+3tYRgU6k3qM g4TNFmnJsO2mUl1vvWkklsmEP242LK+aqIoq9iEFcw0aGBtpO+mCu+31T86Yb0D6FLfq Du4ofZKYSWUcNybMCJQmqZ+qwaplzJLi4xdkWhHXGC6rxON2Kh7wq6qfWgGf8c1FD7/i LXrTqZ0Djy3TLYh08Nt/6o727cNu+PnsynahGzokMppcvcwwdoB4o/8++l9HauvTaKdq h1ChSoRPWe4TlZXPXnz3eKp86UuMsEH6zw1QNFACEyQovDjlw5/3LN9V+Vq1bbKc78q2 zhQg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b=DfQt3agh; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 68-v6si9108988pla.767.2018.03.05.01.54.59; Mon, 05 Mar 2018 01:55:14 -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=fail header.i=@ffwll.ch header.s=google header.b=DfQt3agh; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752659AbeCEJYD (ORCPT + 99 others); Mon, 5 Mar 2018 04:24:03 -0500 Received: from mail-wm0-f66.google.com ([74.125.82.66]:51613 "EHLO mail-wm0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752482AbeCEJX5 (ORCPT ); Mon, 5 Mar 2018 04:23:57 -0500 Received: by mail-wm0-f66.google.com with SMTP id h21so14334693wmd.1 for ; Mon, 05 Mar 2018 01:23:56 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=sender:date:from:to:cc:subject:message-id:mail-followup-to :references:mime-version:content-disposition:in-reply-to:user-agent; bh=9Bo2k+8BspUVlY8pfpjit5KTFekDr4/F+NC5X+OWWSU=; b=DfQt3aghCQOpOdG3VcnK+snNBJWixhGIbJQQARxiCExZwV22Bx0oxvWnwGzt8RD1GB kx/4OzZe8cfw/tV9xBxUyTLQmfvgomIj/fOlQEh3njIzYC6o5MZMDOsHbwrjXb+R5myE Don4z6CeXoM54T+9Wh+3/OogHI7U9yq9rmh+s= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :mail-followup-to:references:mime-version:content-disposition :in-reply-to:user-agent; bh=9Bo2k+8BspUVlY8pfpjit5KTFekDr4/F+NC5X+OWWSU=; b=sYlSEMg7ockjJAau1jUCu8mPZA75tH1NnSeVBnp7m0LX/swr8fY4qNTeLXJ+XjLyu9 /ntg/UY1CF9vPEwfXiMeW4A5KPLgMQHIbN8oljlL6/zsd569KqxSkZg5rZgM7YpvJMYA Kkfo8FGDAM38WEfNoGe4/oSKz9xL+kmW1LMqN5xGHg6bbrW3K+5yZeBlgpyGmj37L9hE aY3sE0P5QzHKQkLODvutCcrrwZKZfajHOVTeDgi5+xS8Vti/YiSqx9JMTZV55/1CuBv0 Dn0qcD15XqGMkBo5JO1cJrCI5or7ahKibvkiYI7ym3loVAQp9TPyv5yqR5rEb9m4FSwn 57pw== X-Gm-Message-State: APf1xPAKPwBG53SZZuM7KhfC7hJ+PjFJq64p1yNree45WPQHP9t5w+1Z oSyhwq7XhyFdLC0Ao5Y/SewA7A== X-Received: by 10.80.215.74 with SMTP id i10mr17589575edj.95.1520241835863; Mon, 05 Mar 2018 01:23:55 -0800 (PST) Received: from phenom.ffwll.local ([2a02:168:5635:0:39d2:f87e:2033:9f6]) by smtp.gmail.com with ESMTPSA id x7sm10483222edi.27.2018.03.05.01.23.54 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 05 Mar 2018 01:23:55 -0800 (PST) Date: Mon, 5 Mar 2018 10:23:53 +0100 From: Daniel Vetter To: Oleksandr Andrushchenko Cc: 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, jgross@suse.com, boris.ostrovsky@oracle.com, konrad.wilk@oracle.com, Oleksandr Andrushchenko Subject: Re: [PATCH 7/9] drm/xen-front: Implement KMS/connector handling Message-ID: <20180305092353.GI22212@phenom.ffwll.local> Mail-Followup-To: Oleksandr Andrushchenko , 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, jgross@suse.com, boris.ostrovsky@oracle.com, konrad.wilk@oracle.com, Oleksandr Andrushchenko References: <1519200222-20623-1-git-send-email-andr2000@gmail.com> <1519200222-20623-8-git-send-email-andr2000@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1519200222-20623-8-git-send-email-andr2000@gmail.com> X-Operating-System: Linux phenom 4.14.0-3-amd64 User-Agent: Mutt/1.9.3 (2018-01-21) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 21, 2018 at 10:03:40AM +0200, Oleksandr Andrushchenko wrote: > From: Oleksandr Andrushchenko > > Implement kernel modesetiing/connector handling using > DRM simple KMS helper pipeline: > > - implement KMS part of the driver with the help of DRM > simple pipepline helper which is possible due to the fact > that the para-virtualized driver only supports a single > (primary) plane: > - initialize connectors according to XenStore configuration > - handle frame done events from the backend > - generate vblank events > - create and destroy frame buffers and propagate those > to the backend > - propagate set/reset mode configuration to the backend on display > enable/disable callbacks > - send page flip request to the backend and implement logic for > reporting backend IO errors on prepare fb callback > > - implement virtual connector handling: > - support only pixel formats suitable for single plane modes > - make sure the connector is always connected > - support a single video mode as per para-virtualized driver > configuration > > Signed-off-by: Oleksandr Andrushchenko I think once you've removed the midlayer in the previous patch it would makes sense to merge the 2 patches into 1. Bunch more comments below. -Daniel > --- > drivers/gpu/drm/xen/Makefile | 2 + > drivers/gpu/drm/xen/xen_drm_front_conn.c | 125 +++++++++++++ > drivers/gpu/drm/xen/xen_drm_front_conn.h | 35 ++++ > drivers/gpu/drm/xen/xen_drm_front_drv.c | 15 ++ > drivers/gpu/drm/xen/xen_drm_front_drv.h | 12 ++ > drivers/gpu/drm/xen/xen_drm_front_kms.c | 299 +++++++++++++++++++++++++++++++ > drivers/gpu/drm/xen/xen_drm_front_kms.h | 30 ++++ > 7 files changed, 518 insertions(+) > create mode 100644 drivers/gpu/drm/xen/xen_drm_front_conn.c > create mode 100644 drivers/gpu/drm/xen/xen_drm_front_conn.h > create mode 100644 drivers/gpu/drm/xen/xen_drm_front_kms.c > create mode 100644 drivers/gpu/drm/xen/xen_drm_front_kms.h > > diff --git a/drivers/gpu/drm/xen/Makefile b/drivers/gpu/drm/xen/Makefile > index d3068202590f..4fcb0da1a9c5 100644 > --- a/drivers/gpu/drm/xen/Makefile > +++ b/drivers/gpu/drm/xen/Makefile > @@ -2,6 +2,8 @@ > > drm_xen_front-objs := xen_drm_front.o \ > xen_drm_front_drv.o \ > + xen_drm_front_kms.o \ > + xen_drm_front_conn.o \ > xen_drm_front_evtchnl.o \ > xen_drm_front_shbuf.o \ > xen_drm_front_cfg.o > diff --git a/drivers/gpu/drm/xen/xen_drm_front_conn.c b/drivers/gpu/drm/xen/xen_drm_front_conn.c > new file mode 100644 > index 000000000000..d9986a2e1a3b > --- /dev/null > +++ b/drivers/gpu/drm/xen/xen_drm_front_conn.c > @@ -0,0 +1,125 @@ > +/* > + * 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. > + * > + * Copyright (C) 2016-2018 EPAM Systems Inc. > + * > + * Author: Oleksandr Andrushchenko > + */ > + > +#include > +#include > + > +#include