Received: by 2002:ac0:a679:0:0:0:0:0 with SMTP id p54csp559467imp; Thu, 21 Feb 2019 06:51:38 -0800 (PST) X-Google-Smtp-Source: AHgI3IaHkCpZccW2CjGF5t8MscxzpctulXzRyD5tw1jJD+D4OxQ8G9kYmZrIbnHheRRhkqhHgWkn X-Received: by 2002:a63:54c:: with SMTP id 73mr6890394pgf.295.1550760698367; Thu, 21 Feb 2019 06:51:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550760698; cv=none; d=google.com; s=arc-20160816; b=d/751CMPCLQO7818Bd8qgIjwcecP8zgs1NYZSM+vZzv8D1jnc5h9D/hiywxcIQz026 h9IQewt6cuSgOmFhmhnGab+3DDMZ96CfVmxwra+3G+/6pa5QiSMy3AvlD8zI/lEA/UvT Ulj9Y5D5lkv32veCw5v0g9t56qT36VkkTT6BrHaEFMhPHRh/4u0KwrwUuV9QjnUYSnO7 7iemGeyefktMsLe52NgpOAMgHh5mCKQJegMubfxXHSicGpJQ0XyJ8j50OhvVBDmwboe+ EOYaqHwFv+Su5kjTWOCwyyi7nh7A33cIwLmTBCwVeJgnkFrzBXDRPcd6J27zQDOrYvQv 3NiA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=/RzpyjrRQm861JkvQ3VMJ+pQ1nmF7xt0csUXHGeQsO0=; b=pauJaPM6YzLFwNco0BkvTY4DZAYTybTBK/X71UEiei5dAKyODLtXu/FVxm1qlZRB8t enQyp+/97+RUH0b26FQIv5UNHCKIz+z2i29Ctgg23qeJ04rkguYX/nKlr32kpIhuqQD7 LvnmneuEBXlwUbtRYUg7edDbiQclWDw87mObfXQ6rJCEDix9UrjNkW+id09N3qO+hl2J 4pDi+F9ejYNuOrCN5jfT5vL4IekApcPbqURIDVrb7Ln+qyyOW5L33NuO390TmunWafyf G58+aNkVmF/nxKFwLp9bGK/caJpHBS06JNdYK3nWVCohYZ0Hu9JFa2Avgd9xn+voHgU+ YrhA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="Ij/++nIX"; 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 q77si21899953pfi.220.2019.02.21.06.51.23; Thu, 21 Feb 2019 06:51:38 -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=@kernel.org header.s=default header.b="Ij/++nIX"; 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 S1728707AbfBUOih (ORCPT + 99 others); Thu, 21 Feb 2019 09:38:37 -0500 Received: from mail.kernel.org ([198.145.29.99]:60384 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728698AbfBUOie (ORCPT ); Thu, 21 Feb 2019 09:38:34 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 7A28A20838; Thu, 21 Feb 2019 14:38:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1550759914; bh=HFeKOf7BvP+DA553igZKP/B9NshuS38YunMx0QXnGnQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Ij/++nIXTKt5hdqG4YG+FW8GsedeVCEK3sNPtcOwSDRhhF9cMEp18ArpveOumoyfG nkbmX17Mqm42VatYOp3Fw1/+2lSp7BadijD4gvPBPCjKllJxm7xg2RJe13luklPnr1 SXYRegM/jq8HoDDlQxfLRRBz+t7FPCNyL8uaOmLA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jann Horn , Alexander Duyck , "David S. Miller" Subject: [PATCH 4.9 12/20] net: Do not allocate page fragments that are not skb aligned Date: Thu, 21 Feb 2019 15:35:50 +0100 Message-Id: <20190221125243.589040429@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190221125242.153179182@linuxfoundation.org> References: <20190221125242.153179182@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.9-stable review patch. If anyone has any objections, please let me know. ------------------ From: Alexander Duyck [ Upstream commit 3bed3cc4156eedf652b4df72bdb35d4f1a2a739d ] This patch addresses the fact that there are drivers, specifically tun, that will call into the network page fragment allocators with buffer sizes that are not cache aligned. Doing this could result in data alignment and DMA performance issues as these fragment pools are also shared with the skb allocator and any other devices that will use napi_alloc_frags or netdev_alloc_frags. Fixes: ffde7328a36d ("net: Split netdev_alloc_frag into __alloc_page_frag and add __napi_alloc_frag") Reported-by: Jann Horn Signed-off-by: Alexander Duyck Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- net/core/skbuff.c | 4 ++++ 1 file changed, 4 insertions(+) --- a/net/core/skbuff.c +++ b/net/core/skbuff.c @@ -383,6 +383,8 @@ static void *__netdev_alloc_frag(unsigne */ void *netdev_alloc_frag(unsigned int fragsz) { + fragsz = SKB_DATA_ALIGN(fragsz); + return __netdev_alloc_frag(fragsz, GFP_ATOMIC | __GFP_COLD); } EXPORT_SYMBOL(netdev_alloc_frag); @@ -396,6 +398,8 @@ static void *__napi_alloc_frag(unsigned void *napi_alloc_frag(unsigned int fragsz) { + fragsz = SKB_DATA_ALIGN(fragsz); + return __napi_alloc_frag(fragsz, GFP_ATOMIC | __GFP_COLD); } EXPORT_SYMBOL(napi_alloc_frag);