Doug Anderson wrote at Tuesday, October 11, 2011 6:06 PM: > On Tegra UARTs (except UART1), the DTR / DCD / DSR lines are not > externally accessible. Instead, the DTR line internally appears to be > looped back to be the input to the DCD and DSR lines. The net effect > of this is that when we drop DTR (like when we suspend), we'll see DCD > drop too. ...and when we see DCD drop, we treat that as a hangup. > > In order to prevent this hangup from occurring at every sleep, we need > to force DTR to remain high on Tegra UARTs. > > This patch uses the mcr_mask / mcr_force fields, which were originally > added for the kludge ALPHA_KLUDGE_MCR. Using these fields does not > prevent us from removing ALPHA_KLUDGE_MCR--we can just remove the "if" > tests I have added and always init mcr_mask / mcr_force from the > serial8250_config. > > NOTE: If we have people that are using UARTA on a Tegra and need to > control DTR, we'll need to either add a separate port type for UARTA > or we'll need to add some tegra-specific code to detect whether the > DTR needs to be left high. I did some research on the HW, and here's how everything is hooked up in Tegra20 and Tegra30. Later chips may have this fixed, or at least configurable; I don't know the details yet. All 5 UARTs support the modem signals in the HW block. In UART A, you can mux the modem signals out using the pinmux. If the pinmux /doesn't/ route the signals out, the DSR and DCD signals are tied to an /active/ state. In UART B, the DTR output is indeed wired back into the DSR and DCD inputs, as you discovered. In UARTs C, D, and E, the DSR and DCD signals are tied to an /inactive/ state. So, I think this particular WAR is only needed on UART B. -- nvpublic -- 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