Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp3699565pxv; Mon, 5 Jul 2021 03:41:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwCn4Se8Q6OPHrmbTF8QGHrlJRsWG3Ap0QdxMxKLCvH8JdLj4DpwyayVCq1gNqYbwgJ6zfK X-Received: by 2002:a17:907:2da0:: with SMTP id gt32mr13082111ejc.58.1625481698364; Mon, 05 Jul 2021 03:41:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625481698; cv=none; d=google.com; s=arc-20160816; b=wdq3NOgQ6fjWl5L3Oh5NlgXTsTRxp1TUo6eOLKP7nn+kj8NLn1x6HIyyzrvIjYjLQ9 DSVb3kihdbl5/TUJZvRkGBYQjTQFvPZSxSxPKAUz/1Ei9P1ggiMWasRF4Rv6iE1aFGLC HtRinMJUVlYiwrnNdM/dioMFxP4+7VSxSgdJ9OClMBKTfYqJddUBW2RSEZt/C8MzL2A/ h5CTgbynA1+TE2DMjF261U0dujyefBkcxoJ8ftdSkYf1aZROkk+yXtPFVvHwtLqFrbNH WNwp2Lxy/J/n6aL5f7/nG4QdiRvhEXBnuoabocoZnh061x7DbZlZYxVS7UywVGHB4KPt p+hA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=hmyjf7EoeXbYEDsziKL9vvOOtbbXjWfHV1JQXzPMhDY=; b=N9hm4Ygn+iVZPv+8tpyvfQx+Nn7LjyHzCHBXTnfUBXLSoSGnYDZ3KoWvfcVW9madHO faTCgWcadGdy4sZoZrSUGYyYjtxhLncI/ik/q9VkhqBOVnn46ibpbiD7trkyMdX2oZZB sGlQtVvXkkitT0htmOEu6lQzRzG1okwOtgzrBIhgUtWzxm0CT/npuk3eHLoskUOdQmU8 x/yXjUAMda65A/Tar98uuKM0kmdEHu/lqL6YkpyvszL7Yshc1MveS3r1tPYm/qc4L0ZQ ncLp05SQONPK6l5x4QX7jpekmVX6u7w2lm4BigMBj4h/gnd7OZJmHnm5fDPTQ/fOt0Oz oNwQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t15si7189897edr.311.2021.07.05.03.41.14; Mon, 05 Jul 2021 03:41:38 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231166AbhGEKmw (ORCPT + 99 others); Mon, 5 Jul 2021 06:42:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57904 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230474AbhGEKmv (ORCPT ); Mon, 5 Jul 2021 06:42:51 -0400 Received: from Chamillionaire.breakpoint.cc (Chamillionaire.breakpoint.cc [IPv6:2a0a:51c0:0:12e:520::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 99FB4C061574; Mon, 5 Jul 2021 03:40:14 -0700 (PDT) Received: from fw by Chamillionaire.breakpoint.cc with local (Exim 4.92) (envelope-from ) id 1m0M19-0001Ez-WE; Mon, 05 Jul 2021 12:40:00 +0200 Date: Mon, 5 Jul 2021 12:39:59 +0200 From: Florian Westphal To: Cole Dishington Cc: pablo@netfilter.org, Anthony Lineham , Scott Parlane , Blair Steven , Jozsef Kadlecsik , Florian Westphal , "David S. Miller" , Jakub Kicinski , netfilter-devel@vger.kernel.org, coreteam@netfilter.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] net: netfilter: Add RFC-7597 Section 5.1 PSID support Message-ID: <20210705103959.GG18022@breakpoint.cc> References: <20210630142049.GC18022@breakpoint.cc> <20210705040856.25191-1-Cole.Dishington@alliedtelesis.co.nz> <20210705040856.25191-3-Cole.Dishington@alliedtelesis.co.nz> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210705040856.25191-3-Cole.Dishington@alliedtelesis.co.nz> User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Cole Dishington wrote: > Adds support for masquerading into a smaller subset of ports - > defined by the PSID values from RFC-7597 Section 5.1. This is part of > the support for MAP-E and Lightweight 4over6, which allows multiple > devices to share an IPv4 address by splitting the L4 port / id into > ranges. > > Co-developed-by: Anthony Lineham > Signed-off-by: Anthony Lineham > Co-developed-by: Scott Parlane > Signed-off-by: Scott Parlane > Signed-off-by: Blair Steven > Signed-off-by: Cole Dishington > --- Just a quick review: > + /* In this case we are in PSID mode, avoid checking all ranges by computing bitmasks */ > + if (is_psid) { > + u16 j = ntohs(max->all) - ntohs(min->all) + 1; > + u16 a = (1 << 16) / ntohs(base->all); This gives crash when base->all is 0. If this is impossible, please add a comment, otherwise this needs a sanity test on the divisor. > @@ -55,8 +55,21 @@ nf_nat_masquerade_ipv4(struct sk_buff *skb, unsigned int hooknum, > newrange.flags = range->flags | NF_NAT_RANGE_MAP_IPS; > newrange.min_addr.ip = newsrc; > newrange.max_addr.ip = newsrc; > - newrange.min_proto = range->min_proto; > - newrange.max_proto = range->max_proto; > + > + if (range->flags & NF_NAT_RANGE_PSID) { > + u16 off = prandom_u32(); > + u16 base = ntohs(range->base_proto.all); > + u16 min = ntohs(range->min_proto.all); > + u16 max_off = ((1 << 16) / base) - 1; > + > + newrange.flags = newrange.flags | NF_NAT_RANGE_PROTO_SPECIFIED; > + newrange.min_proto.all = htons(min + base * (off % max_off)); Same here for base and max_off.