Hi Russell, I'm working on the port of the USB-Serial layer to the Serial Core [1], and turns out that most of the USB-Serial drivers does need to sleep in set_termios(), break_ctl(), get_mctrl() and set_mctrl() calls (which are not allowed to sleep according to the documentation).
I took a look in the Serial Core code and didn't see why set_termios() and break_ctl() (plus tx_empty()) are not allowed to sleep: they doesn't seem to run in atomic context. So, are they allowed to sleep? Isn't the documentation out of date? I've even submitted a patch to fix it [2]. For get_mctrl() and set_mctrl() it seems possible to switch from a spinlock to a mutex, as they are not called from an interrupt context. Is this really possible? Would you agree with this change? Please, note that your opnion is very important. Both issues makes the port not possible. Thanks. [1] http://distro2.conectiva.com.br/~lcapitulino/patches/usbserial/2.6.17-rc5/serialcore-port-V0/ [2] http://marc.theaimsgroup.com/?l=linux-kernel&m=114979748706523&w=2 -- Luiz Fernando N. Capitulino _______________________________________________ linux-usb-devel@lists.sourceforge.net To unsubscribe, use the last form field at: https://lists.sourceforge.net/lists/listinfo/linux-usb-devel