What: Add an optimization for isend in pml/ob1. This optimization is a
companion to the optimizations recently committed to 1.8.1. The basic
idea is if the btl supports inline sends and the message is small
(currently hardcoded but planned to be configurable) then try to send it
with the inline send function. If this succeeds return
ompi_request_empty for the request. From what I can tell the only
requirement on a request returned by MPI_Isend is that the status
indicates whether the request was cancelled so this should be ok.
Why: This optimization should improve small message rates when the btl
provides an inline send function. This commit may or may not help
application performance but it certainly gives better results with
osu_bibw and osu_mbw_mr.
When: This is targeted for 1.8.1 so I would like this to soak on the
trunk for a little while before being moved over. As I said, it is
conceptually the same as the other ob1 optimization. Setting the timeout
for two weeks (April 29).
The patch is attached. It has been tested with btl/ugni and btl/vader
and I have seen a 10-30% improvement in the small message rate.
- application/pgp-signature attachment: stored