Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1197424imm; Wed, 11 Jul 2018 19:54:22 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdorGOCDTEF0ysbT2p1eOFrKNchONyfjyXeOc2uVyqHZiQJWqyrZUJxKWzM+d0mXfeHsqM6 X-Received: by 2002:a65:5683:: with SMTP id v3-v6mr419277pgs.176.1531364062487; Wed, 11 Jul 2018 19:54:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531364062; cv=none; d=google.com; s=arc-20160816; b=j7THqooV2/dlIp1bdWTwZIqntsUaNSn32yEA1gyJhHq33Zj8zCk8leh572/wJ5zT05 8Ptt0M6RJKkzjr7zL4/QBKJ/YscMi6TSPfV48935rQJJCQS5KZ6xvJH51+7XFACYuJZb PhKNvbSgxUObMnfWy7jrCx4E1g6x7KRlKlh4VT+SGT0fdB9VUe6cuwQ9g9P8WBmT9QJE wgwpFvuejWqhczL7JucMPhq753ZRjxBRYL7V5qWCDDbNhNN778ho5VGuy+E1H/PRHyxc sbjsVWdyUYMa8x2bxwo5mcDvSxhxROpuR3AGcZnwzxbI0Pbjjb4Mxi2mBj3pzxHwRWA8 kh+Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=5w4nLPEuwrKCz5EFO/Uj4lhd6c7bn4BL+FGxKombQeE=; b=qmseLzPhvTzI8V8QBwsjqzBrACVePJN6J5d3/zcMhpBa6QkFpIODeelXoaiu9v2vuz pdfE19maJoLw6wqxiJTTUYD8m5SiYnfcPu50tCloG8O0FjsgvumrAAtzR2asOTDdXXup KxYUC++zCcmck7Bf3+liN3O+f0CiafeAvUNbOkpyzhUPi7x+gdMwqBJDUBmKR46ONjfZ Q7YBpRxvLtniflz55gKWMhD1wYKgFE2US9d/HewtI1o1Zbax+rBa0rr3yoLy+MOsJ0MC H1SYPNiVpAN0rVqO071uRXLNhkA8S8L2wqo81nNQD1hmOWKXOh9o9n54jTTMy0gMDHlN UC6A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lixom-net.20150623.gappssmtp.com header.s=20150623 header.b=a2AqncCN; 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 g16-v6si18990798pgv.78.2018.07.11.19.54.07; Wed, 11 Jul 2018 19:54:22 -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=@lixom-net.20150623.gappssmtp.com header.s=20150623 header.b=a2AqncCN; 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 S2388878AbeGKVGJ (ORCPT + 99 others); Wed, 11 Jul 2018 17:06:09 -0400 Received: from mail-pf0-f196.google.com ([209.85.192.196]:35058 "EHLO mail-pf0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388336AbeGKVGI (ORCPT ); Wed, 11 Jul 2018 17:06:08 -0400 Received: by mail-pf0-f196.google.com with SMTP id q7-v6so18069459pff.2 for ; Wed, 11 Jul 2018 13:59:58 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=lixom-net.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=5w4nLPEuwrKCz5EFO/Uj4lhd6c7bn4BL+FGxKombQeE=; b=a2AqncCNRW/thst/ozp/a3WArKo3XjeANBS3YY2TJ5cQwCnmmrzd9U1z8gEvf1mNd+ 1oiybqn5G5+0nsBHZDXmYuirZ/zukiIL63aoDVHpqYUhSyxRYh6mz3V+bcbhAUWeAEFK J3Upk7vLeyw6t4im40JAVt2cOdN+z0jDEjg3aaPV3z+unomrLiAGzAnD2gsJIw/ZqgJ7 3AnZFpwn3VZZg44tvrqsu9zC810+reHyZ81F6P1ttHow+PwcdF90csoDt78GtVOVDFK+ cN1/+9U2JQJW8V/fT/U/rKeo6R4oH7XOBJWdbZdkBN7SbCHx47tKApwIoVqd1eSA6zPx 2QvQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=5w4nLPEuwrKCz5EFO/Uj4lhd6c7bn4BL+FGxKombQeE=; b=ngCEuY9WtpzO1VCALQsnC3ubGNvL0XZgMu4OdPrV39NfXcmzJW6SLm1tCl0V+zwBB8 tvop+tFSAfzf6QsTlTW7yKQv5JOCnHMmtS7Aur7acbpowc+Yx6+if/tBhA0hsMy2/yIa tPNXA6jFeUgJ0XDehs2MJYJNSLsvDrfUn27DjzCVz5NX9k13jAx/+fdPLaADng6RUfQb 3essfU/55OiZB6RZdCWRhRg21MpkkDvOsAzr+ACg+NfH+mvSZ0oFs4ydUZ0SpEOqRs4i Hd4dp2GVIG2mgLJ7+91Xo9+UDg4c0pXwMe4F80mDL55gLvBrlLz8uU/Qx/Z3gxCUa83o vsQg== X-Gm-Message-State: AOUpUlHeRZdjK3V6jMHhsXv+WTUQvHk7sr/MldNZMB1ODcP8b1v+yAWF CGocqbdtuDAD/30S6gUPyHes/VxW X-Received: by 2002:a62:2605:: with SMTP id m5-v6mr180994pfm.223.1531342798357; Wed, 11 Jul 2018 13:59:58 -0700 (PDT) Received: from localhost.localdomain (173-13-129-225-sfba.hfc.comcastbusiness.net. [173.13.129.225]) by smtp.gmail.com with ESMTPSA id j2-v6sm22867564pff.35.2018.07.11.13.59.55 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 11 Jul 2018 13:59:56 -0700 (PDT) From: Olof Johansson To: Joerg Roedel Cc: iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org, Olof Johansson Subject: [PATCH 2/2] iommu: add sysfs attribyte for domain type Date: Wed, 11 Jul 2018 13:59:36 -0700 Message-Id: <20180711205936.18614-2-olof@lixom.net> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20180711205936.18614-1-olof@lixom.net> References: <20180711205936.18614-1-olof@lixom.net> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org While we could print it at setup time, this is an easier way to match each device to their default IOMMU allocation type. Signed-off-by: Olof Johansson --- drivers/iommu/iommu.c | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/drivers/iommu/iommu.c b/drivers/iommu/iommu.c index ab8fc54467e0..53164107620c 100644 --- a/drivers/iommu/iommu.c +++ b/drivers/iommu/iommu.c @@ -298,11 +298,39 @@ static ssize_t iommu_group_show_resv_regions(struct iommu_group *group, return (str - buf); } +static ssize_t iommu_group_show_type(struct iommu_group *group, + char *buf) +{ + char *type = "unknown\n"; + + if (group->default_domain) { + switch (group->default_domain->type) { + case IOMMU_DOMAIN_BLOCKED: + type = "blocked\n"; + break; + case IOMMU_DOMAIN_IDENTITY: + type = "identity\n"; + break; + case IOMMU_DOMAIN_UNMANAGED: + type = "unmanaged\n"; + break; + case IOMMU_DOMAIN_DMA: + type = "DMA"; + break; + } + } + strcpy(buf, type); + + return strlen(type); +} + static IOMMU_GROUP_ATTR(name, S_IRUGO, iommu_group_show_name, NULL); static IOMMU_GROUP_ATTR(reserved_regions, 0444, iommu_group_show_resv_regions, NULL); +static IOMMU_GROUP_ATTR(type, 0444, iommu_group_show_type, NULL); + static void iommu_group_release(struct kobject *kobj) { struct iommu_group *group = to_iommu_group(kobj); @@ -384,6 +412,10 @@ struct iommu_group *iommu_group_alloc(void) if (ret) return ERR_PTR(ret); + ret = iommu_group_create_file(group, &iommu_group_attr_type); + if (ret) + return ERR_PTR(ret); + pr_debug("Allocated group %d\n", group->id); return group; -- 2.11.0