From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-pf1-f179.google.com (mail-pf1-f179.google.com [209.85.210.179]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 8E880241695 for ; Mon, 15 Jun 2026 17:46:23 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.210.179 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1781545584; cv=none; b=tIvVz41kp8a0jnaZhJvSxZgVx7ShCer1yEc4ucYIC/IaOHOqJxs8WThPz4t5U8YiWkNwqUMPGQslK5f6mKUeSEu98is+knnviaRoIQqSVDax2lYR0bh94qv1hYeJufMEh5SOR7AU5kfvNIiIGOy4lLlzm134WAzn1mJUP3iMLlQ= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1781545584; c=relaxed/simple; bh=pyOrnNpJGd2dapO35pY6K6uj+/dk+op3maz1n/yK9Mw=; h=From:Subject:Date:To:Cc:Message-ID:In-Reply-To:References; b=YoVouext6ZlpR4ZkI50pOw0w0vBOEosuek2Gj/ydX6Q/O5ygOiuq3kAr/FRFG7p4SNcMqORQSfNiWT5G63pbE7FdeYrT0vbonwJHUYNStCLZM9RyqLV3P7RYfyq/tqOG8Ucwr2ht5wmpxp/Lp0Av8Snj4Pl6DlNrIMnxfCDQw8k= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ankey.net; spf=none smtp.mailfrom=ankey.net; dkim=pass (2048-bit key) header.d=ankey-net.20251104.gappssmtp.com header.i=@ankey-net.20251104.gappssmtp.com header.b=TJ5X9c9+; arc=none smtp.client-ip=209.85.210.179 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ankey.net Authentication-Results: smtp.subspace.kernel.org; spf=none smtp.mailfrom=ankey.net Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=ankey-net.20251104.gappssmtp.com header.i=@ankey-net.20251104.gappssmtp.com header.b="TJ5X9c9+" Received: by mail-pf1-f179.google.com with SMTP id d2e1a72fcca58-84237c55ef9so2327077b3a.0 for ; Mon, 15 Jun 2026 10:46:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ankey-net.20251104.gappssmtp.com; s=20251104; t=1781545583; x=1782150383; darn=vger.kernel.org; h=references:in-reply-to:message-id:cc:to:date:subject:from:from:to :cc:subject:date:message-id:reply-to; bh=J6Dz8o9Ws8v17p3yxoQcldpA2jKECp2Yes6whuzgrz0=; b=TJ5X9c9+290G1aY1H+x96js5ox8q/MxFg3tB61ySvPkkmDOVFyIsnNbz5u+MYNy3s9 TorTuaRcrvMzXDuZ3A3APmTVYfdF5a9viLLytDjHBfnm6wFIcOhxFDNxYoQzADhOnXEQ ZJ/AYAw5xxFJWnQT0VVCu1bNZj9jAbSHw3nb1/kk1cGYYvaqK6LZ6FhgwI8I9WeotmfO JXMtFeoYf3iA/s/e52i601WELUPHg842Eidps6S/H1jCaUfovHqBJSDv1sU+lVYvCodM xL8ofipx7zwgVzYEndd812Uzb9flVHJu8RoOoA9Vh7Emrih8GfX/CPrZXyvCOfIeasUI fNJA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1781545583; x=1782150383; h=references:in-reply-to:message-id:cc:to:date:subject:from:x-gm-gg :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=J6Dz8o9Ws8v17p3yxoQcldpA2jKECp2Yes6whuzgrz0=; b=mXHXIHk2YmTMXhwk0+1iehG7HHgr+5atcjZsZct9oD8LJG3N+7chAKWTce42gtEDYf MFr56/zbFJgwf47Ep2mTj+Qp+BmG3nfdiR8MkNWtSiOiEVex+77XzaAuuDlYceI2mZsF PoH8zzOnLsEmb8nEiv3l1LeHfFwfIw2xQVyNau4jgon273bowzA4ziXKybhRDuLn1cdp 5jb6yDw2broHqhGQ9hyT9TFXJuSyScb/QDznRTJ4BQOwE+c2xgjREUCXAtDt0NoqMovV xjkQ0XZ1sPLPzvAfS0h+zdbEtnQTphq5oDBUI1mE4IzRO6ckC5LcANKxupZvJJOJtyTp KyQA== X-Forwarded-Encrypted: i=1; AFNElJ8rwNvCOC0osl3/2QwUJOiRObGbMQFlQxah7BVeZWH60kUvLoK+LrsZLcVuC8CPiKEJCLX32JHYKgANv5g=@vger.kernel.org X-Gm-Message-State: AOJu0YzCdTHAck8lBPH4c82Bxf0QB9ogIDqEWl6ReKz6N0/MUjcMY2q8 nV52Ul0uplTKmM2qBYWlTRFg5pCy8t615T8vf2YGK83CBCzY5Hd5Ut/c3oFv12J2NA== X-Gm-Gg: Acq92OFR2p2oFjedi80F4+RMjKiXPNw5REZtxyrJJfSiCnjjwILt8mbRAKsgKnviMQa lPTgD2kPRsow5Ufdoi/SaYlFKGZ4RqlPBt2dvSXXNmKNuK1m6nqUhTs9Uh/T2TX73t3B1NQg6R/ EDLTJ8sg/OmSF/DphIYgTtXyQzN5M3A2YNFsMzfTbJjOlyPlwgsjKn2Gdus8AieM9m7M96RUXgu F3upGv10vxFcNo8sWwGHmX9WWXm8d4kPKo55tIUL5ojcZV/63OhztzOGDGWF2j6Ybx6cSq3FlMG ul0ropvc2RNbSg8ncdu4CKXiMKU2+oXBHrLC1xCGpn2zihpC0kUjU08pN6p/RMnn5YShafVQ5CX vybyRX5ea31eCEMIrhIn/GWvbyQY3lXFGoAYcX6BM/SJGPbaEPP8PtDAhA73cBq+kfGGqFbcgig a7aRcBQoxVO5cV/BACr0MSGKgrcQcKANNohznatNlTjRAxti7jyN888jPAS+L8j0+KAM0RzR8IH zUzkwaGEdSPMYxwaUMj+fqv2nEXMrSKiL9G X-Received: by 2002:a05:6a00:3908:b0:842:33f3:da7f with SMTP id d2e1a72fcca58-8434cd0c971mr15482546b3a.2.1781545582913; Mon, 15 Jun 2026 10:46:22 -0700 (PDT) Received: from atimofey-ld1.linkedin.biz ([52.149.25.61]) by smtp.gmail.com with ESMTPSA id d2e1a72fcca58-8434accae18sm11214086b3a.17.2026.06.15.10.46.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 15 Jun 2026 10:46:22 -0700 (PDT) From: Alex Timofeyev Subject: [PATCH rdma-next v1 2/2] RDMA/cma: accept cross-NIC same-host local dst in validate_ipv6_net_dev Date: Mon, 15 Jun 2026 17:46:19 +0000 To: Jason Gunthorpe , Leon Romanovsky , linux-rdma@vger.kernel.org Cc: Parav Pandit , Edward Srouji , Vlad Dumitrescu , stable@vger.kernel.org, linux-kernel@vger.kernel.org Message-ID: <1781545579.3-sashka@ankey.net> In-Reply-To: <1781545579.1-sashka@ankey.net> References: <1781545579.1-sashka@ankey.net> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: validate_ipv6_net_dev() confirms an incoming CM REQ was delivered on the correct net_dev with an rt6_lookup() that requires rt->rt6i_idev->dev == net_dev. For an IPv6 destination that is local to a different netdev of the same host, the FIB resolves the lookup onto the loopback netdev, so rt6i_idev->dev is lo regardless of which physical netdev owns the listener address. The strict comparison then rejects the REQ with -EHOSTUNREACH even though it was correctly delivered on net_dev. Accept the request when the resolved route is RTF_LOCAL and net_dev itself owns the address the listener was bound to (src_addr). This is the receive-side counterpart to the cross-NIC same-host send-side fix in addr_resolve_neigh(). Fixes: f887f2ac87c2 ("IB/cma: Validate routing of incoming requests") Cc: stable@vger.kernel.org Cc: Parav Pandit Signed-off-by: Alex Timofeyev --- drivers/infiniband/core/cma.c | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c index 9480d1a51c11..872c57943362 100644 --- a/drivers/infiniband/core/cma.c +++ b/drivers/infiniband/core/cma.c @@ -1635,7 +1635,20 @@ static bool validate_ipv6_net_dev(struct net_device *net_dev, if (!rt) return false; - ret = rt->rt6i_idev->dev == net_dev; + if (rt->rt6i_idev->dev == net_dev) { + ret = true; + } else if (rt->rt6i_flags & RTF_LOCAL) { + /* For a destination that is local to another netdev of the same + * host, the FIB collapses the lookup onto the loopback netdev, + * so rt6i_idev->dev is not net_dev even though the request was + * correctly delivered on net_dev. Accept it when net_dev itself + * owns the address we were listening on. + */ + ret = ipv6_chk_addr(dev_net(net_dev), &src_addr->sin6_addr, + net_dev, 1); + } else { + ret = false; + } ip6_rt_put(rt); return ret; -- 2.40.4