I set the MTU on my ADSL router to 1488 bytes, as this is exactly the payload of 31 ATM cells (48 bytes each). This is the most efficient MTU for ADSL connections that utilise ATM, it would seem. PPPoA with VC/MUX is one of the more common configurations in the UK. This adds a 2 byte header and an 8 byte trailer to the data, leaving 1478 bytes left for the packet headers and payload.
The IPv6 tunnel transports IPv6 packets encapsulated in IPv4. IPv4 IP headers are 20 bytes. The maximum MTU for IPv6 packets is therefore 1478 - 20 bytes, i.e. 1458 bytes.
Hurricane Electric allow some configuration of tunnel MTU on their website, but not an MTU that is exactly 1458 bytes, unfortunately. The nearest is 1452 bytes. After configuring the MTU at both ends and checking with ping6 that the path MTU discovery was correctly reporting the 1452 byte MTU, I was happy that all was working as it should.
I started to notice that YouTube videos would no longer buffer correctly shortly after this. The video would play for a few seconds and then wait while buffering for about 30 seconds to play a few more seconds. At first I put it down to a glitch. As time went on I realised that YouTube over IPv4 was fine, but not over IPv6. YouTube's website is IPv4 only, but the video streams from their CDN come from servers that are dual stack enabled.
I checked and rechecked my IPv6 tunnel using ping6 and http://test-ipv6.com/ to make sure it was working correctly. As far as I can tell, it is.
It seems (to me) that YouTube's CDN servers aren't doing path MTU discovery correctly, or at least, path MTU discovery is failing to work, possibly because ICMPv6 is blocked somewhere in the network path.
A Google search reveals a number of people experiencing this buffering issue when connected to an IPv6 enabled network. Very few posts give any clear information on how it might be fixed. The closest they seem to get to a fix is mention of changing MTU value.
I have managed to fix the buffering issue now, I hope! The answer is to use TCP MSS clamping.
All traffic on my home network passes through my Linux router, which does NAT for IPv4 traffic and pass-through for IPv6 traffic. Adding the following to the firewall rules seems to fix the YouTube buffering issue:
ip6tables -A FORWARD -p tcp -t mangle --tcp-flags SYN,RST SYN \
-j TCPMSS --set-mss 1392
This causes the MSS (Maximum Segment Size) for TCP connections to be fixed at 1392 bytes. This is the TCP payload value and is calculated by subtracting the header length of 60 bytes from the MTU, i.e. 1452 - 60 bytes.
It's unfortunate that this has to be done, but on the plus side, it will fix path MTU discovery issues for other sites as well as YouTube.