On Tue, 30 Mar 2010 14:49:57 +0800 christian pellegrin <chripell@xxxxxxxx> wrote: > On Tue, Mar 30, 2010 at 4:14 AM, Feng Tang <feng.tang@xxxxxxxxx> > wrote: > > On Mon, 29 Mar 2010 20:55:51 +0800 > > > > When the HW works at 230400 bps, when we copy bulk data to the > > console, max3110 will probably receive about 20K characters, so the > > time for handling each char is 50us. If you use one char per spi > > transfer, it will have to execute 20K spi_transfer in one second, > > and each need be done in 50us, in this 50us you'll have to deal > > with controller IRQ handler + spi system overhead + tty receiving > > overhead. Is it a little over-killing to use one char per spi > > transfer? while the HW does have a 8 words RX FIFO > > this is too hackish, max3100 wasn't conceived this way. Let me point > some problems of such an approach: > > 1) latency on rx chars becomes very high because we can process > incoming transfers only after a full 8 byte (or whatever the spi > transfer dimension is). For a 9600 this is too much. > > 2) even worse is that we can do flow control decision only on such > boundary. > > 3) this is not reliable: think of what happens if the actual SPI > transfer speed we get will be slower that the one we requested. We > won't be emptying the RX buffer fastly enough even if could. > > 4) for low speeds we are going to monopolize the SPI bus for ages. No words in my last email suggested to use dynamic SPI clock speed, I admited that method is brutal and not mature when my driver was reviewed. In early version of our 3110 driver, we don't use dynamic clock speed, but the maxim clock supports by 3110, while we still use 8 words buffer read for RX. Let me cut my question clear: why not use the 8 words RX HW fifo? For bulk RX in 230400 case, is 50us enough to handle controller IRQ + spi subsystem overhead + tty receive overhead for one char per spi transfer model? > > So I'm rather convinced that the SPI transfer has to happen as soon as > possible at a SPI device driver level without any guess on how the > data will be clocked out. I suggest you to improve the dw_spi driver > for better performance. Will consider that, thanks > > > [[ ..000000 iiuu eessoo ....44rr11((eeggffnn--77 > > ggccvvrriinn444411((bbnnuu44441144bbnnuu)))) [[ ..000000 > > BBOO--8800 0000000000001100--0000000000008800 uuaall)) > > huh, here I'm seeing another kind of problem: the same char is > repeated two times (for example BBOO is written instead of BIOS). I'm > quite sure (but I will triple check shortly) the the console driver > doesn't do this (it's quite an easy loop in max3100_console_work, I > will check wit a printascii to another serial port what is sent). So I > guess the problem can be in the SPI master driver: is it correctly > handling the CS changes? Isn't it having problems with DMA for example > (I always found DMA for small data transfer (such 2 bytes in this > case) problematic (for example many platforms just do it on a 4 byte > boundary))? Have you tested it with other devices? > Yes, the controller HW has a register to chose slave devices and thus the HW CS handling is transparent to software. The controller supports several slave devices connecting to it simultaneously, one is a 3G modem whose throughput is about several Mega bits. The current in-tree controller driver lacks DMA part, which is rejected as the related DMA controller driver never show up publicly. -- To unsubscribe from this list: send the line "unsubscribe linux-serial" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html