>-----Original Message-----
>From: Daniele Di Proietto [mailto:diproiet...@ovn.org]
>Sent: Tuesday, October 18, 2016 4:07 AM
>To: Bodireddy, Bhanuprakash <bhanuprakash.bodire...@intel.com>
>Cc: dev@openvswitch.org
>Subject: Re: [ovs-dev] [PATCH v3 06/12] cmap: Remove prefetching in
>2016-10-14 7:37 GMT-07:00 Bhanuprakash Bodireddy
>prefetching the data in to the caches isn't improving the performance in
>cmap_find_batch(). Moreover its found that there is slight improvement
>in performance with out prefetching.
>This patch removes prefetching from cmap_find_batch().
>Signed-off-by: Bhanuprakash Bodireddy
>Co-authored-by: Antonio Fischetti <antonio.fische...@intel.com>
>Signed-off-by: Antonio Fischetti <antonio.fische...@intel.com>
>I tested this patch in isolation and on my system I didn't notice any
>improvements for a single flow (with EMC disabled), I noticed a slight drop
>instead with 128 flows in the classifier.
>Probably this is due to the fact that I didn't apply yet the first patch of the
>series (the one that increases the batch to 32), so I guess I'll defer this 
>until we can apply the rest of the series.
>Also, if you guys see an improvement (and since you got some evidence with
>VTune), I don't think it matters that on one particular system (mine) I can't 
>any benefit.
I am testing this on haswell and VTune confirmed our observation. Also 
Is done at 4 places in cmap_find_batch() and at two places the prefetching is 
done just before
the data is accessed.  
As prefetch instruction has some overhead, prefetching should be done well 
in advance to have performance gains. Also prefetching too earlier can has 
negative effect
as the prefetched data can be flushed by other access.  We played around a bit 
and found
removing the prefetching doesn't impact the performance and hence submitted 
this patch.

Bhanu Prakash. 


dev mailing list

Reply via email to