ip_output()/if_output() behaviour
    Michael Tuexen 
    Michael.Tuexen at lurchi.franken.de
       
    Fri Nov 29 13:11:27 UTC 2013
    
    
  
On Nov 29, 2013, at 12:44 PM, Julian Elischer <julian at freebsd.org> wrote:
> On 11/29/13, 5:42 PM, Michael Tuexen wrote:
>> On Nov 29, 2013, at 3:54 AM, Adrian Chadd <adrian at freebsd.org> wrote:
>> 
>>> On 28 November 2013 12:35, Michael Tuexen
>>> <Michael.Tuexen at lurchi.franken.de> wrote:
>>>> Dear all,
>>>> 
>>>> I'm investigating a problem and need to understand the behaviour
>>>> of ip_output(). Is it correct that if ip_output() returns an
>>>> non-zero error, the corresponding packet was never sent?
>>>> In the SCTP stack we assume this, but it seems that at least
>>>> the em and the igb driver might return an error from
>>>> igb_mq_start_locked(), for example, but have accepted the packet.
>>> Which error(s) ?
>> ENOBUFS, but does it matter? What is the correct reaction to
>> ip_output() returning an error? The SCTP stack assumes that the
>> packet was not put on the wire. With the current version of the
>> igb driver we are wrong. igb_mq_start() might return an error,
>> even if the packets was enqueued successfully (in case
>> igb_mq_start_locked() fails).
>> 
>> But the SCTP stacks assumes in general that if ip_output() returns
>> an error, the packet didn't make it out.
> From my memory it's always been the case that you really have little
> idea if the packet makes it out onto the wire or not.
> In the past it's been the case that an error indicates that it probably DIDN'T make it out, but
> the converse is not true.. NO error is not an indication of success.
I understand that if the call is successful, I don't know if it makes
it out. I'm only thinking about the case an error is indicated.
I have
* either remove the functionality from SCTP to take the return
  code of ip_output() into account.
* or fix the drivers to not return an error if the packet was
  queued.
I looked at the IP layer code and it seems that an error is only
indicated if the packet is dropped by the stack. So basically it
seems to be a question of if_output()...
> I'm surprised that you could get an error when it was broadcast however.. that is counter
> to the last 30 years of behaviour.
This sounds more like changing the driver... Do we have specified how
if_transmit() behaves?
Best regards
Michael
> 
> 
>> 
>> Best regards
>> Michael
>>>> Before digging further, I would like to know what the intended
>>>> behaviour of ip_output() is.
>>> 
>>> -adrian
>>> 
>> _______________________________________________
>> freebsd-net at freebsd.org mailing list
>> http://lists.freebsd.org/mailman/listinfo/freebsd-net
>> To unsubscribe, send any mail to "freebsd-net-unsubscribe at freebsd.org"
>> 
>> 
> 
> 
    
    
More information about the freebsd-net
mailing list