Received: by 10.213.65.68 with SMTP id h4csp1252734imn; Thu, 29 Mar 2018 00:51:04 -0700 (PDT) X-Google-Smtp-Source: AIpwx49ZU1JrzohZkx79xhMSn6uorBKcVcBUvTvLmz1BiRyWIOXHQW5ydhcMEQYd8UdmqAFluckG X-Received: by 2002:a17:902:8508:: with SMTP id bj8-v6mr695625plb.292.1522309864127; Thu, 29 Mar 2018 00:51:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522309864; cv=none; d=google.com; s=arc-20160816; b=zcbuoDhxXRu3ffPxwZClhhAUid5z4XiWEmTJpACEs98Dkr0jaZDXQNWdGRDqdyiaa/ o6o4MeMI01IeGjomhi+quhO8ezrG8sWnrz8LKm/bJQ0bitvEokWiC69nBXkzS6M/GIne vJ0mQp+y4Herqm0XUMMkQLyPzZO3A17HpTWnmdZiRyT8M7Tf63ahJkWBxo0SUTxfpqlk j+pfWOfG94Saop+YME87cANZsgeQjLtpOjpPkVy3F0666IbKRGJeJB0FsrAjfTANOlzC b4cubduqCnhD9dB7wFV63EnMxBhrWc7svZ6X244UyciLkeN1SwlpLyvVD9SyirMFMmfi l76g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language:in-reply-to:mime-version :user-agent:date:message-id:from:references:to:subject :dkim-signature:arc-authentication-results; bh=8f7bHJdQsotFX27O0xSc2WVHKBnHjOXvefrzJGSU3yU=; b=sSr90EAVBp4Brb5B97Hi7dWMvFQThIBQCGYHdaAVJ2ALIvQYL+ORCtWrLq+gvxvvWl poqqK+la3q3+aTyEZPPie8N2A1cIlGYSsNpMZ1vJ5XrHrmbpJQR5PN9BTL5BDBlIo+6q NOv7HU0WbQKP0Z2GtG+0rku09IuLFQLnHQSNJEUdG6oEb3DcLc6xD/zzjDpxtY+zDs8M QbTEUDBUqJq6DuqpSDz5wM6dnyUFsSbjaluZYYxs6VomyzIAWAyJQf7DiF9fYTbgOrXc Bbic04kmIDSfn9FdKjBYDmn8x/EXlFhbQ1NbMUxJQBGCRF5mqns8u9XF8J8Za67ZVzzd DVog== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=eABgL+hj; 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 l5si3729092pgn.723.2018.03.29.00.50.49; Thu, 29 Mar 2018 00:51:04 -0700 (PDT) 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=eABgL+hj; 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 S1752125AbeC2Htv (ORCPT + 99 others); Thu, 29 Mar 2018 03:49:51 -0400 Received: from mail-wm0-f66.google.com ([74.125.82.66]:37632 "EHLO mail-wm0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751230AbeC2Htq (ORCPT ); Thu, 29 Mar 2018 03:49:46 -0400 Received: by mail-wm0-f66.google.com with SMTP id r131so9706699wmb.2 for ; Thu, 29 Mar 2018 00:49:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:references:from:message-id:date:user-agent:mime-version :in-reply-to:content-language; bh=8f7bHJdQsotFX27O0xSc2WVHKBnHjOXvefrzJGSU3yU=; b=eABgL+hjeMmxKnZ6PI+AG6aeV5L0YKp8pLNkoWQtYnBlw9gD6jCipT76RHvff636N5 DjOskEPXygige3N8yhH59AUCXj0w/BgzYhf2rgiKAOSGSa/ehKOPrWj/9JAD5/NSAk5b ttsrXww/JNzHxAJRjwxAIcD+mHrtOaVWPRmJgqzy0vxfv6XucspYrOM1StYfpO7lblze 3Tlt0SV3zedmUA5/FZZ1gwHt06DaEtIRySUF8BSrS7nYf5J8e5QvF/YsXiSu6QJoy7U2 0t7fruGvYv4V7OEXepDLTITvu3mORZeAjXgcb9N4IGU9lFnFH7jFnKYHSDjIbAhq/yzT G8rA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language; bh=8f7bHJdQsotFX27O0xSc2WVHKBnHjOXvefrzJGSU3yU=; b=UcNqV9NpoEOKQRjy9u4eF2O62bMzAO3mwkaOjewte8X5TydjB61kOLKvcXsWN3sfFx FayBm192HdwkYZ73hnoryIiPyO8/eKl3H48UGW4TdBodVHdTbgBOBbE0253S0b/rVttC L5fo3IIvAYa2TM4/sHvF4fnADW0HU9Pa+qeE6xRQSAFPoI2M99qjLWQvUM5YU4Jxp7M8 uUdYEurBMku5eHJgIDy2szSS4obxPQqgzAqKKbd7/jaEB2n9wwsasaKZpVLWnZRr7Jmw V5q5g8SYltE9Bhwm4w4TntNvZ+p1t5P2cTwT06c6a8vAbca1KVGli/BlWudPBJk95FaJ zqFg== X-Gm-Message-State: AElRT7EuNfL0O53ouGeEfzXF2PlHowS3iD3Thu4tyai2zhw68v4Ou9AK pCXVRGca5LWz1/v02BFdN6I= X-Received: by 10.28.239.18 with SMTP id n18mr5275002wmh.56.1522309785266; Thu, 29 Mar 2018 00:49:45 -0700 (PDT) Received: from [10.17.182.9] (ll-59.209.223.85.sovam.net.ua. [85.223.209.59]) by smtp.gmail.com with ESMTPSA id 142sm1383830wmq.47.2018.03.29.00.49.43 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 29 Mar 2018 00:49:43 -0700 (PDT) Subject: Re: [PATCH v4 2/2] drm/xen-front: Add support for Xen PV display frontend To: daniel.vetter@intel.com, jgross@suse.com, konrad.wilk@oracle.com, airlied@linux.ie, Oleksandr Andrushchenko , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, xen-devel@lists.xenproject.org, boris.ostrovsky@oracle.com References: <1522219661-26827-1-git-send-email-andr2000@gmail.com> <1522219661-26827-3-git-send-email-andr2000@gmail.com> <20180328074251.GE14155@phenom.ffwll.local> <32481355-27f6-695b-c6c1-8113ea268a33@gmail.com> <20180329071748.GG3881@phenom.ffwll.local> From: Oleksandr Andrushchenko Message-ID: Date: Thu, 29 Mar 2018 10:49:42 +0300 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: <20180329071748.GG3881@phenom.ffwll.local> Content-Type: multipart/mixed; boundary="------------0F431B0390EA6413AB0422ED" Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is a multi-part message in MIME format. --------------0F431B0390EA6413AB0422ED Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit On 03/29/2018 10:17 AM, Daniel Vetter wrote: > On Wed, Mar 28, 2018 at 01:29:46PM +0300, Oleksandr Andrushchenko wrote: >> Hi, Daniel! >> >> I just noticed I have missed one change in the patch: >> the below must be static. >> >> On 03/28/2018 10:42 AM, Daniel Vetter wrote: >>> +enum drm_mode_status display_mode_valid(struct drm_crtc *crtc, >>> + const struct drm_display_mode *mode) >>> +{ >>> + struct xen_drm_front_drm_pipeline *pipeline = >>> + container_of(crtc, >> Could you please amend the patch in attachment >> when merging, so I don't resend? > Merging is up to you, as soon as you have your commit rights. Thank you, meanwhile I'll need to rebase onto the latest drm-tip fixing 2 more minor issues (attached) and making the driver work after the API change [1]. So, I'll post v4 right after fd.o is back online with the v3..v4 diff to make review simpler > -Daniel Thank you, Oleksandr >> Thank you in advance, >> Oleksandr >> From 3a82d76bd3d954056b760e5d1d09e2f96a2786ef Mon Sep 17 00:00:00 2001 >> From: Oleksandr Andrushchenko >> Date: Wed, 28 Mar 2018 13:24:04 +0300 >> Subject: [PATCH] drm/xen-front: Make display_mode_valid static >> >> Signed-off-by: Oleksandr Andrushchenko >> --- >> drivers/gpu/drm/xen/xen_drm_front_kms.c | 2 +- >> 1 file changed, 1 insertion(+), 1 deletion(-) >> >> diff --git a/drivers/gpu/drm/xen/xen_drm_front_kms.c b/drivers/gpu/drm/xen/xen_drm_front_kms.c >> index 545049dfaf0a..bd676be5a0db 100644 >> --- a/drivers/gpu/drm/xen/xen_drm_front_kms.c >> +++ b/drivers/gpu/drm/xen/xen_drm_front_kms.c >> @@ -273,7 +273,7 @@ static void display_update(struct drm_simple_display_pipe *pipe, >> drm_dev_exit(idx); >> } >> >> -enum drm_mode_status display_mode_valid(struct drm_crtc *crtc, >> +static enum drm_mode_status display_mode_valid(struct drm_crtc *crtc, >> const struct drm_display_mode *mode) >> { >> struct xen_drm_front_drm_pipeline *pipeline = >> -- >> 2.7.4 >> >> _______________________________________________ >> dri-devel mailing list >> dri-devel@lists.freedesktop.org >> https://lists.freedesktop.org/mailman/listinfo/dri-devel > [1] https://github.com/freedesktop/drm-misc/commit/0c9c7fd00e17907efb35697ecb9f2df39a0b536c --------------0F431B0390EA6413AB0422ED Content-Type: text/x-patch; name="0001-drm-xen-front-Free-page-on-event-channel-error-path.patch" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename*0="0001-drm-xen-front-Free-page-on-event-channel-error-path.pat"; filename*1="ch" From e16847ef23d19106c6855951674624bfd37e4209 Mon Sep 17 00:00:00 2001 From: Oleksandr Andrushchenko Date: Thu, 29 Mar 2018 08:54:25 +0300 Subject: [PATCH 1/2] drm/xen-front: Free page on event channel error path While creating an event channel a page was leaked in case of error. Fix this by freeing the page. Signed-off-by: Oleksandr Andrushchenko --- drivers/gpu/drm/xen/xen_drm_front_evtchnl.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/xen/xen_drm_front_evtchnl.c b/drivers/gpu/drm/xen/xen_drm_front_evtchnl.c index e521785fd22b..02b6f3d9fe4c 100644 --- a/drivers/gpu/drm/xen/xen_drm_front_evtchnl.c +++ b/drivers/gpu/drm/xen/xen_drm_front_evtchnl.c @@ -186,8 +186,10 @@ static int evtchnl_alloc(struct xen_drm_front_info *front_info, int index, sring, XEN_PAGE_SIZE); ret = xenbus_grant_ring(xb_dev, sring, 1, &gref); - if (ret < 0) + if (ret < 0) { + free_page(page); goto fail; + } handler = evtchnl_interrupt_ctrl; } else { @@ -195,8 +197,10 @@ static int evtchnl_alloc(struct xen_drm_front_info *front_info, int index, ret = gnttab_grant_foreign_access(xb_dev->otherend_id, virt_to_gfn((void *)page), 0); - if (ret < 0) + if (ret < 0) { + free_page(page); goto fail; + } gref = ret; handler = evtchnl_interrupt_evt; -- 2.7.4 --------------0F431B0390EA6413AB0422ED Content-Type: text/x-patch; name="0002-drm-xen-front-Align-documentation-title-w-other-driv.patch" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename*0="0002-drm-xen-front-Align-documentation-title-w-other-driv.pa"; filename*1="tch" From a6668b48003b46cd711f7e56faaf35dbad769c03 Mon Sep 17 00:00:00 2001 From: Oleksandr Andrushchenko Date: Thu, 29 Mar 2018 09:13:11 +0300 Subject: [PATCH 2/2] drm/xen-front: Align documentation title w/ other drivers Align title of the documentation for the driver with the rest of the drivers, e.g. have drm/xen-front in front of the title. Signed-off-by: Oleksandr Andrushchenko --- Documentation/gpu/xen-front.rst | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Documentation/gpu/xen-front.rst b/Documentation/gpu/xen-front.rst index 8188e03c9d23..009d942386c5 100644 --- a/Documentation/gpu/xen-front.rst +++ b/Documentation/gpu/xen-front.rst @@ -1,6 +1,6 @@ -==================================== -Xen para-virtualized frontend driver -==================================== +==================================================== + drm/xen-front Xen para-virtualized frontend driver +==================================================== This frontend driver implements Xen para-virtualized display according to the display protocol described at -- 2.7.4 --------------0F431B0390EA6413AB0422ED--