mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-15 15:06:42 +00:00
Add a new, better mechanism for sticking packets onto ifqueues.
The old system had the misfeature that the only policy it could implement was tail-drop; the new IF_ENQ_DROP macro/function makes it possible to implement more sophisticated queueing policies on a system-wide basis. No code actually uses this yet (although on my machine I have converted the ethernet and (polled) loopback to use it).
This commit is contained in:
parent
c6a977a04d
commit
6f86639187
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=17247
31
sys/net/if.h
31
sys/net/if.h
@ -31,7 +31,7 @@
|
||||
* SUCH DAMAGE.
|
||||
*
|
||||
* @(#)if.h 8.1 (Berkeley) 6/10/93
|
||||
* $Id: if.h,v 1.28 1996/02/06 18:51:10 wollman Exp $
|
||||
* $Id: if.h,v 1.29 1996/06/10 23:07:28 gpalmer Exp $
|
||||
*/
|
||||
|
||||
#ifndef _NET_IF_H_
|
||||
@ -252,6 +252,35 @@ struct ifnet {
|
||||
} \
|
||||
}
|
||||
|
||||
#ifdef KERNEL
|
||||
#define IF_ENQ_DROP(ifq, m) if_enq_drop(ifq, m)
|
||||
|
||||
#if defined(__GNUC__) && defined(MT_HEADER)
|
||||
static inline int
|
||||
if_queue_drop(struct ifqueue *ifq, struct mbuf *m)
|
||||
{
|
||||
IF_QDROP(ifq);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static inline int
|
||||
if_enq_drop(struct ifqueue *ifq, struct mbuf *m)
|
||||
{
|
||||
if (IF_QFULL(ifq) &&
|
||||
!if_queue_drop(ifq, m))
|
||||
return 0;
|
||||
IF_ENQUEUE(ifq, m);
|
||||
return 1;
|
||||
}
|
||||
#else
|
||||
|
||||
#ifdef MT_HEADER
|
||||
int if_enq_drop __P((struct ifqueue *, struct mbuf *));
|
||||
#endif
|
||||
|
||||
#endif
|
||||
#endif /* KERNEL */
|
||||
|
||||
#define IFQ_MAXLEN 50
|
||||
#define IFNET_SLOWHZ 1 /* granularity is 1 second */
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user