Public bug reported:
I have some VMs running in a host (KVM), and every time any VM sends an ICMP6 Router Advertisement, we get the following log in syslog: Aug 10 11:18:36 Hostname kernel: [1722430.045240] IPv6 header not found For the traffic, I use QinQ (802.1Q in both tags), the inner tag is set with OVS in the tap, and the outer is set with a veth of vlan type, in the following way: +-------------------------------------------------------+ | +-----------+ HOST | | | | Unbuntu 16.04 | | | VM-1 | 4.4.0-62-generic | | | | | +----+------+ | | | | | |TAG=1 | | +-----------------------+ | | | OVS | | | +---------+-------------+ | | | veth1.203 | | | | | | | | +veth0 | | +---------------------+ | | | Bridge | | | +-------+-------------+ | | | | | | | | +--+----+ | | |ens11f1| | +-------------------------------------------------------+ 'Regular traffic' (non ICMP6) seems to work fine, the problem happens apparently only with ICMPv6 (but the packets seem to progress right). I checked the code writing that log, and I think it seems to be in 'kernel/net/ipv6/exthdrs_core.c' if (*offset) { struct ipv6hdr _ip6, *ip6; ip6 = skb_header_pointer(skb, *offset, sizeof(_ip6), &_ip6); if (!ip6 || (ip6->version != 6)) { printk(KERN_ERR "IPv6 header not found\n"); return -EBADMSG; } start = *offset + sizeof(struct ipv6hdr); nexthdr = ip6->nexthdr; } but both the protocol and protocol version seem right in tcpdump: 11:28:38.675686 02:00:40:00:21:31 > 33:33:00:00:00:01, ethertype 802.1Q (0x8100), length 158: vlan 203, p 0, ethertype 802.1Q, vlan 49, p 0, ethertype IPv6, fe80::40ff:fe00:2131 > ff02::1: ICMP6, router advertisement, length 96 `....`:...........@...!1................... @...............@.!1..........@.... ........*.. ..!1................*.. ..!1............. '. 11:28:39.300076 02:00:40:00:23:2a > 33:33:00:00:00:01, ethertype 802.1Q (0x8100), length 158: vlan 204, p 0, ethertype 802.1Q, vlan 193, p 0, ethertype IPv6, fe80::40ff:fe00:232a > ff02::1: ICMP6, router advertisement, length 96 `....`:...........@...#*...................%@...............@.#*..........@.... ........*.. ..#*................*.. ..#*............. I also debugged a bit with systempad: probe kernel.statement("*@net/ipv6/exthdrs_core.c:200") { printf("Function call %s -> %s\n", thread_indent(1), ppfunc()); printf("%s\n", $$parms$); printf("%s\n",$$locals$$); printf("\nIP6->%s\n",$_ip6$$) } And the problem seems to be in the version field? IP6->{.priority=8, .version=4, .flow_lbl="9�?���F�r����� ", .payload_len=34832, .nexthdr='\377', .hop_limit='\377', .saddr={.in6_u={.u6_addr8="F�r����� ", .u6_addr16=[60998, ...], .u6_addr32=[2171792966, ...]}}, .daddr={.in6_u={.u6_addr8="#�q�����", .u6_addr16=[35619, ...], .u6_addr32=[2171702051, ...]}}} Regards, Andrés ProblemType: Bug DistroRelease: Ubuntu 16.04 Package: linux-image-4.4.0-62-generic 4.4.0-62.83 ProcVersionSignature: Ubuntu 4.4.0-62.83-generic 4.4.40 Uname: Linux 4.4.0-62-generic x86_64 AlsaDevices: total 0 crw-rw---- 1 root audio 116, 1 Jul 21 12:50 seq crw-rw---- 1 root audio 116, 33 Jul 21 12:50 timer AplayDevices: Error: [Errno 2] No such file or directory: 'aplay' ApportVersion: 2.20.1-0ubuntu2.9 Architecture: amd64 ArecordDevices: Error: [Errno 2] No such file or directory: 'arecord' AudioDevicesInUse: Error: command ['fuser', '-v', '/dev/snd/seq', '/dev/snd/timer'] failed with exit code 1: Date: Wed Aug 16 14:45:55 2017 HibernationDevice: RESUME=UUID=bc05b7d7-5163-44ea-8c18-89f5d02f272c InstallationDate: Installed on 2017-07-13 (34 days ago) InstallationMedia: Ubuntu-Server 16.04.2 LTS "Xenial Xerus" - Release amd64 (20170215.8) IwConfig: Error: [Errno 2] No such file or directory: 'iwconfig' JournalErrors: Error: command ['journalctl', '-b', '--priority=warning', '--lines=1000'] failed with exit code 1: Hint: You are currently not seeing messages from other users and the system. Users in the 'systemd-journal' group can see all messages. Pass -q to turn off this notice. No journal files were opened due to insufficient permissions. MachineType: FOXCONN CL7100 PciMultimedia: ProcEnviron: TERM=xterm-256color PATH=(custom, no user) XDG_RUNTIME_DIR=<set> LANG=es_ES.UTF-8 SHELL=/bin/bash ProcFB: 0 astdrmfb ProcKernelCmdLine: BOOT_IMAGE=/vmlinuz-4.4.0-62-generic root=UUID=545e3d8c-c105-4403-b599-c069ff58c690 ro RelatedPackageVersions: linux-restricted-modules-4.4.0-62-generic N/A linux-backports-modules-4.4.0-62-generic N/A linux-firmware 1.157.11 RfKill: Error: [Errno 2] No such file or directory: 'rfkill' SourcePackage: linux UpgradeStatus: No upgrade log present (probably fresh install) WifiSyslog: dmi.bios.date: 07/18/2016 dmi.bios.vendor: American Megatrends Inc. dmi.bios.version: HGP0104F dmi.board.asset.tag: NULL dmi.board.name: CL670R G3 6S dmi.board.vendor: FOXCONN dmi.board.version: 1A4258V00-600-G dmi.chassis.asset.tag: NULL dmi.chassis.type: 23 dmi.chassis.vendor: FOXCONN dmi.chassis.version: 1A42AV600-600-G dmi.modalias: dmi:bvnAmericanMegatrendsInc.:bvrHGP0104F:bd07/18/2016:svnFOXCONN:pnCL7100:pvrPVT1-X05:rvnFOXCONN:rnCL670RG36S:rvr1A4258V00-600-G:cvnFOXCONN:ct23:cvr1A42AV600-600-G: dmi.product.name: CL7100 dmi.product.version: PVT1-X05 dmi.sys.vendor: FOXCONN ** Affects: linux (Ubuntu) Importance: Undecided Status: Confirmed ** Tags: amd64 apport-bug xenial -- You received this bug notification because you are a member of Ubuntu Bugs, which is subscribed to Ubuntu. https://bugs.launchpad.net/bugs/1711124 Title: “IPV6 header not found” log with ICMPv6 with QinQ To manage notifications about this bug go to: https://bugs.launchpad.net/ubuntu/+source/linux/+bug/1711124/+subscriptions -- ubuntu-bugs mailing list ubuntu-bugs@lists.ubuntu.com https://lists.ubuntu.com/mailman/listinfo/ubuntu-bugs