Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp935629pxb; Fri, 22 Apr 2022 14:46:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwuCO0aMu0pDHXoHZXYn4GufM5XLh0E1y4+vqsRYVyeB3E3lY3htQOcGUfdBFmH1BrMskX1 X-Received: by 2002:a17:902:c215:b0:14f:f1c2:9fe3 with SMTP id 21-20020a170902c21500b0014ff1c29fe3mr6619262pll.145.1650663980473; Fri, 22 Apr 2022 14:46:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650663980; cv=none; d=google.com; s=arc-20160816; b=tzuHWHF6/Oam5aImpJuzotcgt3uGySQtxhxe7Smw5fxZ63zr4Qljl/oJeLNLbUg43l ZLUK5KjY9KBJH+mxMK5FNcpAYRu9PsQU+CU0RsNEpBDpouQL6AspG3P1lFp6VX62jdQM o+0A6XTp86VvpeuIM0LkjqwIDCCfIsv8kdswJLymC/hbZ2inP70HSHkZjWDmXfnyjSKK yLK9zUnlZ+HFtCfTc5y7KjaOb3kCZb5Zcve4zShYN9QZ9myUpMs3fslIH6L/NI69DadD jUQuM0MUldpFsP7b4dS7/+Qde9WJE5MEoEDJRYi8yium6HLx9AsbOwGQOqxxfqBrojH2 X6Sw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-signature; bh=FWaKUpxpKzKjbtSZ6ZKtWz+3C1vj9orKjhUr2xwY4lM=; b=xgvax35AuqoSSnGWLaYPoIbPl2NH3BLuPX/yKFHFdZ67Q8dTwakSmRWaF/tuzNUDgT eHbW+SNrVknlUIZm5j4KdV8VgRpcOFOjpeUU1JId4TBpJBb5q9D5Wtz9GMb44xRKDlhg 60+ynQLpNXeLADBMwjWYkdqfP8fcMgwPjPnMfjUfbwubSI6ZPExOQlERMDS71Rqjbai1 NYlf5zsogHtkkxDEuIT9UfKXt1QJItldiEaggBgm91Ul1M0M2XsHWwqn5GH03Qzpbfpw 4AkAC9x4f/kFmAqHo0kZ1Jpz+VRb3V5pmnJGaEcduXx7xJUMEcZwlyrqDTQJg7bjcofC VAyQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=hZs3izeC; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 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 lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id y5-20020a17090322c500b0015caeda8720si1954674plg.106.2022.04.22.14.46.20 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 Apr 2022 14:46:20 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=hZs3izeC; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from out1.vger.email (out1.vger.email [IPv6:2620:137:e000::1:20]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A7D0832FF53; Fri, 22 Apr 2022 12:54:10 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1449932AbiDVQy4 (ORCPT + 99 others); Fri, 22 Apr 2022 12:54:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51872 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1449870AbiDVQyW (ORCPT ); Fri, 22 Apr 2022 12:54:22 -0400 Received: from mail-lf1-x12f.google.com (mail-lf1-x12f.google.com [IPv6:2a00:1450:4864:20::12f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 241215F8DF for ; Fri, 22 Apr 2022 09:51:28 -0700 (PDT) Received: by mail-lf1-x12f.google.com with SMTP id y32so15294301lfa.6 for ; Fri, 22 Apr 2022 09:51:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=FWaKUpxpKzKjbtSZ6ZKtWz+3C1vj9orKjhUr2xwY4lM=; b=hZs3izeCtmtt43a0UNm5IqmPSa6o2CTFdv4hT95HlTt8sq4U8H2GVbe8LO7gpfIx9P nUCA0BIFr8bWe4R+3Vx5F5V5bZlcVUxVU6cfKnoKPtW9fYpu4rM0I3NA6A9jDYVP/9eT 5v6R6JbVvZdOMWrOceZlrUlagLbrTSPHZ85X9eWLHsTTCGbqBvoaWLAPWUgbs6Idby5s 4LtwH2Lnu3gjEMNKSbuabCyQMifLdMh/r+T6OpIX4rBGG1FX/6XuNg2Nq2vJTPVMJqWK NdOH6K0tTIKQxd1NLk5+6LC7bTT/3ZCxi4f0143G79Y5OyjlhU1DkqwMqAELZuYMQgwV 5rHg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=FWaKUpxpKzKjbtSZ6ZKtWz+3C1vj9orKjhUr2xwY4lM=; b=LlqKv4YHT8o3XFKHlJw8awYPwkVEElwEpTgG1jgwsHnaUdZnTT8+MFhi5NOsX3Sii2 pkyd0ulXWsMoi6FCfWwOC1v1ZtEjJv+msihAWorazt60nAAktsLxOgB6CaZk30DBBfhG dPawn/gOYWQDI3AbzSOboIczgoUjXunIY/pENtcQhme/pv2xriZQhCWoGZ2lYHWHPm+z ZPSKFCtvQ3jaWhGm8qJjhn0iX2cD45gxmVFEj7kh7QHZ/5EyCe6IejZnGW+zZ45Ek/xM rc+uIauPzkBEhAEt8uT5QCEbmEsfthfitNnfIQ+JG2VkL8PGAYM0xAX5/IIzRdi20cMB KEKQ== X-Gm-Message-State: AOAM532nu7VRITAYC3h+pq7eV1yS+gRWhlqwgCfnbHHnUkcnIE8PGV2f 3GICMm/duG89SAwVarFsDhE= X-Received: by 2002:a05:6512:3d14:b0:46b:81d9:b9ee with SMTP id d20-20020a0565123d1400b0046b81d9b9eemr3709015lfv.109.1650646286428; Fri, 22 Apr 2022 09:51:26 -0700 (PDT) Received: from otyshchenko.router ([212.22.223.21]) by smtp.gmail.com with ESMTPSA id n2-20020a056512310200b0046e2f507a3asm279742lfb.167.2022.04.22.09.51.25 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Fri, 22 Apr 2022 09:51:26 -0700 (PDT) From: Oleksandr Tyshchenko To: xen-devel@lists.xenproject.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Cc: Oleksandr Tyshchenko , Boris Ostrovsky , Juergen Gross , Stefano Stabellini , Julien Grall , "Michael S. Tsirkin" , Christoph Hellwig Subject: [PATCH V1 6/6] arm/xen: Assign xen-grant DMA ops for xen-grant DMA devices Date: Fri, 22 Apr 2022 19:51:03 +0300 Message-Id: <1650646263-22047-7-git-send-email-olekstysh@gmail.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1650646263-22047-1-git-send-email-olekstysh@gmail.com> References: <1650646263-22047-1-git-send-email-olekstysh@gmail.com> X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Oleksandr Tyshchenko As the main (and single at the moment) purpose of xen-grant DMA devices is to enable using virtio devices in Xen guests in a safe manner, assign xen-grant DMA ops only if restricted access to the guest memory is enabled. Signed-off-by: Oleksandr Tyshchenko --- Changes RFC -> V1: - update commit subject/description - remove #ifdef CONFIG_XEN_VIRTIO - re-organize the check taking into the account that swiotlb and virtio cases are mutually exclusive - update according to the new naming scheme: s/virtio/grant_dma --- include/xen/arm/xen-ops.h | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/include/xen/arm/xen-ops.h b/include/xen/arm/xen-ops.h index 288deb1..26954e5 100644 --- a/include/xen/arm/xen-ops.h +++ b/include/xen/arm/xen-ops.h @@ -2,12 +2,17 @@ #ifndef _ASM_ARM_XEN_OPS_H #define _ASM_ARM_XEN_OPS_H +#include #include +#include static inline void xen_setup_dma_ops(struct device *dev) { #ifdef CONFIG_XEN - if (xen_swiotlb_detect()) + if (arch_has_restricted_virtio_memory_access() && + xen_is_grant_dma_device(dev)) + xen_grant_setup_dma_ops(dev); + else if (xen_swiotlb_detect()) dev->dma_ops = &xen_swiotlb_dma_ops; #endif } -- 2.7.4