> On Tue, Oct 30, 2012 at 4:12 AM, David Laight <david.lai...@aculab.com> wrote: > >> Instead of masking head and tail every time we increment them, just let > >> them > >> wrap through UINT_MAX and mask them when subscripting. Add simple accessor > >> functions to do the subscripting properly to minimize the chances of > >> messing > >> this up. > > ... > >> +static unsigned int macb_tx_ring_avail(struct macb *bp) > >> +{ > >> + return TX_RING_SIZE - (bp->tx_head - bp->tx_tail); > >> +} > > > > That one doesn't look quite right to me. > > Surely it should be masking with 'TX_RING_SIZE - 1' > > Why is that? head and tail can never be more than TX_RING_SIZE apart, > so it shouldn't make any difference.
It's a ring buffer (I presume) the pointers can be in either order. David -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/