Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp116678pxu; Wed, 2 Dec 2020 16:48:50 -0800 (PST) X-Google-Smtp-Source: ABdhPJwNTcQ3b3hq3noY1uz7wqsBNcHf00tR/vlcyMgCKS23yIGzWeEoDi/s2I+EX47tM1Wc+HP0 X-Received: by 2002:a17:906:9345:: with SMTP id p5mr398351ejw.40.1606956529858; Wed, 02 Dec 2020 16:48:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606956529; cv=none; d=google.com; s=arc-20160816; b=LU4sY20PnliK1fHh3h1SBesTckQtAiz4ECM8LbNy7/gXK1eDe6+UqQZb4qMQZ/JaqT e2f6iAksBNWoDvvfZwMv40/p/yyJBVsHvYKIDMC/PS/8Q/cgI8dpkZF+M/oqPifycBCZ yzyYYuHIy0YdHLKwgw5denJB5CE6iLcCVRKXO10NZMBjYv1zG5ALBJbFwai48oDo1tdW oRj9UmE2MjtzeT3k5nBjZe8neGqACeM/K+ORu6fOm8HUkDeVUeYsMQiMnynyuisN15m6 K+FOLRrrAtHG1X1lablAFnY4whi9Rxx9QIIQU0MIXzVTe6zn5Jw7DHlJqVWqWfJze/Uo Kkdw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=8EDCn101SFARHTTM1x2YExb2aB0Hg6FLAdBXqacqkCk=; b=LoCT62uz4pahrjCTXMHEIKf45lpEqZYLg9Flj2E6D8d4hpKzHzDerkabueCnUe0w0F hkl5d1ot9kFkfeT7DRlIK8W/bV8EpFnTCqG8J9ObPXxfNCnvGaImnmIRAcq7SJy6Y/S/ o0qJRGDFD3l0YhY/tnknDPKRQfd0TONJTX7oYQhg0qJlcFtvYf7r0zvMKE5HYQP5iVk6 e9ZZZvfuckd7ZUJBFkZrlqPZpvoelRkcxHbz+wm6Uu/xEkA7P8YSHZMU8ghfIfTLigp+ JwlkXRZmMzE/rCBaPOfA/0aH4QML/Oo7m/RMh1uUqh1n1H5z3nNmDNzh72G7RuVXQ7LO 1Q9Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=hY++CIev; 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 91si360083edy.541.2020.12.02.16.48.26; Wed, 02 Dec 2020 16:48:49 -0800 (PST) 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=@redhat.com header.s=mimecast20190719 header.b=hY++CIev; 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726929AbgLCAph (ORCPT + 99 others); Wed, 2 Dec 2020 19:45:37 -0500 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:46037 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727078AbgLCApg (ORCPT ); Wed, 2 Dec 2020 19:45:36 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1606956249; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=8EDCn101SFARHTTM1x2YExb2aB0Hg6FLAdBXqacqkCk=; b=hY++CIeve54nt2ZfRvL+G0boc8dDeFiUzGtehr7LWYngHclCt0+LWp2gH9PrC7v7Fzv8Zf iCGNpNtVI5xHRtPckFZCkvnFGUo9oRwCXKyn+PJU1aUEbuweqbOGaiEyUBB47V6IAK2Ei2 qjKp0q+UR8Tb4v0gOSXR+SDgIMPVDII= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-453-v018RCeoPrS-9pv7ITQBjQ-1; Wed, 02 Dec 2020 19:44:07 -0500 X-MC-Unique: v018RCeoPrS-9pv7ITQBjQ-1 Received: from smtp.corp.redhat.com (int-mx07.intmail.prod.int.phx2.redhat.com [10.5.11.22]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id AA6751007463; Thu, 3 Dec 2020 00:44:05 +0000 (UTC) Received: from f33vm.wilsonet.com.wilsonet.com (dhcp-17-185.bos.redhat.com [10.18.17.185]) by smtp.corp.redhat.com (Postfix) with ESMTP id A36F810013C0; Thu, 3 Dec 2020 00:44:00 +0000 (UTC) From: Jarod Wilson To: linux-kernel@vger.kernel.org Cc: Jarod Wilson , Ivan Vecera , Jay Vosburgh , Veaceslav Falico , Andy Gospodarek , "David S. Miller" , Jakub Kicinski , Thomas Davis , netdev@vger.kernel.org Subject: [PATCH net v3] bonding: fix feature flag setting at init time Date: Wed, 2 Dec 2020 19:43:57 -0500 Message-Id: <20201203004357.3125-1-jarod@redhat.com> In-Reply-To: <20201202173053.13800-1-jarod@redhat.com> References: <20201202173053.13800-1-jarod@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.84 on 10.5.11.22 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Don't try to adjust XFRM support flags if the bond device isn't yet registered. Bad things can currently happen when netdev_change_features() is called without having wanted_features fully filled in yet. This code runs on post-module-load mode changes, as well as at module init time and new bond creation time, and in the latter two scenarios, it is running prior to register_netdevice() having been called and subsequently filling in wanted_features. The empty wanted_features led to features also getting emptied out, which was definitely not the intended behavior, so prevent that from happening. Originally, I'd hoped to stop adjusting wanted_features at all in the bonding driver, as it's documented as being something only the network core should touch, but we actually do need to do this to properly update both the features and wanted_features fields when changing the bond type, or we get to a situation where ethtool sees: esp-hw-offload: off [requested on] I do think we should be using netdev_update_features instead of netdev_change_features here though, so we only send notifiers when the features actually changed. v2: rework based on further testing and suggestions from ivecera v3: add helper function, remove goto, fix problem description Fixes: a3b658cfb664 ("bonding: allow xfrm offload setup post-module-load") Reported-by: Ivan Vecera Suggested-by: Ivan Vecera Cc: Jay Vosburgh Cc: Veaceslav Falico Cc: Andy Gospodarek Cc: "David S. Miller" Cc: Jakub Kicinski Cc: Thomas Davis Cc: netdev@vger.kernel.org Signed-off-by: Jarod Wilson --- drivers/net/bonding/bond_main.c | 10 ++++------ drivers/net/bonding/bond_options.c | 19 ++++++++++++++----- 2 files changed, 18 insertions(+), 11 deletions(-) diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c index 47afc5938c26..7905534a763b 100644 --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c @@ -4747,15 +4747,13 @@ void bond_setup(struct net_device *bond_dev) NETIF_F_HW_VLAN_CTAG_FILTER; bond_dev->hw_features |= NETIF_F_GSO_ENCAP_ALL | NETIF_F_GSO_UDP_L4; -#ifdef CONFIG_XFRM_OFFLOAD - bond_dev->hw_features |= BOND_XFRM_FEATURES; -#endif /* CONFIG_XFRM_OFFLOAD */ bond_dev->features |= bond_dev->hw_features; bond_dev->features |= NETIF_F_HW_VLAN_CTAG_TX | NETIF_F_HW_VLAN_STAG_TX; #ifdef CONFIG_XFRM_OFFLOAD - /* Disable XFRM features if this isn't an active-backup config */ - if (BOND_MODE(bond) != BOND_MODE_ACTIVEBACKUP) - bond_dev->features &= ~BOND_XFRM_FEATURES; + bond_dev->hw_features |= BOND_XFRM_FEATURES; + /* Only enable XFRM features if this is an active-backup config */ + if (BOND_MODE(bond) == BOND_MODE_ACTIVEBACKUP) + bond_dev->features |= BOND_XFRM_FEATURES; #endif /* CONFIG_XFRM_OFFLOAD */ } diff --git a/drivers/net/bonding/bond_options.c b/drivers/net/bonding/bond_options.c index 9abfaae1c6f7..1ae0e5ab8c67 100644 --- a/drivers/net/bonding/bond_options.c +++ b/drivers/net/bonding/bond_options.c @@ -745,6 +745,18 @@ const struct bond_option *bond_opt_get(unsigned int option) return &bond_opts[option]; } +#ifdef CONFIG_XFRM_OFFLOAD +static void bond_set_xfrm_features(struct net_device *bond_dev, u64 mode) +{ + if (mode == BOND_MODE_ACTIVEBACKUP) + bond_dev->wanted_features |= BOND_XFRM_FEATURES; + else + bond_dev->wanted_features &= ~BOND_XFRM_FEATURES; + + netdev_update_features(bond_dev); +} +#endif /* CONFIG_XFRM_OFFLOAD */ + static int bond_option_mode_set(struct bonding *bond, const struct bond_opt_value *newval) { @@ -768,11 +780,8 @@ static int bond_option_mode_set(struct bonding *bond, bond->params.tlb_dynamic_lb = 1; #ifdef CONFIG_XFRM_OFFLOAD - if (newval->value == BOND_MODE_ACTIVEBACKUP) - bond->dev->wanted_features |= BOND_XFRM_FEATURES; - else - bond->dev->wanted_features &= ~BOND_XFRM_FEATURES; - netdev_change_features(bond->dev); + if (bond->dev->reg_state == NETREG_REGISTERED) + bond_set_xfrm_features(bond->dev, newval->value); #endif /* CONFIG_XFRM_OFFLOAD */ /* don't cache arp_validate between modes */ -- 2.28.0