Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp4772943imd; Tue, 30 Oct 2018 07:14:11 -0700 (PDT) X-Google-Smtp-Source: AJdET5dh7gxjOrrrcPnmvenoFBWvjF5jGJObzUVn/pkduDnD+PyZJrPlPzjX/4WntDFpY0sBDOSi X-Received: by 2002:a63:9a09:: with SMTP id o9mr16521615pge.94.1540908850863; Tue, 30 Oct 2018 07:14:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540908850; cv=none; d=google.com; s=arc-20160816; b=wb3FLCkIEHj3S4K6rdhVBKdibfyOlUbFBsCTirhlAK8qKVGK09Mfs7v0H/2lL7vpv4 G2Gl0qX0cW0iHK97JAoqsejDhWY0aamRx0Ft47gcyWLrTueUxLo6ak91evo4DAWCIBJL dW7WyVPsFhbdXiWhcOq//jHAe5E+Tpe7tACWK/6hgDEU07kUvAdm4u9mGvt8ooXNhcBt /nBZGhvkdOfR7wJY1SEsq8qDUmgN1LnbZe3uQPp4G20ncI834LTy302k2NcKTYcKRI79 7I/gcV0TrqYLxxEAzN7RtKwhXHSmBl2AA6ZH6rLEIIAXRX14AI4sw0s858AIjvmMc8sk A12Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=5Ad89uNrru7yFGWtmS1GlTbYipXiO9MoWvJf1J1lWLg=; b=w/E704bEXMYRjw46UFo0TWtTWtIvxYlzQ9H8tYpCiqpoWPHfDQcCefuLoWvUWQu/5A 5HiOvIGV52REWtaZwumngVxRvbsqujoXUgAoOrmYvOzGkF9GVkMTzHX870tJqydJy+uZ AfRqx7tTOd7UubYENCfKxf9iPRqra1vH+7g8K+EQKPtgZ4/QvCPKrMwObSNqNvmdrWJE qV6H88gfU0KnYhy+9UM/I8TjuTKVk/ynIFA0Cu88xpZ3hZ/GN1LPkG+m2R4gEL5wlNuB 4PUSYPMNsh0CfU7dts+5yJTq2LXEy0mUlXhnIKqCcvTt7tIsL8lIQqHBhBQT4njkOD78 vnUg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b=LrZPeuBP; 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=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r68-v6si24823890pfa.15.2018.10.30.07.13.53; Tue, 30 Oct 2018 07:14:10 -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=@oracle.com header.s=corp-2018-07-02 header.b=LrZPeuBP; 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=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728243AbeJ3XGi (ORCPT + 99 others); Tue, 30 Oct 2018 19:06:38 -0400 Received: from aserp2120.oracle.com ([141.146.126.78]:34502 "EHLO aserp2120.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727768AbeJ3XGi (ORCPT ); Tue, 30 Oct 2018 19:06:38 -0400 Received: from pps.filterd (aserp2120.oracle.com [127.0.0.1]) by aserp2120.oracle.com (8.16.0.22/8.16.0.22) with SMTP id w9UE4LPJ112338; Tue, 30 Oct 2018 14:12:52 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=subject : to : cc : references : from : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=corp-2018-07-02; bh=5Ad89uNrru7yFGWtmS1GlTbYipXiO9MoWvJf1J1lWLg=; b=LrZPeuBPb671czKH2YHsVPtVhHo7+cT08BsvUeDO6T/Rq1w+CGUkUXACiTiketEETAln htayi+Qy7bBBLw8wRTO4bT/qKI4Wi1YhLQlJZqe0Bn994D9+VNKkEx42/xCvgslzAo3M 6rldn0WzrjEO/PfTj1IFZHhxzXtLEWz3d43jc2sX4mk9d3cXLexbbhmus2FHrlggRcdf dFMebGa476vOeGFieuy5/OEnGBDadAw2NYMB5UYX0J+T29bCeoN5ninfKbjQ3B4hnlLv 0yVe7fAhxfgPzS9lH2P3hxSVP1edfP1CiQP9XBRWMaCeEwkOrKhbmIrolm/Vb5XN2VwM Kw== Received: from userv0021.oracle.com (userv0021.oracle.com [156.151.31.71]) by aserp2120.oracle.com with ESMTP id 2ncfypvhdw-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 30 Oct 2018 14:12:51 +0000 Received: from aserv0122.oracle.com (aserv0122.oracle.com [141.146.126.236]) by userv0021.oracle.com (8.14.4/8.14.4) with ESMTP id w9UECoKK021088 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 30 Oct 2018 14:12:50 GMT Received: from abhmp0019.oracle.com (abhmp0019.oracle.com [141.146.116.25]) by aserv0122.oracle.com (8.14.4/8.14.4) with ESMTP id w9UEClor010435; Tue, 30 Oct 2018 14:12:47 GMT Received: from [10.211.47.88] (/10.211.47.88) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Tue, 30 Oct 2018 07:12:47 -0700 Subject: Re: [Xen-devel] [PATCH] xen-swiotlb: exchange memory with Xen only when pages are contiguous To: Paul Durrant , Boris Ostrovsky , Konrad Rzeszutek Wilk Cc: John Sobecki , "DONGLI.ZHANG" , "linux-kernel@vger.kernel.org\"" , "konrad@kernel.org" , "xen-devel@lists.xenproject.org" , Christoph Helwig References: <20181024130246.GA22616@localhost.localdomain> <83900cf4-690c-9725-d022-d427fdeb4f7d@oracle.com> <581cb7ea-3112-791d-918d-9bb887e4744f@oracle.com> <24a62522-1629-5d0b-398e-6d2c1a0b97f7@oracle.com> <922914c9-22db-c5d1-33da-d07691ebd7d7@oracle.com> <45f5ffe8-3f48-4485-53f0-5a056be69b0c@oracle.com> <5b64850f-9142-0360-fe4e-9e7bc74d2368@oracle.com> <3e65208c-cb11-d918-00eb-012a97e56fec@oracle.com> <57e5593233c64dc0a36c7d4c750a1ed4@AMSPEX02CL03.citrite.net> From: Joe Jin Message-ID: Date: Tue, 30 Oct 2018 07:12:46 -0700 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.13; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <57e5593233c64dc0a36c7d4c750a1ed4@AMSPEX02CL03.citrite.net> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit X-Proofpoint-Virus-Version: vendor=nai engine=5900 definitions=9061 signatures=668683 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 suspectscore=2 malwarescore=0 phishscore=0 bulkscore=0 spamscore=0 mlxscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1807170000 definitions=main-1810300123 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/30/18 1:59 AM, Paul Durrant wrote: >> On 10/25/18 11:56 AM, Joe Jin wrote: >>> I just discussed this patch with Boris in private, his opinions(Boris, >>> please correct me if any misunderstood) are: >>> >>> 1. With/without the check, both are incorrect, he thought we need to >>> prevented unalloc'd free at here. >>> 2. On freeing, if upper layer already checked the memory was DMA-able, >>> the checking at here does not make sense, we can remove all checks. >>> 3. xen_create_contiguous_region() and xen_destroy_contiguous_region() >>> to come in pairs. >> I tried to added radix_tree to track allocating/freeing and I found some >> memory only allocated but was not freed, I guess it caused by driver used >> dma_pool, that means if lots of such requests, the list will consume lot >> of memory for it. Will continue to work on it, if anyone have good idea >> for it please let me know, I'd like to try it. >> > FWIW, in my Xen PV-IOMMU test patches, I have also tried keeping a list of ranges mapped for DMA and have discovered apparent issues with some drivers, particularly tg3, that seem to free mappings that have not been allocated (or possibly double-free). I've never fully tracked down the issue. Call trace of first called xen_swiotlb_alloc_coherent(The pages never backed to Xen): [ 23.436333] [] xen_swiotlb_alloc_coherent+0x169/0x510 [ 23.436623] [] ? kmem_cache_alloc_trace+0x1ed/0x280 [ 23.436900] [] dma_pool_alloc+0x11f/0x260 [ 23.437190] [] ehci_qh_alloc+0x52/0x120 [ 23.437481] [] ehci_setup+0x2bf/0x8e0 [ 23.437760] [] ? __dev_printk+0x46/0xa0 [ 23.438042] [] ? _dev_info+0x53/0x60 [ 23.438327] [] ehci_pci_setup+0xc0/0x5f0 [ 23.438615] [] usb_add_hcd+0x25d/0xaf0 [ 23.438901] [] usb_hcd_pci_probe+0x406/0x520 [ 23.439177] [] ehci_pci_probe+0x36/0x40 [ 23.439469] [] local_pci_probe+0x4a/0xb0 [ 23.439752] [] ? pci_match_device+0xe5/0x110 [ 23.440027] [] pci_device_probe+0xd1/0x120 [ 23.440320] [] driver_probe_device+0x20c/0x4d0 [ 23.440599] [] __driver_attach+0x9b/0xa0 [ 23.440879] [] ? __device_attach+0x50/0x50 Above was EHCI used DMA pool to allocate DMA memory. During my testing, ~1000 entries was not freed, if more PCI devices use DMA pool, the tree/list will have more entries, looks it's not a good idea that use a list to track it. Thanks, Joe