On Sat, Jan 19, 2008 at 07:27:38PM +0000, Byron Bradley wrote:
>               case IPPROTO_UDP:
>                       cmd_sts |= ETH_UDP_FRAME;
> -                     desc->l4i_chk = udp_hdr(skb)->check;
> +                     desc->l4i_chk = htons(udp_hdr(skb)->check);
>                       break;
>               case IPPROTO_TCP:
> -                     desc->l4i_chk = tcp_hdr(skb)->check;
> +                     desc->l4i_chk = htons(tcp_hdr(skb)->check);
>                       break;

The first part was OK, but this one...  AFAICS, the sucker byteswaps
64bit words in descriptors wholesale, right?  Then the right way to spell
that would be ntohs((__force __be16)....->check).

What's happening here is that we take a fixed-endian (checksum) and then
correct for conversion done in hardware - i.e. we store it in something
that expects a _host_-endian value and would convert that to fixed-endian.
So we need to counter that correction and that's where the damn thing is
coming from.

It's not particulary rare - drivers that do hardware byteswap tend to need
it.  For now I'd suggest explicit form (with force-cast from __csum to
__be16 and ntohs() on top of it); if anybody has good ideas for helper
names, though...  csum_as_le() and csum_as_be(), perhaps?  Interpret
__csum (fixed-endian) and another fixed-endian type, with proper checks;
i.e. something along the lines of
static inline __be16 csum_as_be(__csum sum)
{
        return (__force __be16)sum;
}
and this stuff becoming ntohs(csum_as_be(udp_hdr(skb)->check)), etc.
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to