Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp745863pxb; Wed, 25 Aug 2021 14:06:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzsBqhK655H36IpmC8coFur3fx1XsnAUXxrfep7Oxx+2AQYciKbKIzOa9ZdPG7+ts+vI5df X-Received: by 2002:a02:2307:: with SMTP id u7mr409606jau.28.1629925604784; Wed, 25 Aug 2021 14:06:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629925604; cv=none; d=google.com; s=arc-20160816; b=Sgvyh/UCjYxET/LXY0TQiDWBRezRY1zoQS8mJfcBFVN1naOyXH/qeMcwbGqhxUfbJ6 aR21uBQ0ZxVt76liqr0sSF5xNq+f9FT0TY1hmcmAvNbRCJH0+VzgBRTL+LSzODHljQ4O W7tI8bVhzAF8JLU5F2pv2PImLNyaPK8X/eZW4ZDh6DsejjuYqVUXjjb15lyxGip2+d4g GGyy60A5+fBNpRPcA8q/X3bC3TgEP2+gXr+agYtZQtQ076Mo4gIZSDJORYE9JRN2lTch Zl7BflCml+F+/cv/KIUu22wyfjqLZYRWGzqla2JPYBEIDyqCHMPjVGn0QNm6c0h7n0Qu Zd0Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=Qfk6BSvcgBI7Pc/jE3YW7xZmx9KCBB6EdbOOmvrD6Qc=; b=XavK2BXy4L4P+AnwZuK6k9tKxQm+3jP+kKNgDT0XMKqoIHJjDFe4Tle/XaLEvLBlbq J2nfVwPhV636bExeoiIrk3WdgCqOWqflzMxiMHwQ6k3qoQ85v/X2HtNNKdZL/onorQgH MvyDB9RiMw35aPcefvtBAmefpBa5Z1HTkqec7cltQJWZbpONF8esyCMCveEJBxzWd4Tv NuNteolOkwhQkRyru6n0nVtU/NjEhbw8mMR+NKGlvI0j8QRcqS3+2jcFx/OpKrwe2mJo NJusWzxJ2iua/iT31uCuaEBM0YoZoukGnVZuCFOOfwvuKrOxmC6/EJTsR4D7c5TC0ihu uGNQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="o/kwIS9r"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h6si695496jaj.19.2021.08.25.14.06.31; Wed, 25 Aug 2021 14:06:44 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="o/kwIS9r"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236861AbhHYSbw (ORCPT + 99 others); Wed, 25 Aug 2021 14:31:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41632 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236451AbhHYSbv (ORCPT ); Wed, 25 Aug 2021 14:31:51 -0400 Received: from mail-pl1-x630.google.com (mail-pl1-x630.google.com [IPv6:2607:f8b0:4864:20::630]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0F490C0613C1 for ; Wed, 25 Aug 2021 11:31:05 -0700 (PDT) Received: by mail-pl1-x630.google.com with SMTP id j2so113029pll.1 for ; Wed, 25 Aug 2021 11:31:05 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=Qfk6BSvcgBI7Pc/jE3YW7xZmx9KCBB6EdbOOmvrD6Qc=; b=o/kwIS9r/jytIoTEBqNyRfm1IR4OcGddRWAo+yF9fpQLIb+9crwAo912mpdNTPka7k jEua+cYFJcUHhwXbdudbENPFHXpuVrdJGkBWbMgP8Yv3O9J1NT+qE4YQBsMDrHss0aZZ mATbCEQd0H2F5LDvP/Q+3vnLxXjVKghXtt5BkXNTr5o5yFTuj94hQvHvGCIfSZVCb4mK 0ADz6SCGJEbjL0NoMsqBC2DXVteR88Zr8uklUMYOT1vFoR1QGC+VhR9OuTG6p8+OIto0 BtmIqhLO9WQ4QLXP+gcM1TbJmvC7qhoC8xFqXKlb3PObbxREqOe3oodksIkkajQ6e2ku nR+Q== 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:mime-version :content-transfer-encoding; bh=Qfk6BSvcgBI7Pc/jE3YW7xZmx9KCBB6EdbOOmvrD6Qc=; b=IcYFMBwX5kOFeDmq96uRbjlMiMsQKOR3iS0KHA43H1dzaApUmZXq8UKnVpApD+xCsc aHvId8R27DDcvi6dmGauP86FwGnVy7aLyJO5SAZ/Mh1AkBDVqkI6oUU/EcRYK1bXNhLM AnRSFKsbh21rZJxr3QSjnrC+/L2D+0/q/1rfRQTvqUUf78qRT7XNRFds3L/Tpa6m4iPc pIQVUYRuC0DSerT9NcMA7B5mDJdrCc3AbKm4ADemI1atMcrEsLPWFVfBhZXm4WGsPGTg RmjuzZohzLbGvNdOulhAxTAk8NvtmS+yIpjlIK4h2rLv2qNs6a798a+2rtsO5HCTGCqv sL8Q== X-Gm-Message-State: AOAM530I10CNCNrsv3L8HSf8vOpi4xxuaNbvEJjyFPdwVZ/wHSzSOoRp qn2kJHeaxiW1KsbFg4+4SmUnxjDfs2gNEw== X-Received: by 2002:a17:90a:eb0d:: with SMTP id j13mr10470703pjz.163.1629916263928; Wed, 25 Aug 2021 11:31:03 -0700 (PDT) Received: from localhost.localdomain ([2601:1c2:680:1319:692:26ff:feda:3a81]) by smtp.gmail.com with ESMTPSA id x20sm382813pfh.188.2021.08.25.11.31.02 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 25 Aug 2021 11:31:03 -0700 (PDT) From: John Stultz To: lkml Cc: John Stultz , Daniel Vetter , Christian Koenig , Sumit Semwal , Liam Mark , Chris Goldsworthy , Laura Abbott , Brian Starkey , Hridya Valsaraju , Suren Baghdasaryan , Sandeep Patil , Daniel Mentz , =?UTF-8?q?=C3=98rjan=20Eide?= , Robin Murphy , Ezequiel Garcia , Simon Ser , James Jones , Leo Yan , linux-media@vger.kernel.org, dri-devel@lists.freedesktop.org Subject: [RFC][PATCH] dma-buf: system_heap: Avoid warning on mid-order allocations Date: Wed, 25 Aug 2021 18:30:59 +0000 Message-Id: <20210825183059.1085561-1-john.stultz@linaro.org> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When trying to do mid-order allocations, set __GFP_NOWARN to avoid warning messages if the allocation fails, as we will still fall back to single page allocatitions in that case. This is the similar to what we already do for large order allocations. Cc: Daniel Vetter Cc: Christian Koenig Cc: Sumit Semwal Cc: Liam Mark Cc: Chris Goldsworthy Cc: Laura Abbott Cc: Brian Starkey Cc: Hridya Valsaraju Cc: Suren Baghdasaryan Cc: Sandeep Patil Cc: Daniel Mentz Cc: Ørjan Eide Cc: Robin Murphy Cc: Ezequiel Garcia Cc: Simon Ser Cc: James Jones Cc: Leo Yan Cc: linux-media@vger.kernel.org Cc: dri-devel@lists.freedesktop.org Signed-off-by: John Stultz --- drivers/dma-buf/heaps/system_heap.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/drivers/dma-buf/heaps/system_heap.c b/drivers/dma-buf/heaps/system_heap.c index 23a7e74ef966..f57a39ddd063 100644 --- a/drivers/dma-buf/heaps/system_heap.c +++ b/drivers/dma-buf/heaps/system_heap.c @@ -40,11 +40,12 @@ struct dma_heap_attachment { bool mapped; }; +#define LOW_ORDER_GFP (GFP_HIGHUSER | __GFP_ZERO | __GFP_COMP) +#define MID_ORDER_GFP (LOW_ORDER_GFP | __GFP_NOWARN) #define HIGH_ORDER_GFP (((GFP_HIGHUSER | __GFP_ZERO | __GFP_NOWARN \ | __GFP_NORETRY) & ~__GFP_RECLAIM) \ | __GFP_COMP) -#define LOW_ORDER_GFP (GFP_HIGHUSER | __GFP_ZERO | __GFP_COMP) -static gfp_t order_flags[] = {HIGH_ORDER_GFP, LOW_ORDER_GFP, LOW_ORDER_GFP}; +static gfp_t order_flags[] = {HIGH_ORDER_GFP, MID_ORDER_GFP, LOW_ORDER_GFP}; /* * The selection of the orders used for allocation (1MB, 64K, 4K) is designed * to match with the sizes often found in IOMMUs. Using order 4 pages instead -- 2.25.1