This is a question about M_EXT mbuf reference counts in FreeBSD-stable.

There are several instances in kern/uipc_mbuf.c that add a reference
to an M_EXT mbuf by either incrementing the entry in the mclrefcnt[]
array or invoking the "custom" ext_ref routine.

However, it seems that these instances are all broken because they
don't wrap these operations within splimp()...

Isn't the following C statement *not* atomic?

        mclrefcnt[mtocl(m->m_ext.ext_buf)]++;

And isn't access to mclrefcnt[] supposed to be protected by splimp()?
Note: MCLFREE() *does* set splimp() before decrementing M_EXT ref counts.

Therefore, isn't there a race condition wrt. the M_EXT reference counts?

The functions which fail to set splimp() before adding a reference are:

        m_copym()
        m_copypacket()
        m_split()

Thanks for any comments/clarification on this subject..

-Archie

__________________________________________________________________________
Archie Cobbs     *     Packet Design     *     http://www.packetdesign.com

To Unsubscribe: send mail to [EMAIL PROTECTED]
with "unsubscribe freebsd-net" in the body of the message

Reply via email to