diff options
author | bmilekic <bmilekic@FreeBSD.org> | 2000-12-21 21:44:31 +0000 |
---|---|---|
committer | bmilekic <bmilekic@FreeBSD.org> | 2000-12-21 21:44:31 +0000 |
commit | 4b6a7bddad70a11b35893cc1825a768e53fb28c7 (patch) | |
tree | cb3615d12a5b91954bedb7d2b4481c994b02b3d6 /sys/netncp | |
parent | 37eea88efd33920c8d4ef7e41923db5d5eec76cf (diff) | |
download | FreeBSD-src-4b6a7bddad70a11b35893cc1825a768e53fb28c7.zip FreeBSD-src-4b6a7bddad70a11b35893cc1825a768e53fb28c7.tar.gz |
* Rename M_WAIT mbuf subsystem flag to M_TRYWAIT.
This is because calls with M_WAIT (now M_TRYWAIT) may not wait
forever when nothing is available for allocation, and may end up
returning NULL. Hopefully we now communicate more of the right thing
to developers and make it very clear that it's necessary to check whether
calls with M_(TRY)WAIT also resulted in a failed allocation.
M_TRYWAIT basically means "try harder, block if necessary, but don't
necessarily wait forever." The time spent blocking is tunable with
the kern.ipc.mbuf_wait sysctl.
M_WAIT is now deprecated but still defined for the next little while.
* Fix a typo in a comment in mbuf.h
* Fix some code that was actually passing the mbuf subsystem's M_WAIT to
malloc(). Made it pass M_WAITOK instead. If we were ever to redefine the
value of the M_WAIT flag, this could have became a big problem.
Diffstat (limited to 'sys/netncp')
-rw-r--r-- | sys/netncp/ncp_rq.c | 16 | ||||
-rw-r--r-- | sys/netncp/ncp_sock.c | 2 |
2 files changed, 9 insertions, 9 deletions
diff --git a/sys/netncp/ncp_rq.c b/sys/netncp/ncp_rq.c index 8cef7d2..e661f5e 100644 --- a/sys/netncp/ncp_rq.c +++ b/sys/netncp/ncp_rq.c @@ -60,9 +60,9 @@ ncp_rq_head(struct ncp_rq *rqp, u_int32_t ptype, u_int8_t fn,struct proc *p, bzero(rqp, sizeof(*rqp)); rqp->p = p; rqp->cred = cred; - m = m_gethdr(M_WAIT, MT_DATA); + m = m_gethdr(M_TRYWAIT, MT_DATA); if (m == NULL) - return ENOBUFS; /* if M_WAIT ? */ + return ENOBUFS; /* if M_TRYWAIT ? */ m->m_pkthdr.rcvif = NULL; rqp->rq = rqp->mrq = m; rqp->rp = NULL; @@ -106,9 +106,9 @@ m_getm(struct mbuf *top, int len) { mp = top; while (rest > 0) { /* NCPSDEBUG("%d\n",rest);*/ - m = m_get(M_WAIT, MT_DATA); + m = m_get(M_TRYWAIT, MT_DATA); if (rest > MINCLSIZE) { - MCLGET(m,M_WAIT); + MCLGET(m,M_TRYWAIT); mlen = ( (m->m_flags & M_EXT) == 0) ? MLEN : MCLBYTES; } else { mlen = MLEN; @@ -135,7 +135,7 @@ ncp_mchecksize(struct ncp_rq *rqp, int size) { panic("ncp_mchecksize\n"); if (M_TRAILINGSPACE(rqp->mrq)<(size)) { struct mbuf *m; - m = m_get(M_WAIT, MT_DATA); + m = m_get(M_TRYWAIT, MT_DATA); m->m_len = 0; rqp->bpos = mtod(m, caddr_t); rqp->mrq->m_next = m; @@ -435,7 +435,7 @@ ncp_rp_mbuf(struct ncp_rq *rqp, int size) { register struct mbuf *m=rqp->mrp, *rm; register unsigned count; - rm = m_copym(m, rqp->bpos - mtod(m,caddr_t), size, M_WAIT); + rm = m_copym(m, rqp->bpos - mtod(m,caddr_t), size, M_TRYWAIT); while (size > 0) { if (m == 0) { printf("ncp_rp_mbuf: can't advance\n"); @@ -555,9 +555,9 @@ nwfs_uiotombuf(uiop, mq, siz, bpos) while (left > 0) { mlen = M_TRAILINGSPACE(mp); if (mlen == 0) { - MGET(mp, M_WAIT, MT_DATA); + MGET(mp, M_TRYWAIT, MT_DATA); if (clflg) - MCLGET(mp, M_WAIT); + MCLGET(mp, M_TRYWAIT); mp->m_len = 0; mp2->m_next = mp; mp2 = mp; diff --git a/sys/netncp/ncp_sock.c b/sys/netncp/ncp_sock.c index 238f0ae..206c341 100644 --- a/sys/netncp/ncp_sock.c +++ b/sys/netncp/ncp_sock.c @@ -171,7 +171,7 @@ ncp_sock_send(struct socket *so, struct mbuf *top, struct ncp_rq *rqp) int sendwait; for(;;) { - m = m_copym(top, 0, M_COPYALL, M_WAIT); + m = m_copym(top, 0, M_COPYALL, M_TRYWAIT); /* NCPDDEBUG(m);*/ error = so->so_proto->pr_usrreqs->pru_sosend(so, to, 0, m, 0, flags, p); if (error == 0 || error == EINTR || error == ENETDOWN) |