Received: by 2002:a05:6a10:9afc:0:0:0:0 with SMTP id t28csp2196033pxm; Fri, 4 Mar 2022 11:08:28 -0800 (PST) X-Google-Smtp-Source: ABdhPJwrQ+GUJ5zOLwdl7lUn3vgClcMzZgkhAxlICbb8gYOOae6LdoRN6xNLsXu5r37V5d+P3Cmq X-Received: by 2002:a63:580d:0:b0:36c:2a9f:7f4 with SMTP id m13-20020a63580d000000b0036c2a9f07f4mr35748525pgb.544.1646420908059; Fri, 04 Mar 2022 11:08:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1646420908; cv=none; d=google.com; s=arc-20160816; b=aPBF6LDiT0ZCtpet2AwfJdWn6FSA1iHkZ0hb+6eIh5ablLqPXd3oZ4RL1eQOkiNiyX ZFsycPXqgt7mHjELFCT49mUJ7dfeMRnprd59h+prcOnqEBVJJDjNsRbXEQtoDNnBYPuj yF7iQbTjfKwUkD2oUvq+wtLRTBVkAmCJRdS08f6FMx0H/iGec/7DYx5Xah3ksAG8vIvq foU97m2daXk3IfJ0XCSdQnVHAHHBQelfTEPVApImcj7RDuJawAkrtZg5JWL3crcQmOS4 qQEBOsEYh21sdQ4typWNUxWUDEwtia0w6ycAInObrym6CBJM+UpFPLmtDMFF6COvwh5D 7aDw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=Da8BQW91R+I/mDbBGeHp6nR/Fc1yIVFk2ka6ORjpwKQ=; b=nlc9BgulnLRwt0b8qbTR4fz8jHhPMyfWRJssYDNuV5ShqtCqf88ipqqp9wQPzhihzf ZYqfroyusW/dk2/fP/2S6Xml76+Ke7Sdcakogtga2PIjgye8EfB+wQGP4ifhC+GDrRpR SnX66pxraT6Y/UTvy4eULRghaKP2PN73I0Gu98CBq80NDgpd6ubXCHRVAKSO5vSK+EW0 TFVM2N/2swdwrkjaCG23wAuj+ciSzbv8K4pmRJu0e7O4Y8emnQK6grg1C7NxjYKGGPhl gPsX5jfe+W4jWI0J7lt/nyZOw8i2MCZyqhyEapRklcNuODCKnQKW/T/VtvVJXQ284f2c 73MA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=mediatek.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id x18-20020a170902ec9200b00151cacdd311si421192plg.316.2022.03.04.11.08.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 04 Mar 2022 11:08:28 -0800 (PST) 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; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=mediatek.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 920629026D; Fri, 4 Mar 2022 11:03:03 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229938AbiCCXJS (ORCPT + 99 others); Thu, 3 Mar 2022 18:09:18 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34880 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229625AbiCCXJQ (ORCPT ); Thu, 3 Mar 2022 18:09:16 -0500 Received: from mailgw01.mediatek.com (unknown [60.244.123.138]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0F17546679 for ; Thu, 3 Mar 2022 15:08:28 -0800 (PST) X-UUID: a0062f3918ee45d48cd2d42cbe27ea98-20220304 X-UUID: a0062f3918ee45d48cd2d42cbe27ea98-20220304 Received: from mtkexhb01.mediatek.inc [(172.21.101.102)] by mailgw01.mediatek.com (envelope-from ) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-SHA384 256/256) with ESMTP id 2024328738; Fri, 04 Mar 2022 07:08:22 +0800 Received: from mtkcas10.mediatek.inc (172.21.101.39) by mtkmbs10n1.mediatek.inc (172.21.101.34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.2.792.15; Fri, 4 Mar 2022 07:08:21 +0800 Received: from mtksdccf07.mediatek.inc (172.21.84.99) by mtkcas10.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Fri, 4 Mar 2022 07:08:21 +0800 From: Miles Chen To: CC: , , , , , , Subject: Re: [PATCH] iommu/iova: Improve 32-bit free space estimate Date: Fri, 4 Mar 2022 07:08:21 +0800 Message-ID: <20220303230821.13149-1-miles.chen@mediatek.com> X-Mailer: git-send-email 2.18.0 In-Reply-To: <033815732d83ca73b13c11485ac39336f15c3b40.1646318408.git.robin.murphy@arm.com> References: <033815732d83ca73b13c11485ac39336f15c3b40.1646318408.git.robin.murphy@arm.com> MIME-Version: 1.0 Content-Type: text/plain X-MTK: N X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY 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 > For various reasons based on the allocator behaviour and typical > use-cases at the time, when the max32_alloc_size optimisation was > introduced it seemed reasonable to couple the reset of the tracked > size to the update of cached32_node upon freeing a relevant IOVA. > However, since subsequent optimisations focused on helping genuine > 32-bit devices make best use of even more limited address spaces, it > is now a lot more likely for cached32_node to be anywhere in a "full" > 32-bit address space, and as such more likely for space to become > available from IOVAs below that node being freed. > > At this point, the short-cut in __cached_rbnode_delete_update() really > doesn't hold up any more, and we need to fix the logic to reliably > provide the expected behaviour. We still want cached32_node to only move > upwards, but we should reset the allocation size if *any* 32-bit space > has become available. > > Reported-by: Yunfei Wang > Signed-off-by: Robin Murphy Reviewed-by: Miles Chen