Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3511939pxf; Mon, 15 Mar 2021 11:10:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzX2PU6i3O4Gw6VVuUZDBpdDtnBkYub0OmBQEIVIA4iQEKKXo7fVq3CtaBCxmu+aaFNOzvs X-Received: by 2002:a17:906:3552:: with SMTP id s18mr25404459eja.497.1615831818170; Mon, 15 Mar 2021 11:10:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1615831818; cv=none; d=google.com; s=arc-20160816; b=BQHzCZ1gx6J9VlzofACPd2wBs3jPFF2hVvxSzFg/7CywJ9NxeKwbd+0tw5R1CO9Qfm khkdwFvukcsMv2xQMEV43ZYxFyO7+O8/IC4dx3b8KNLyTQulPisbhkN9SC08+uTNI05c R4aJGpD/O0LypDZ0hNd5H+0Ztud/HPWlkmtC3SibYIvfHw2HSoreK3+ZzonieRdUvrKE DDHpxjNuHuB7fFbRDluQt3L5+6fJIER+TG2Qai/gyxzyu7ZJyhYilbC12Zwv04NOu+pD JXKC49LdVe3TeQQdk9N/tuqriLVEGUOEXLSzsLtjw92mYc+G7VAqnhjr5N+onDqnaWC9 Rj9Q== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=L4cX9e70q94EdDBQ+L/43fNgpqpGhBBZTQCiBQhIiHk=; b=xTNJkAIrd/ismCojRb5n+2eKZtZrzukkG4W/3J7uZQ41jvOobEZitugmF/Yremx3s9 P7cL9X8NJzgX9maS+ncRAmKFWme8D6sJ0FATnHZYarcF4XIJOfSlz8pvnYFQVXseFVKU D3dmmK/FSyLZAnKfu6XzSXMQzb2LDBJwoQ3LgQH4KnbmNIQKpW/5Rw+aDAOJRjU5L5Ej xbs5YN8pe2EhEpa/4EGW0kZn+YRBmbXmrBmjLd0FPk5he9WmggaSpsl0uRra52421AA5 mDI/wWB4RCKJC/7Iqvcn+CECAo3oKeWqXV/jEpZJA74reCWMVxQury1gI8NS7M0POxgQ KAZw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=JLOK71+1; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s18si12435800ejj.88.2021.03.15.11.09.53; Mon, 15 Mar 2021 11:10:18 -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=@linuxfoundation.org header.s=korg header.b=JLOK71+1; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235715AbhCOOK0 (ORCPT + 99 others); Mon, 15 Mar 2021 10:10:26 -0400 Received: from mail.kernel.org ([198.145.29.99]:37670 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232290AbhCON6W (ORCPT ); Mon, 15 Mar 2021 09:58:22 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 69F9B64EF3; Mon, 15 Mar 2021 13:58:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1615816698; bh=6JzNxAYuGj0N3DsPXW3YpmIefZQqBRq5K6bvIzYn8aU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=JLOK71+1lQzsUQ6IMd3uDZDn66R6rKDWYcTcvXvDIQhUebCMcCNKJtMCPKweZZ8HJ tJq8CeVUG20N7S1uj+vpbgRom0eT/6fkQfP5cHjXyWhi+Fq722J4v5XaOD6BnS9bYE 0oDfJpjqhlZUviqVpcMCFw+oD1iuV8WS0WBSFI9Y= From: gregkh@linuxfoundation.org To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Maxim Mikityanskiy , "David S. Miller" Subject: [PATCH 4.14 05/95] net: Introduce parse_protocol header_ops callback Date: Mon, 15 Mar 2021 14:56:35 +0100 Message-Id: <20210315135740.438622487@linuxfoundation.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20210315135740.245494252@linuxfoundation.org> References: <20210315135740.245494252@linuxfoundation.org> User-Agent: quilt/0.66 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 From: Greg Kroah-Hartman From: Maxim Mikityanskiy commit e78b2915517e8fcadb1bc130ad6aeac7099e510c upstream. Introduce a new optional header_ops callback called parse_protocol and a wrapper function dev_parse_header_protocol, similar to dev_parse_header. The new callback's purpose is to extract the protocol number from the L2 header, the format of which is known to the driver, but not to the upper layers of the stack. Signed-off-by: Maxim Mikityanskiy Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- include/linux/netdevice.h | 10 ++++++++++ 1 file changed, 10 insertions(+) --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h @@ -272,6 +272,7 @@ struct header_ops { const struct net_device *dev, const unsigned char *haddr); bool (*validate)(const char *ll_header, unsigned int len); + __be16 (*parse_protocol)(const struct sk_buff *skb); }; /* These flag bits are private to the generic network queueing @@ -2731,6 +2732,15 @@ static inline int dev_parse_header(const return dev->header_ops->parse(skb, haddr); } +static inline __be16 dev_parse_header_protocol(const struct sk_buff *skb) +{ + const struct net_device *dev = skb->dev; + + if (!dev->header_ops || !dev->header_ops->parse_protocol) + return 0; + return dev->header_ops->parse_protocol(skb); +} + /* ll_header must have at least hard_header_len allocated */ static inline bool dev_validate_header(const struct net_device *dev, char *ll_header, int len)