From owner-freebsd-hackers@freebsd.org Mon Feb 6 18:53:57 2017 Return-Path: Delivered-To: freebsd-hackers@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 45C29CD39CB; Mon, 6 Feb 2017 18:53:57 +0000 (UTC) (envelope-from auryn@zirakzigil.org) Received: from mx1.etoilesoft.fr (mx1.etoilesoft.fr [52.57.51.18]) by mx1.freebsd.org (Postfix) with ESMTP id 10A8B1566; Mon, 6 Feb 2017 18:53:56 +0000 (UTC) (envelope-from auryn@zirakzigil.org) Received: from mx1.etoilesoft.fr (localhost [127.0.0.1]) by mx1.etoilesoft.fr (Postfix) with ESMTP id 95E039D19F; Mon, 6 Feb 2017 18:54:08 +0000 (UTC) Received: from [172.20.15.189] (localhost [127.0.0.1]) (Authenticated sender: auryn@zirakzigil.org) by mx1.etoilesoft.fr (Postfix) with ESMTPA id 262019D19D; Mon, 6 Feb 2017 18:54:08 +0000 (UTC) To: "freebsd-net@freebsd.org" , freebsd-hackers@freebsd.org From: Giulio Ferro Subject: Duplicate MAC addresses in VNET epair interaces Message-ID: <472069af-0f9d-d830-064b-2d984a5774ae@zirakzigil.org> Date: Mon, 6 Feb 2017 19:53:48 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.7.0 MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit X-Virus-Scanned: ClamAV using ClamSMTP X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 06 Feb 2017 18:53:57 -0000 Hi all, Setup: 11.0-STABLE FreeBSD 11.0-STABLE #0 r312338: Tue Jan 17 12:29:38 UTC 2017 I've set up two freebsd hosts, each of which has a single VNET jail. On each host I've created 2 epair interfaces. Host A - epair0a, epair1a on the host - epair0b, epair1b on the jail Host B - epair0a, epair10a on the host - epair0b, epair10b on the jail What I noticed is that on both hosts, each epair interface has the same MAC address: Host A: root@xxx:~ # ifconfig epair0a epair0a: flags=8843 metric 0 mtu 1500 options=8 ether 02:ff:e0:00:03:0a inet 192.168.0.1 netmask 0xffffff00 broadcast 192.168.0.255 nd6 options=29 media: Ethernet 10Gbase-T (10Gbase-T ) status: active groups: epair root@xxx:~ # ifconfig epair1a epair1a: flags=8943 metric 0 mtu 1500 options=8 ether 02:ff:e0:00:05:0a nd6 options=29 media: Ethernet 10Gbase-T (10Gbase-T ) status: active groups: epair Host B: root@yyy:~ # ifconfig epair0a epair0a: flags=8843 metric 0 mtu 1500 options=8 ether 02:ff:e0:00:03:0a inet 192.168.0.1 netmask 0xffffff00 broadcast 192.168.0.255 nd6 options=29 media: Ethernet 10Gbase-T (10Gbase-T ) status: active groups: epair root@yyy:~ # ifconfig epair10a epair10a: flags=28943 metric 0 mtu 1500 options=8 ether 02:ff:e0:00:05:0a nd6 options=29 media: Ethernet 10Gbase-T (10Gbase-T ) status: active groups: epair (same behavior on the epair interfaces on the jail side) As you can see, the mac addresses seems to depend on the order of the creation of the epair, not on the name or address This is a potentially bad behavior, because if I want to bridge say epair1a on A with epair10a on B with a VPN or a physical connection giving 192.168.1.1 to epair1b and 192.168.1.2 to epair10b, I won't be able to make them talk to each other since they have the same MAC address. My question is: is this a bug or something I'm doing wrong? If there any workaround I can use? Thanks Giulio