added m_cljget() with support for jumbo9 size: it should help with broadcom570x
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@28603 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
11d2eeb7eb
commit
1dc9113089
@ -78,10 +78,14 @@ struct mbuf {
|
||||
|
||||
#define EXT_CLUSTER 1
|
||||
#define EXT_PACKET 3
|
||||
#define EXT_JUMBO9 4
|
||||
#define EXT_NET_DRV 100
|
||||
|
||||
#define M_BCAST 0x00000200
|
||||
#define M_MCAST 0x00000400
|
||||
#define M_FRAG 0x00000800
|
||||
#define M_FIRSTFRAG 0x00001000
|
||||
#define M_LASTFRAG 0x00002000
|
||||
#define M_VLANTAG 0x00010000
|
||||
|
||||
#define CSUM_IP 0x0001
|
||||
@ -125,6 +129,7 @@ void m_copyback(struct mbuf *, int, int, caddr_t);
|
||||
struct mbuf *m_get(int how, short type);
|
||||
struct mbuf *m_gethdr(int how, short type);
|
||||
void m_clget(struct mbuf *m, int how);
|
||||
void *m_cljget(struct mbuf *m, int how, int size);
|
||||
|
||||
void m_extadd(struct mbuf *m, caddr_t buffer, u_int size,
|
||||
void (*freeHook)(void *, void *), void *args, int flags, int type);
|
||||
|
@ -21,6 +21,7 @@
|
||||
|
||||
static object_cache *sMBufCache;
|
||||
static object_cache *sChunkCache;
|
||||
static object_cache *sJumbo9ChunkCache;
|
||||
|
||||
int max_linkhdr = 16;
|
||||
int max_protohdr = 40 + 20; /* ip6 + tcp */
|
||||
@ -60,9 +61,21 @@ construct_mbuf(struct mbuf *mb, short type, int flags)
|
||||
|
||||
|
||||
static int
|
||||
construct_ext_mbuf(struct mbuf *mb, int how)
|
||||
construct_ext_sized_mbuf(struct mbuf *mb, int how, int size)
|
||||
{
|
||||
mb->m_ext.ext_buf = object_cache_alloc(sChunkCache, m_to_oc_flags(how));
|
||||
object_cache *cache;
|
||||
int ext_type;
|
||||
if (size != MCLBYTES && size != MJUM9BYTES)
|
||||
panic("unsupported size");
|
||||
|
||||
if (size == MCLBYTES) {
|
||||
cache = sChunkCache;
|
||||
ext_type = EXT_CLUSTER;
|
||||
} else {
|
||||
cache = sJumbo9ChunkCache;
|
||||
ext_type = EXT_JUMBO9;
|
||||
}
|
||||
mb->m_ext.ext_buf = object_cache_alloc(cache, m_to_oc_flags(how));
|
||||
if (mb->m_ext.ext_buf == NULL)
|
||||
return B_NO_MEMORY;
|
||||
|
||||
@ -70,21 +83,28 @@ construct_ext_mbuf(struct mbuf *mb, int how)
|
||||
mb->m_flags |= M_EXT;
|
||||
/* mb->m_ext.ext_free = NULL; */
|
||||
/* mb->m_ext.ext_args = NULL; */
|
||||
mb->m_ext.ext_size = MCLBYTES;
|
||||
mb->m_ext.ext_type = EXT_CLUSTER;
|
||||
mb->m_ext.ext_size = size;
|
||||
mb->m_ext.ext_type = ext_type;
|
||||
/* mb->m_ext.ref_cnt = NULL; */
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
static inline int
|
||||
construct_ext_mbuf(struct mbuf *mb, int how)
|
||||
{
|
||||
return construct_ext_sized_mbuf(mb, how, MCLBYTES);
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
construct_pkt_mbuf(int how, struct mbuf *mb, short type, int flags)
|
||||
{
|
||||
construct_mbuf(mb, type, flags);
|
||||
if (construct_ext_mbuf(mb, how) < 0)
|
||||
return -1;
|
||||
mb->m_ext.ext_type = EXT_PACKET;
|
||||
mb->m_ext.ext_type |= EXT_PACKET;
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -92,7 +112,14 @@ construct_pkt_mbuf(int how, struct mbuf *mb, short type, int flags)
|
||||
static void
|
||||
destruct_pkt_mbuf(struct mbuf *mb)
|
||||
{
|
||||
object_cache_free(sChunkCache, mb->m_ext.ext_buf);
|
||||
object_cache *cache;
|
||||
if (mb->m_ext.ext_type & EXT_CLUSTER)
|
||||
cache = sChunkCache;
|
||||
else if (mb->m_ext.ext_type & EXT_JUMBO9)
|
||||
cache = sJumbo9ChunkCache;
|
||||
else
|
||||
panic("unknown cache");
|
||||
object_cache_free(cache, mb->m_ext.ext_buf);
|
||||
mb->m_ext.ext_buf = NULL;
|
||||
}
|
||||
|
||||
@ -151,6 +178,18 @@ m_clget(struct mbuf *m, int how)
|
||||
}
|
||||
|
||||
|
||||
void *
|
||||
m_cljget(struct mbuf *m, int how, int size)
|
||||
{
|
||||
if (m == NULL)
|
||||
panic("m_cljget doesn't support allocate mbuf");
|
||||
m->m_ext.ext_buf = NULL;
|
||||
construct_ext_sized_mbuf(m, how, size);
|
||||
/* shouldn't be used */
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
m_freem(struct mbuf *mb)
|
||||
{
|
||||
@ -172,6 +211,9 @@ mb_free_ext(struct mbuf *m)
|
||||
else if (m->m_ext.ext_type == EXT_CLUSTER) {
|
||||
object_cache_free(sChunkCache, m->m_ext.ext_buf);
|
||||
m->m_ext.ext_buf = NULL;
|
||||
} else if (m->m_ext.ext_type == EXT_JUMBO9) {
|
||||
object_cache_free(sJumbo9ChunkCache, m->m_ext.ext_buf);
|
||||
m->m_ext.ext_buf = NULL;
|
||||
} else
|
||||
panic("unknown type");
|
||||
|
||||
@ -207,23 +249,31 @@ init_mbufs()
|
||||
{
|
||||
sMBufCache = create_object_cache("mbufs", MSIZE, 8, NULL, NULL, NULL);
|
||||
if (sMBufCache == NULL)
|
||||
return B_NO_MEMORY;
|
||||
|
||||
goto clean;
|
||||
sChunkCache = create_object_cache("mbuf chunks", MCLBYTES, 0, NULL, NULL,
|
||||
NULL);
|
||||
if (sChunkCache == NULL) {
|
||||
if (sChunkCache == NULL)
|
||||
goto clean;
|
||||
sJumbo9ChunkCache = create_object_cache("mbuf jumbo9 chunks", MJUM9BYTES, 0, NULL, NULL,
|
||||
NULL);
|
||||
if (sJumbo9ChunkCache == NULL)
|
||||
goto clean;
|
||||
return B_OK;
|
||||
|
||||
clean:
|
||||
if (sChunkCache != NULL)
|
||||
delete_object_cache(sChunkCache);
|
||||
if (sMBufCache != NULL)
|
||||
delete_object_cache(sMBufCache);
|
||||
return B_NO_MEMORY;
|
||||
}
|
||||
|
||||
return B_OK;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
uninit_mbufs()
|
||||
{
|
||||
delete_object_cache(sMBufCache);
|
||||
delete_object_cache(sChunkCache);
|
||||
delete_object_cache(sJumbo9ChunkCache);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user