Hi! > >> drivers/net/ethernet/stmicro/stmmac/common.h > >> #define STMMAC_COAL_TX_TIMER 40000 > >> #define STMMAC_MAX_COAL_TX_TICK 100000 > >> #define STMMAC_TX_MAX_FRAMES 256 > >> > >> If I lower the parameters, delays are gone, but I get netdev watchdog > >> backtrace followed by broken driver. > >> > >> Any ideas what is going on there? > > > > 4.9-rc6 still has the delays. With the > > > > #define STMMAC_COAL_TX_TIMER 1000 > > #define STMMAC_TX_MAX_FRAMES 2 > > > > settings, delays go away, and driver still works. (It fails fairly > > fast in 4.4). Good news. But the question still is: what is going on > > there? > > 256 packets looks way too large for being a trigger for aborting the > TX coalescing timer. > > Looking more deeply into this, the driver is using non-highres timers > to implement the TX coalescing. This simply cannot work. > > 1 HZ, which is the lowest granularity of non-highres timers in the > kernel, is variable as well as already too large of a delay for > effective TX coalescing. > > I seriously think that the TX coalescing support should be ripped out > or disabled entirely until it is implemented properly in this > driver.
Hmm. I still don't understand how the coalescing is supposed to do any good in this driver. As long as transmits happen, it seems driver is not recycling used DMA descriptors. When the transmits stops, it waits for 40msec, then recycles them. We'll run out of DMA descriptors in 5msec at 100mbit speeds. Giuseppe Cavallaro, Alexandre Torgue: could you comment here? Can you apply the cleanup patches? The driver is marked as supported, but I see no reactions on email, and bugzilla is down :-(. Thanks, Pavel -- (english) http://www.livejournal.com/~pavelmachek (cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
signature.asc
Description: Digital signature