Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 13 Nov 2009 11:40:44 -0800
From:      Chuck Swiger <cswiger@mac.com>
To:        Ben Kelly <ben@wanderview.com>
Cc:        current@freebsd.org
Subject:   Re: dummynet log messages after recent update
Message-ID:  <D891A9BD-B906-4DED-AF4C-DE08E62E8CC6@mac.com>
In-Reply-To: <75C5C3A9-E8B7-4EBB-8731-603981BADD97@wanderview.com>
References:  <75C5C3A9-E8B7-4EBB-8731-603981BADD97@wanderview.com>

next in thread | previous in thread | raw e-mail | index | archive | help
Hi, Ben--

On Nov 13, 2009, at 10:43 AM, Ben Kelly wrote:
> I recently upgraded my firewall from a soekris net4501 to a  
> net5501.  As part of this process I update my freebsd sources to  
> CURRENT as of 11/13/2009 1300 GMT.  Once the new box was up and  
> running I noticed some odd output in the logs:
>
>  Nov 13 18:30:19 gate kernel: dummynet: OUCH! pipe should have been  
> idle!
>  Nov 13 18:30:34 gate last message repeated 15 times

The message is coming from netinet/ip_dummynet.c:

                 /*
                  * Look at eligibility. A flow is not eligibile if  
S>V (when
                  * this happens, it means that there is some other  
flow already
                  * scheduled for the same pipe, so the scheduler_heap  
cannot be
                  * empty). If the flow is not eligible we just store  
it in the
                  * not_eligible_heap. Otherwise, we store in the  
scheduler_heap
                  * and possibly invoke ready_event_wfq() right now if  
there is
                  * leftover credit.
                  * Note that for all flows in scheduler_heap (SCH),  
S_i <= V,
                  * and for all flows in not_eligible_heap (NEH), S_i  
 > V.
                  * So when we need to compute max(V, min(S_i)) forall  
i in
                  * SCH+NEH, we only need to look into NEH.
                  */
                 if (DN_KEY_GT(q->S, pipe->V)) {         /* Not  
eligible. */
                         if (pipe->scheduler_heap.elements == 0)
                                 printf("dummynet: ++ ouch! not  
eligible but empty scheduler!\n");
                         heap_insert(&(pipe->not_eligible_heap), q->S,  
q);
                 } else {
                         heap_insert(&(pipe->scheduler_heap), q->F, q);
                         if (pipe->numbytes >= 0) {       /* Pipe is  
idle. */
                                 if (pipe->scheduler_heap.elements != 1)
                                         printf("dummynet: OUCH! pipe  
should have been idle!\n");
                                 DPRINTF(("dummynet: waking up pipe %d  
at %d\n",
                                     pipe->pipe_nr, (int)(q->F >>  
MY_M)));
                                 pipe->sched_time = curr_time;
                                 ready_event_wfq(pipe, &head, &tail);
                         }
                 }

I'm not entirely sure of logic in the /* Pipe is idle. */ test is  
right-- if pipe->numbytes == 0, I'd agree the pipe is idle, but if you  
have some bytes of traffic in the pipe, the the assumption that the  
current packet is the only traffic doesn't seem to make sense.  But,  
I'm not the author of the code....  :-)

Regards,
-- 
-Chuck




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?D891A9BD-B906-4DED-AF4C-DE08E62E8CC6>