[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20110902153147.GB29025@philter>
Date: Fri, 2 Sep 2011 17:31:47 +0200
From: Phil Sutter <phil.sutter@...rinet.com>
To: chetan loke <loke.chetan@...il.com>
Cc: linux-arm-kernel@...ts.infradead.org, netdev@...r.kernel.org,
linux@....linux.org.uk, davem@...emloft.net
Subject: Re: FW: [PATCH] af_packet: flush complete kernel cache in
packet_sendmsg
On Fri, Sep 02, 2011 at 10:00:16AM -0400, chetan loke wrote:
> >
> > This flushes the cache before and after accessing the mmapped packet
> > buffer. It seems like the call to flush_dcache_page from inside
> > __packet_get_status is not enough on Kirkwood (or ARM in general).
>
>
>
> > + kw_extra_cache_flush();
> > + rc = po->tx_ring.pg_vec ? tpacket_snd(po, msg) :
> > + packet_snd(sock, msg, len);
> > + kw_extra_cache_flush();
> > + return rc;
> > }
>
> If a workaround is needed for mmap, then why not change tpacket_snd?
I did not verify that packet_snd() is not affected. OTOH, adding it
there was quite "intuitive".
> Also, is this workaround actually working for all the cases? Because
> packet_get_status is not being touched in your patch.
>
> Also, I don't see any changes for the Rx-path. Is that working ok?
So far we haven't noticed problems in that direction. I just tried some
explicit test: having tcpdump print local timestamps (not the pcap-ones)
on every received packet, activating icmp_echo_ignore_all and pinging
the host on a dedicated line. I expected to sometimes see a second
difference between the two timestamps, as like with sending from time to
time a packet should get "lost" in the cache, and then occur to
userspace after the next one arrived. Maybe my test is broken, or RX is
indeed unaffected.
Greetings and thanks for the hints, Phil
--
Viprinet GmbH
Mainzer Str. 43
55411 Bingen am Rhein
Germany
Zentrale: +49-6721-49030-0
Durchwahl: +49-6721-49030-134
Fax: +49-6721-49030-209
phil.sutter@...rinet.com
http://www.viprinet.com
Sitz der Gesellschaft: Bingen am Rhein
Handelsregister: Amtsgericht Mainz HRB40380
Geschäftsführer: Simon Kissel
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists