Received: by 10.192.165.148 with SMTP id m20csp4362014imm; Tue, 24 Apr 2018 01:09:41 -0700 (PDT) X-Google-Smtp-Source: AIpwx48EkzdSrL4evTBB1GxzOBtHYluR2jajmUlL3fuaS4qvP+V/D2D6aPpBbTtDPv7IUxuC755T X-Received: by 2002:a17:902:9a0b:: with SMTP id v11-v6mr24294210plp.387.1524557381539; Tue, 24 Apr 2018 01:09:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524557381; cv=none; d=google.com; s=arc-20160816; b=HYc8Yz1WJ2rASod/EJp3RFYFJTxio1wGw/s5ySzOLhDK4Vbt4YkCsoEcHKAUYnGxXs S95fT76Ky8lnqVroHsokTU4kTQT0GADEk0JfdLMBHfvIMKj9wQBzFJSsbCSvObZhOu3G ISHOruBru6n18eWqh5poidTd+w7Mv45Hs9uvOpLQ4WIn/AEfAYm9/9fAXyrfNtXbBLLl UHJs17mgT/h/8wjwhoqD8m5xLVVjTQNvG1X+D7onm3axHXM6y3G0EvoEKVmA5rdCh9M3 er0ho7qhsaLpc+LVDTrTrWZb5KBk744IZii0ceHJIxdsdIV4zi+8erh7rzQ+hxso5q2a OYCA== 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=vtJRcr0/F3fkwL29zB+GIB1G3dssU2JbZiKPDgN2J3I=; b=nbbIn/+WD+InlPH+FFD1c8jcbVPydftVUVdooS9udmMexZLIb3F8VWH24JbwnwVe+A 2Rql3Wuk/i8wc8FII734DiRzSfZsS1iKvb64i5Eo5M/WBCQ76sW+1ZVEpN4+Dmup3rrV kYLYwYI+XfcP5Lrz76x9cHH3HE9w6heN0VKfhhwCZDXKOikl2YwXXxs8uw78Z8Bga4iP gCojJlAOdjI2qFFZ4p29H3QjvNdVAkHh8aAa2Ge87dLvad+IgZsylnHvRh6W/CUVqHBo qK1W1iQZlpmQa2Dbrngqwc2I/eXlnvLe4Q17zfBf5D20N63JLLRnjibfEe7Rrv/RMNTi 1LAA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=hwAWO0os; 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 j123si420634pfg.156.2018.04.24.01.09.26; Tue, 24 Apr 2018 01:09:41 -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=hwAWO0os; 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 S1756481AbeDXIHe (ORCPT + 99 others); Tue, 24 Apr 2018 04:07:34 -0400 Received: from mail-lf0-f67.google.com ([209.85.215.67]:38258 "EHLO mail-lf0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756228AbeDXIHZ (ORCPT ); Tue, 24 Apr 2018 04:07:25 -0400 Received: by mail-lf0-f67.google.com with SMTP id z130-v6so18894916lff.5 for ; Tue, 24 Apr 2018 01:07:24 -0700 (PDT) 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=vtJRcr0/F3fkwL29zB+GIB1G3dssU2JbZiKPDgN2J3I=; b=hwAWO0os0hkbGhWOwbJqbZVzuLI7VdJ20xAx2tZHZ4+PZUXA/P/85+Et2frr70tLqU b7skZAPxIuMg7IRl0t8kUM4FWuBF4fPtYQynwnNn/yxXV9NzzrrDoStTZAeT7y7wOkRy vCs/p28vxSNqyo3qX9CZni+cCHBu2qMVeIbtVVbvigr41x1FuD8IAOfiI2E+6aFSL7FQ 0tXkL8xbr4sRKQhxk69XEIFHjP9M9g0FD2oxOcbfKdZG88ijHdr61JLMHwCXTgc2UiF0 J/Ppn2jIt4RNXLRMu5xdV9R/hp4j5hAA0xbj5EwABsZj2Jha7/wlxPP0sCpcQXjXTpQy 6hIQ== 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=vtJRcr0/F3fkwL29zB+GIB1G3dssU2JbZiKPDgN2J3I=; b=CYZ2Ht2+JV1uGbZh0jsgv1yCseYAzbMDKaDBycAjqJav2ahmVwK3SaF0IZSxydcUND 0uqRMJqCvM4S2NwV6+J/e61XSF5PlNEPp/dmj3iRdn6OfNQGvgQ5Wd4qbG8+D7KyMVBY lK0G4qF1WMdahrh358rL65pxuhKka3EX/bOT53QrEgNdlATtcpQlXEDwn7bji9RStObk arVS/r0yihlE11YxNgSXLRL/ynFyudtMZ5iGQuFrPbaTG07YQX0PW/oQI4g/nnYYkFdD axpKRO3+G1d/LXEG+UpBfWMgItEcRGbqCQfhNSa5USvkiB/NoPuR1pfe25PK4pGSnaF0 R0Zg== X-Gm-Message-State: ALQs6tB+CC+tZTI/onpTCfl4iepUP/LvuFX4q0MlftIfkFlihaMvIyK1 1Q6vYFRoz74Z0IKl9sjBxqA= X-Received: by 2002:a19:de9c:: with SMTP id i28-v6mr11367661lfl.75.1524557243506; Tue, 24 Apr 2018 01:07:23 -0700 (PDT) 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 h126-v6sm3203771lfh.97.2018.04.24.01.07.21 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 24 Apr 2018 01:07:22 -0700 (PDT) Subject: Re: [Xen-devel] [PATCH 0/1] drm/xen-zcopy: Add Xen zero-copy helper DRM driver To: Juergen Gross , Boris Ostrovsky , Wei Liu Cc: =?UTF-8?Q?Roger_Pau_Monn=c3=a9?= , Artem Mygaiev , Dongwon Kim , konrad.wilk@oracle.com, airlied@linux.ie, "Oleksandr_Andrushchenko@epam.com" , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, "Potrola, MateuszX" , xen-devel@lists.xenproject.org, daniel.vetter@intel.com References: <5d8fec7f-956c-378f-be90-f45029385740@gmail.com> <20180416192905.GA18096@downor-Z87X-UD5H> <20180417075928.GT31310@phenom.ffwll.local> <20180417205744.GA15930@downor-Z87X-UD5H> <41487acb-a67a-8933-d0c3-702c19b0938e@gmail.com> <20180418073508.ptvntwedczpvl7bx@MacBook-Pro-de-Roger.local> <20180418101058.hyqk3gr3b2ibxswu@MacBook-Pro-de-Roger.local> <20180420071914.GG31310@phenom.ffwll.local> <76cdc65a-7bb1-9377-7bc5-6164e32f7b5d@gmail.com> <20180423115242.ywdwqblj2aseu3fr@citrix.com> <61105351-8896-072b-abf0-757c7f6c0edf@gmail.com> <30ddb005-96c8-f47c-2e23-4e0d354e5842@gmail.com> From: Oleksandr Andrushchenko Message-ID: Date: Tue, 24 Apr 2018 11:07:21 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 04/24/2018 10:51 AM, Juergen Gross wrote: > On 24/04/18 07:43, Oleksandr Andrushchenko wrote: >> On 04/24/2018 01:41 AM, Boris Ostrovsky wrote: >>> On 04/23/2018 08:10 AM, Oleksandr Andrushchenko wrote: >>>> On 04/23/2018 02:52 PM, Wei Liu wrote: >>>>> On Fri, Apr 20, 2018 at 02:25:20PM +0300, Oleksandr Andrushchenko >>>>> wrote: >>>>>>>>       the gntdev. >>>>>>>> >>>>>>>> I think this is generic enough that it could be implemented by a >>>>>>>> device not tied to Xen. AFAICT the hyper_dma guys also wanted >>>>>>>> something similar to this. >>>>>>> You can't just wrap random userspace memory into a dma-buf. We've >>>>>>> just had >>>>>>> this discussion with kvm/qemu folks, who proposed just that, and >>>>>>> after a >>>>>>> bit of discussion they'll now try to have a driver which just wraps a >>>>>>> memfd into a dma-buf. >>>>>> So, we have to decide either we introduce a new driver >>>>>> (say, under drivers/xen/xen-dma-buf) or extend the existing >>>>>> gntdev/balloon to support dma-buf use-cases. >>>>>> >>>>>> Can anybody from Xen community express their preference here? >>>>>> >>>>> Oleksandr talked to me on IRC about this, he said a few IOCTLs need to >>>>> be added to either existing drivers or a new driver. >>>>> >>>>> I went through this thread twice and skimmed through the relevant >>>>> documents, but I couldn't see any obvious pros and cons for either >>>>> approach. So I don't really have an opinion on this. >>>>> >>>>> But, assuming if implemented in existing drivers, those IOCTLs need to >>>>> be added to different drivers, which means userspace program needs to >>>>> write more code and get more handles, it would be slightly better to >>>>> implement a new driver from that perspective. >>>> If gntdev/balloon extension is still considered: >>>> >>>> All the IOCTLs will be in gntdev driver (in current xen-zcopy >>>> terminology): >>>>   - DRM_ICOTL_XEN_ZCOPY_DUMB_FROM_REFS >>>>   - DRM_IOCTL_XEN_ZCOPY_DUMB_TO_REFS >>>>   - DRM_IOCTL_XEN_ZCOPY_DUMB_WAIT_FREE >>>> >>>> Balloon driver extension, which is needed for contiguous/DMA >>>> buffers, will be to provide new *kernel API*, no UAPI is needed. >>>> >>> So I am obviously a bit late to this thread, but why do you need to add >>> new ioctls to gntdev and balloon? Doesn't this driver manage to do what >>> you want without any extensions? >> 1. I only (may) need to add IOCTLs to gntdev >> 2. balloon driver needs to be extended, so it can allocate >> contiguous (DMA) memory, not IOCTLs/UAPI here, all lives >> in the kernel. >> 3. The reason I need to extend gnttab with new IOCTLs is to >> provide new functionality to create a dma-buf from grant references >> and to produce grant references for a dma-buf. This is what I have as UAPI >> description for xen-zcopy driver: >> >> 1. DRM_IOCTL_XEN_ZCOPY_DUMB_FROM_REFS >> This will create a DRM dumb buffer from grant references provided >> by the frontend. The intended usage is: >>   - Frontend >>     - creates a dumb/display buffer and allocates memory >>     - grants foreign access to the buffer pages >>     - passes granted references to the backend >>   - Backend >>     - issues DRM_XEN_ZCOPY_DUMB_FROM_REFS ioctl to map >>       granted references and create a dumb buffer >>     - requests handle to fd conversion via DRM_IOCTL_PRIME_HANDLE_TO_FD >>     - requests real HW driver/consumer to import the PRIME buffer with >>       DRM_IOCTL_PRIME_FD_TO_HANDLE >>     - uses handle returned by the real HW driver >>   - at the end: >>     o closes real HW driver's handle with DRM_IOCTL_GEM_CLOSE >>     o closes zero-copy driver's handle with DRM_IOCTL_GEM_CLOSE >>     o closes file descriptor of the exported buffer >> >> 2. DRM_IOCTL_XEN_ZCOPY_DUMB_TO_REFS >> This will grant references to a dumb/display buffer's memory provided by >> the >> backend. The intended usage is: >>   - Frontend >>     - requests backend to allocate dumb/display buffer and grant references >>       to its pages >>   - Backend >>     - requests real HW driver to create a dumb with >> DRM_IOCTL_MODE_CREATE_DUMB >>     - requests handle to fd conversion via DRM_IOCTL_PRIME_HANDLE_TO_FD >>     - requests zero-copy driver to import the PRIME buffer with >>       DRM_IOCTL_PRIME_FD_TO_HANDLE >>     - issues DRM_XEN_ZCOPY_DUMB_TO_REFS ioctl to >>       grant references to the buffer's memory. >>     - passes grant references to the frontend >>  - at the end: >>     - closes zero-copy driver's handle with DRM_IOCTL_GEM_CLOSE >>     - closes real HW driver's handle with DRM_IOCTL_GEM_CLOSE >>     - closes file descriptor of the imported buffer >> >> 3. DRM_XEN_ZCOPY_DUMB_WAIT_FREE >> This will block until the dumb buffer with the wait handle provided be >> freed: >> this is needed for synchronization between frontend and backend in case >> frontend provides grant references of the buffer via >> DRM_XEN_ZCOPY_DUMB_FROM_REFS IOCTL and which must be released before >> backend replies with XENDISPL_OP_DBUF_DESTROY response. >> wait_handle must be the same value returned while calling >> DRM_XEN_ZCOPY_DUMB_FROM_REFS IOCTL. >> >> So, as you can see the above functionality is not covered by the >> existing UAPI >> of the gntdev driver. >> Now, if we change dumb -> dma-buf and remove DRM code (which is only a >> wrapper >> here on top of dma-buf) we get new driver for dma-buf for Xen. >> >> This is why I have 2 options here: either create a dedicated driver for >> this >> (e.g. re-work xen-zcopy to be DRM independent and put it under >> drivers/xen/xen-dma-buf, for example) or extend the existing gntdev driver >> with the above UAPI + make changes to the balloon driver to provide kernel >> API for DMA buffer allocations. > Which user component would use the new ioctls? It is currently used by the display backend [1] and will probably be used by the hyper-dmabuf frontend/backend (Dongwon from Intel can provide more info on this). > > I'm asking because I'm not very fond of adding more linux specific > functions to libgnttab which are not related to a specific Xen version, > but to a kernel version. Hm, I was not thinking about this UAPI to be added to libgnttab. It seems it can be used directly w/o wrappers in user-space > > So doing this in a separate driver seems to be the better option in > this regard. Well, from maintenance POV it is easier for me to have it all in a separate driver as all dma-buf related functionality will reside at one place. This also means that no changes to existing drivers will be needed (if it is ok to have ballooning in/out code for DMA buffers (allocated with dma_alloc_xxx) not in the balloon driver) > > Juergen [1] https://github.com/xen-troops/displ_be