After some debugging and browsing the source code of racoon I found that my
racoon was configured in such a way that racoon would report to the kernel
that it was using non-IKE markers even though non-IKE markers were not being
used. This happened when in racoon.conf I had something like:
listen
{
     isakmp 192.168.xxx.xxx[500];
     isakmp 192.168.xxx.xxx[4500];
}
Instead of this:
listen
{
     isakmp 192.168.xxx.xxx[500];
     isakmp_natt 192.168.xxx.xxx[4500];
}
According to the racoon.conf man page, a socket will accept UDP-encapsulated
ESP traffic for NAT-Traversal when using the isakmp_natt statement in the
listen directive, but not when using the isakmp statement. In fact, however,
I discovered that NetBSD's racoon (NetBSD 7.x) will accept UDP-encapsulated
traffic even with the isakmp statement for port 4500, but it will report to
the kernel that it is using non-IKE markers when, as far as I can tell, it
actually is not using non-IKE markers. I observed this behavior for all
L2TP/IPSEC clients I tested, including Windows, iPhone, and netbsd/racoon.
When using the isakmp_natt statement for port 4500 in the listen directive,
racoon works as expected and does not report using non-IKE markers and
everything works as expected for RFC 3947/3948, for all clients I tested,
including Windows, iPhone, and a netbsd/racoon client.
The bottom line: I think if we remove UDP_ENCAP_ESPINUDP_NON_IKE option from
the kernel, also remove it from racoon.
Chuck Zmudzinski