Received: by 10.223.176.46 with SMTP id f43csp2418737wra; Sun, 21 Jan 2018 19:42:44 -0800 (PST) X-Google-Smtp-Source: AH8x225/kZo3nuJfJ7Larp3q6SanJNpKg6MxuoQDPtwxJWPHsr0E/jUvhvgIgzfd8+Ex6nnFfd2C X-Received: by 2002:a17:902:67:: with SMTP id 94-v6mr2692582pla.183.1516592564417; Sun, 21 Jan 2018 19:42:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516592564; cv=none; d=google.com; s=arc-20160816; b=ReZM5SWTy76qyysjG9BgzxOIAho3RdBHbw/dANL9gLAPlpG2b9ZORjRh3E6sl3BV4p qB218zZIQe84f6QfPLJE1QkK77xe73b0N23sr3dg/tIoZzwZG84Iq8Lg3FSi46duMF36 NQkhkJpfhMbWLp+yVJXczFl9v/jrvOOucgio/qs4zPR0f2ETWHL+Mmhj3AgJNRu71U44 +qEBi94SPwFFioGJXKy01x037Uj8KTT212otZ/LlFSDy9e30wQMW/fmSNhhK/08CR0AL +nhEFchARAywN+8pS3fGaea0hDvZWjV9M9679yN/6KYkKmhGuhen1b0F3XNH3YQA4ggU yymA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:spamdiagnosticmetadata :spamdiagnosticoutput:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature:arc-authentication-results; bh=e+zqva4uBNqUdyAXDTggVLgwG4iULJgpr6J1onuwETw=; b=MqmWFEZp3Igcrcuy+TQ5RzzVhR6vvfQVA0sV8Rt81nbW5vwJaZJGxQkE61RpLK/Rk5 y4UpvW0x+wEgI0/RSypZlsMa5gqKs3690H/FXTDbHA5x+k/w10wkTpUdLSemYXvT7RiV edex3qfD8hU7idc6Iz3M5fO3nUxjCIcj0r5vQM3NITA0gOMt4fYxPzf8DlUgEVDDBnbx HrpmrWtytSeCpcOLiJp7h/mbWdMt60HxEYH2IfM0Z1AxaP8CO+tsNg+p0lq/Vzg9qBvv mr0OeZtLtDJutqeaS/Heh4JG9nmIHwxUZIf3gPmgudKWcEZRIkgF6bn1sjhKS+h8dmAf Cguw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amdcloud.onmicrosoft.com header.s=selector1-amd-com header.b=y9DOy2jK; 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 m7si14478212pfi.179.2018.01.21.19.42.29; Sun, 21 Jan 2018 19:42:44 -0800 (PST) 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=@amdcloud.onmicrosoft.com header.s=selector1-amd-com header.b=y9DOy2jK; 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 S1751106AbeAVDmG (ORCPT + 99 others); Sun, 21 Jan 2018 22:42:06 -0500 Received: from mail-dm3nam03on0046.outbound.protection.outlook.com ([104.47.41.46]:22925 "EHLO NAM03-DM3-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1750951AbeAVDmE (ORCPT ); Sun, 21 Jan 2018 22:42:04 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amdcloud.onmicrosoft.com; s=selector1-amd-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=e+zqva4uBNqUdyAXDTggVLgwG4iULJgpr6J1onuwETw=; b=y9DOy2jKJw86TRuPnuFK6HZQkTS8ZQjfX42JOaxiqypGe7dz61Boq3cTJzElXcxETNGuJS4hDK+O7mkStt8IE8t1ZmdURpopwlnJejf6a6DY3mt0zqjS6Mw1N4AvgKIO7+mRu4xhG1k/7tbBuqiS403mGK+tvrDrbBh/TmbIVxQ= Received: from Suravees-MacBook-Pro-15.local (114.109.128.54) by MWHPR12MB1741.namprd12.prod.outlook.com (10.175.55.12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.428.17; Mon, 22 Jan 2018 03:41:59 +0000 Subject: Re: [RFC PATCH v2 2/2] iommu/amd: Add support for fast IOTLB flushing To: linux-kernel@vger.kernel.org, iommu@lists.linux-foundation.org Cc: joro@8bytes.org, jroedel@suse.de, alex.williamson@redhat.com References: <1514366435-12723-1-git-send-email-suravee.suthikulpanit@amd.com> <1514366435-12723-3-git-send-email-suravee.suthikulpanit@amd.com> From: Suravee Suthikulpanit Message-ID: Date: Mon, 22 Jan 2018 10:41:42 +0700 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.13; rv:52.0) Gecko/20100101 Thunderbird/52.5.2 MIME-Version: 1.0 In-Reply-To: <1514366435-12723-3-git-send-email-suravee.suthikulpanit@amd.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [114.109.128.54] X-ClientProxiedBy: SG2PR06CA0101.apcprd06.prod.outlook.com (10.170.138.27) To MWHPR12MB1741.namprd12.prod.outlook.com (10.175.55.12) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 12b9c69f-a5c9-44c3-7975-08d5614a1898 X-MS-Office365-Filtering-HT: Tenant X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:(7020095)(4652020)(5600026)(4604075)(48565401081)(2017052603307)(7153060)(7193020);SRVR:MWHPR12MB1741; X-Microsoft-Exchange-Diagnostics: 1;MWHPR12MB1741;3:quMDFOfGX13+UkA00lobeKzjDXnjORYrNi21udx06DcSfohOYyDykzrZaf/FqGnargHCdIoQzeAD1JSDks0+ECvV2lvnAMEtsG5Vovr4ro7GUoR7G+lb7iKI0hezmYNqDNoL+W4zkgE7naX/LdOzg6hZWIEOfQrLNgF25LiHOAuI+rBqsYAU8SzBFJyExjqG86vX3P0500Ga3GM3ZRYyM/EowdProhJz5SKtJvtUc0AOozsRLysZkrmKr/9YX7IV;25:MbyOv5YSH9I8CxzDjBby2hc+2qwdDkH9nyaZcxvQrS/sk3nMecxHoF5o0ce3iKg5+OowqXU2GJyBKN3opcx9uQJ89XAmpUjXo6rT/JaZSgVGPUBnJYhoudLL7TYTDFXwSWclGEGmTcej80vwXpM2Jgri5U64D7o3ffWHygqTfNEWWr9JyB2UhjT1D5e5cUaRXjSS7JmAzuFEL32Ex2mDZs7Sg7nj1dGjOyZg6sVpDzxyl4fkH87+Bs5gtsI2jgK00rCxD2gbiF2hCelmxZshDkbDvB5pGvD2g/G0alMTfRKK88gzpWRL6ab1CDhLuzwCVvBdZgiEAjQjZAmINozClA==;31:r/7lcO+oq1ZRszmeK7VdZ+OqxfcUwkMCqTxxKUE62dav1F1ylKCYN39IDAL6tENjk9QxMUh05na1nVLi2QtbQ891O5r9poNwqDdkz47wyQG9XZ/bef8HUGP+mN0foClEhX0XjgJC3BpChEMS4Agd2xSM/t0KC9BRvg2wVJHhktvx1saqLlvAcXOXgge7CYDM5tzwgxnzbbtESF7L1xAIMZq0mFunr8e+t9eoLpda1H8= X-MS-TrafficTypeDiagnostic: MWHPR12MB1741: X-Microsoft-Exchange-Diagnostics: 1;MWHPR12MB1741;20:/uOOeE6C3Fz9b/n4qzdFYFltqdtl1AdCCx5cq+aiMLQvKn7Rzm8a2ETyi4qaOCt/IjaFilCaLYW5HvD7MQEoog4ktkXLjddu20UYKOyNzDR09XmsnM2l9endmaZ4epBLFjMun+okt2LhEDKo9jWxbfa+p7CXb7Jp5E6kI/s44nSqGmhiR5r3A5Lx+StzgztngJ6et4sMdlGD9HGir/+lqW446odb6uiv6uNU9/91REP5TxFD5Ay4drTtMtvzdV9Jc++2m42QBWINZyynKKroS6TLb42bFnv4811OPTRxmqdX91H5xyEE2uLqWoE/bWs9uQI4awCL80oULjYwTD7gqpMxkHe0NZb2A2tbzCjK6IdjLJfZUb0jWUNIGdkZxr3HTRaufMGww/wIlKlvFWiTSGQGGwDpNvcOXaF6FuW49y93Cf+lu5e41NIk3LzVPkPwVEgMrt5yXscUpMKL1Az8E76KgOyMJTK/fstH4TwJyStD8G6PfZkPTAXm0W/C8xZx;4:2YX+kt2VPbTbb5zmB3WwE+hV8/bPlEq66mLGt9Reqwabj4YiY+uZQYPSAlhWHJDpdRbRjlZPCCLsZ1/AnD9I8rmsbX8L9YEAr2hBxWP4Ds1JihYkhWdfRsCM77JVtdFUmo98agpv0kvPx6MzA1Ye9SmNoLbQNjSsMNva+VWhayy1BU/xMeSoUBSISYMmVCkSaUsU7ABeSqC6PDCT9TjaSvSdKNf51NKGnxPouNUN6Bug3q4uf2rENLjnsYnoTd5BVPCm9gnG5je8b4TFSaLwoiGzio9kbOJEiksCCX3w93ti+6yfV8Xb8jkJdrikSOLv X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(767451399110); X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(6040501)(2401047)(8121501046)(5005006)(3231023)(2400081)(944501161)(93006095)(93001095)(10201501046)(3002001)(6055026)(6041288)(201703131423095)(201702281528075)(20161123555045)(201703061421075)(201703061406153)(20161123558120)(20161123560045)(20161123564045)(20161123562045)(6072148)(201708071742011);SRVR:MWHPR12MB1741;BCL:0;PCL:0;RULEID:(100000803101)(100110400095);SRVR:MWHPR12MB1741; X-Forefront-PRVS: 0560A2214D X-Forefront-Antispam-Report: SFV:NSPM;SFS:(10009020)(366004)(346002)(39860400002)(376002)(396003)(39380400002)(189003)(199004)(31686004)(72206003)(64126003)(31696002)(97736004)(50466002)(81156014)(8676002)(81166006)(8936002)(305945005)(68736007)(230700001)(229853002)(6486002)(7736002)(65956001)(65806001)(5890100001)(66066001)(47776003)(25786009)(6346003)(4326008)(478600001)(105586002)(6512007)(53936002)(106356001)(6246003)(67846002)(26005)(316002)(16526018)(2906002)(58126008)(3846002)(83506002)(36756003)(6116002)(59450400001)(76176011)(53546011)(386003)(65826007)(6506007)(52146003)(2486003)(5660300001)(23676004)(6666003)(2950100002)(86362001)(52116002)(217873001);DIR:OUT;SFP:1101;SCL:1;SRVR:MWHPR12MB1741;H:Suravees-MacBook-Pro-15.local;FPR:;SPF:None;PTR:InfoNoRecords;MX:1;A:1;LANG:en; Received-SPF: None (protection.outlook.com: amd.com does not designate permitted sender hosts) Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Suravee.Suthikulpanit@amd.com; X-Microsoft-Exchange-Diagnostics: =?utf-8?B?MTtNV0hQUjEyTUIxNzQxOzIzOlJmL0JnMnM3Z2FkVko3MEt0S2tRZExLd3l2?= =?utf-8?B?dWZVQnFISFhTaittYWpqaXhEY0JXVSs1SmdxZ2t1b2cyVzhIR0hjcGtDVndJ?= =?utf-8?B?Zm4rdHN4MTBQMWxZYUt0Mm9sdStwNlpWY01QbEsrKzZ6UjdybENaWmVNZFNn?= =?utf-8?B?M3hUTE0vSG1PYUhHbGN0aE9HaHZDc0QxNlhod0l0Y0ExdmRzdFdrOEF1bVZz?= =?utf-8?B?Mlp4dzA4UGNHdm1PcFVjb0hoc1pLaGVETTlURVY5bU9qK0FyRU1LS3FwWFBv?= =?utf-8?B?ODlCakRUZHpMaVRPN3hyMUFHVktnWktYanB5TUtkMG0zUmU3azY3amFnWklQ?= =?utf-8?B?Wk5BSXo5ODR6SC96bnFQOW5IeFBDNzF6bWkyUTNuZnQ0WEkybTY0alZJaU9F?= =?utf-8?B?dDJjdUQ2T3lURzdFT2ZTOVV4SXgwN3YwMnFFZnlYRnZqczJSVWFXQWlZUWhp?= =?utf-8?B?ZjNzVmJNM0ZBZENqbVB6SUZFcmZycThrVTFkaUcxRTB5SkZ0SlRaRHpqRS91?= =?utf-8?B?NVBIa2UxWFNiVCtTVjRkV3kyN1lZV0lpcy9kbVdRU2pObjM2OWpPL1hEekJS?= =?utf-8?B?bVg0cDdkckdUNVdmUHVaSy95RkQxdE5RUUMzU2dDMmRZZW91U1RFQ0lwNDA2?= =?utf-8?B?cFpRMkdwanVWRDRaaGxKWWtFR0t3TENBdlk1VlBMUlR5UGZsNUV4MGJDZ3hl?= =?utf-8?B?UG5QeEZ4clkzcWh5UCtVV05SWXZPcXNwQ25iMFZZeUlXcTNrbWFwbG9Sc0w2?= =?utf-8?B?RGdWYkdRZ25YMVlzWWJydGU5ek9sMXkzNjFVWDBRWXNibnNYdC92U2RDRTRL?= =?utf-8?B?QWcyU1lnQmlkZ2dqNm9PRmNCWkQwZkl5R0k1ZDZ0STJZS01lZjl4TFFkYVl4?= =?utf-8?B?MzdNT2dNWStscmIraHNYYjArZGJMN2l4dHp1eTZVS09kWm13bFllMm1zSGhX?= =?utf-8?B?aWJGUWpZOUxnWTNqTWFMRmpJQ3VJMTVNMktyajVPSHJHSEpqN29SdzdCUTAv?= =?utf-8?B?clg5R1RabjJ2N2RVczNPclZrRTNwUXFhL3RjWHZEWE1RVm1wNitabWlFeFMz?= =?utf-8?B?V3hTZTRVbGNjZ2QvM2RFRjZodFpRckZsOWVKTXlrY21iWXNUZUIvS200VlQz?= =?utf-8?B?RTgyWkVPaFR0S1MrcGlBRjUyaXRFWFFaQThPV1F2N3pBNlJURTVxWndqMnBV?= =?utf-8?B?TGJ2SlJhckY1MEs0bGc4VHdCTlNGRzhTL29rTm1vMjVtc21HYWJvS2R5QzZF?= =?utf-8?B?Ri9Sa3FRdmJXTk1CTjFsdGN1aSszQk5HYkdjVGx3eHhjRzRicnhMcWczTU1U?= =?utf-8?B?ekttR2thbHNZNGNBYUhqUlc5aFhRTDVDZU42WTVjMkh2QTZIWWk0WnlDRUhG?= =?utf-8?B?MStFZUxCdTNtNVloRjB0a3NpK3lzOHMwMGtYWTZyM2I3UFpnTGs4NXlRUXBq?= =?utf-8?B?TUVJZlVtcU5GVkh2d29SRTVOZHJaU1RwbUh3MjNqcGx5cHMyN1J6YjlxcEdD?= =?utf-8?B?RjNibUd3M0hsMXZsRXBzRjlmUVQ4T1poOWNQdC9zRy8xQVFRdmdmYXdNZTRM?= =?utf-8?B?cC9mWVFTelBsazFJT0JnMjE5TThtQ0JJZjB4MDdhMDh6ZlhOYk9UeWw3eWRm?= =?utf-8?B?blM4TWFWcTcxaEZwd2hRWUdObnRLWlIxZHUvMmtGc3Q5S1hMZWtUaDNsMno3?= =?utf-8?B?bnhwMEVvN3BQbHVPS3hWMy9KZ1RMK1ptWnUyWVBDa3l5MjVsdkdsMEpmeUx3?= =?utf-8?B?RUd1Z3EvNVZtLzZYbDUwaVJMQytNLzd6cXVhYVJxMENoL0tGb1JjNzAwV2Zr?= =?utf-8?B?bFdWTWU1Sjd4eTVRQTZTczUxRHRLa3pFbnI1NW5wTkh5eklzTFRwV0dUSWcy?= =?utf-8?B?UWpJcWxoYXd6Z1RkNFhLL1RtTFMzM0JyUmduTDNaSEErSVN3blpUeUx6S2Nm?= =?utf-8?Q?k1nfTCzOQBRiaRBmwiQn/JlICAcMqs=3D?= X-Microsoft-Exchange-Diagnostics: 1;MWHPR12MB1741;6:5q5gTnSMFpT2lF0tDNKNXCmkHRzwFRpSqJnmU145NU8/kkSoScfu1ZMaPb9EL3Jol55edOQPP8WcbdL5+Wop8VpcKD6ooY5T1MPWU0KNXrrat5wLb8vSMFNs5W4LtLTgjNuoWIdsomQ6+jqOU8Cb7CAF1hdzt4xkHj4yqtFVCcnw54CXFXc/amqo7yEDTRqCxn/qoC5Jl/kptSkGkeRwRv0kWFacwT7i9pF31xmJ4wq+hkxrV6D4j6W2rQl6Z1ZnIy9DrVbJPqkxSyeaYBLvNp8UWaLnFj57JOSvuqh4kc9B2fs2gWib8jU731sE38Vai4s+Xr5d1BEsZ+z/Vv4u/XPYeY8Jc0qfHJ2gFvtnY5c=;5:p2YZjTrRALeWn0QOE5va48oDqnNHflL3905jtoz7kWRgNIPf31M5zuRk3CrWDu9yGxnh5+XVFhH/xeYsZSe8tHDLh3XOixNgxELjIyOQJ7RpMbKapbc1HBVHTJqXQAc/tKpiDNYnY2sO31VSk1ZHBIznVHqjGCHDTAm17vtUv6s=;24:zEtwHzmZGaKjMKiBJlPw4kaA9JIeDSn92KrtReZwBBxzv369Auf6xefm4QCOuZer61UJFvA/Tn4aZs18+pwQZi6IK2LDzplstTuwpr6F39c=;7:EW3qdbJg6MvIVxOplRppOS8fmwBf7q/6ZMxLdcHpj+WzQo5wGI+kyvom8FvKcccOLRhV0k4JCcQD7oankPothk9gBg+FbOlKCdmXsXaxGWkJfGehMpWz5HIMwbIdlSQJyBhyQbliqrtVBTQ2hKerIQwas+xVh+eR+sXDc/GxNaTQ0RZrASZqTixsugjVek3UC5Szneql6szTpuGY+XEa/apwQjoMv/pW0EH9JezKsknBOKVIDfuX7J2NCMh6dURY SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1;MWHPR12MB1741;20:830HWOCRdVSs09oYsA+f48xFbAEW0dAsAIwqkKgWiD7zwYKCbQOL5c1twwIYjeSQiyGnPRLt7ybJPhbpJLb6LTWQAjIKFoIg3QF4BJx+IxdIEuEkDDHxNczm0eRjB8Iw+mfrARV2nilwC7slwVW/Xcu0m2XxhM50hdRRmY+/N3+vCm+3+zyj8o9fOWB9eW/FX0kxOLACG6CCbEEFcKLj+yIQulOnmStffQj72yMkISwgpcLeodaYG/O5XjwnjrfH X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 22 Jan 2018 03:41:59.5131 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 12b9c69f-a5c9-44c3-7975-08d5614a1898 X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-Transport-CrossTenantHeadersStamped: MWHPR12MB1741 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Joerg, Do you have any feedback regarding this patch for AMD IOMMU? I'm re-sending the patch 1/2 separately per Alex's suggestion. Thanks, Suravee On 12/27/17 4:20 PM, Suravee Suthikulpanit wrote: > Implement the newly added IOTLB flushing interface for AMD IOMMU. > > Signed-off-by: Suravee Suthikulpanit > --- > drivers/iommu/amd_iommu.c | 73 ++++++++++++++++++++++++++++++++++++++++- > drivers/iommu/amd_iommu_init.c | 7 ++++ > drivers/iommu/amd_iommu_types.h | 7 ++++ > 3 files changed, 86 insertions(+), 1 deletion(-) > > diff --git a/drivers/iommu/amd_iommu.c b/drivers/iommu/amd_iommu.c > index 7d5eb00..42fe365 100644 > --- a/drivers/iommu/amd_iommu.c > +++ b/drivers/iommu/amd_iommu.c > @@ -129,6 +129,12 @@ struct dma_ops_domain { > static struct iova_domain reserved_iova_ranges; > static struct lock_class_key reserved_rbtree_key; > > +struct amd_iommu_flush_entries { > + struct list_head list; > + unsigned long iova; > + size_t size; > +}; > + > /**************************************************************************** > * > * Helper functions > @@ -3043,7 +3049,6 @@ static size_t amd_iommu_unmap(struct iommu_domain *dom, unsigned long iova, > unmap_size = iommu_unmap_page(domain, iova, page_size); > mutex_unlock(&domain->api_lock); > > - domain_flush_tlb_pde(domain); > domain_flush_complete(domain); > > return unmap_size; > @@ -3163,6 +3168,69 @@ static bool amd_iommu_is_attach_deferred(struct iommu_domain *domain, > return dev_data->defer_attach; > } > > +static void amd_iommu_flush_iotlb_all(struct iommu_domain *domain) > +{ > + struct protection_domain *dom = to_pdomain(domain); > + > + domain_flush_tlb_pde(dom); > +} > + > +static void amd_iommu_iotlb_range_add(struct iommu_domain *domain, > + unsigned long iova, size_t size) > +{ > + struct amd_iommu_flush_entries *entry, *p; > + unsigned long flags; > + bool found = false; > + > + spin_lock_irqsave(&amd_iommu_flush_list_lock, flags); > + list_for_each_entry(p, &amd_iommu_flush_list, list) { > + if (iova != p->iova) > + continue; > + > + if (size > p->size) { > + p->size = size; > + pr_debug("%s: update range: iova=%#lx, size = %#lx\n", > + __func__, p->iova, p->size); > + } > + found = true; > + break; > + } > + > + if (!found) { > + entry = kzalloc(sizeof(struct amd_iommu_flush_entries), > + GFP_KERNEL); > + if (entry) { > + pr_debug("%s: new range: iova=%lx, size=%#lx\n", > + __func__, iova, size); > + > + entry->iova = iova; > + entry->size = size; > + list_add(&entry->list, &amd_iommu_flush_list); > + } > + } > + spin_unlock_irqrestore(&amd_iommu_flush_list_lock, flags); > +} > + > +static void amd_iommu_iotlb_sync(struct iommu_domain *domain) > +{ > + struct protection_domain *pdom = to_pdomain(domain); > + struct amd_iommu_flush_entries *entry, *next; > + unsigned long flags; > + > + /* Note: > + * Currently, IOMMU driver just flushes the whole IO/TLB for > + * a given domain. So, just remove entries from the list here. > + */ > + spin_lock_irqsave(&amd_iommu_flush_list_lock, flags); > + list_for_each_entry_safe(entry, next, &amd_iommu_flush_list, list) { > + list_del(&entry->list); > + kfree(entry); > + } > + spin_unlock_irqrestore(&amd_iommu_flush_list_lock, flags); > + > + domain_flush_tlb_pde(pdom); > +} > + > const struct iommu_ops amd_iommu_ops = { > .capable = amd_iommu_capable, > .domain_alloc = amd_iommu_domain_alloc, > @@ -3181,6 +3249,9 @@ static bool amd_iommu_is_attach_deferred(struct iommu_domain *domain, > .apply_resv_region = amd_iommu_apply_resv_region, > .is_attach_deferred = amd_iommu_is_attach_deferred, > .pgsize_bitmap = AMD_IOMMU_PGSIZES, > + .flush_iotlb_all = amd_iommu_flush_iotlb_all, > + .iotlb_range_add = amd_iommu_iotlb_range_add, > + .iotlb_sync = amd_iommu_iotlb_sync, > }; > > /***************************************************************************** > diff --git a/drivers/iommu/amd_iommu_init.c b/drivers/iommu/amd_iommu_init.c > index 6fe2d03..e8f8cee 100644 > --- a/drivers/iommu/amd_iommu_init.c > +++ b/drivers/iommu/amd_iommu_init.c > @@ -185,6 +185,12 @@ struct ivmd_header { > bool amd_iommu_force_isolation __read_mostly; > > /* > + * IOTLB flush list > + */ > +LIST_HEAD(amd_iommu_flush_list); > +spinlock_t amd_iommu_flush_list_lock; > + > +/* > * List of protection domains - used during resume > */ > LIST_HEAD(amd_iommu_pd_list); > @@ -2490,6 +2496,7 @@ static int __init early_amd_iommu_init(void) > __set_bit(0, amd_iommu_pd_alloc_bitmap); > > spin_lock_init(&amd_iommu_pd_lock); > + spin_lock_init(&amd_iommu_flush_list_lock); > > /* > * now the data structures are allocated and basically initialized > diff --git a/drivers/iommu/amd_iommu_types.h b/drivers/iommu/amd_iommu_types.h > index f6b24c7..c3f4a7e 100644 > --- a/drivers/iommu/amd_iommu_types.h > +++ b/drivers/iommu/amd_iommu_types.h > @@ -668,6 +668,13 @@ struct iommu_dev_data { > extern struct list_head amd_iommu_pd_list; > > /* > + * Declarations for the global flush list to support > + * iotlb_range_add() and iotlb_sync. > + */ > +extern spinlock_t amd_iommu_flush_list_lock; > +extern struct list_head amd_iommu_flush_list; > + > +/* > * Structure defining one entry in the device table > */ > struct dev_table_entry { >