On Wed, Mar 02, 2022 at 11:56:00AM +0200, Ilpo Järvinen wrote: > +static int dw8250_rs485_config(struct uart_port *p, struct serial_rs485 *rs485) > +{ > + u32 tcr; > + > + tcr = dw8250_readl_ext(p, DW_UART_TCR); > + tcr &= ~DW_UART_TCR_XFER_MODE; > + > + if (rs485->flags & SER_RS485_ENABLED) { > + /* Clearing unsupported flags. */ Nit: Usually we use imperative mood, i.e. "/* clear unsupported flags */". > + rs485->flags &= SER_RS485_ENABLED; > + > + tcr |= DW_UART_TCR_RS485_EN | DW_UART_TCR_XFER_MODE_DE_OR_RE; > + dw8250_writel_ext(p, DW_UART_DE_EN, 1); > + dw8250_writel_ext(p, DW_UART_RE_EN, 1); > + } else { > + rs485->flags = 0; > + > + tcr &= ~DW_UART_TCR_RS485_EN; > + dw8250_writel_ext(p, DW_UART_DE_EN, 0); > + dw8250_writel_ext(p, DW_UART_RE_EN, 0); Do the DW_UART_DE_EN and DW_UART_RE_EN registers have any effect at all if DW_UART_TCR_RS485_EN is disabled in the TCR register? If they don't, there's no need to clear them here. It would be sufficient to set them once (e.g. on probe). > + /* Resetting the default DE_POL & RE_POL */ > + tcr &= ~(DW_UART_TCR_DE_POL | DW_UART_TCR_RE_POL); Nit: Imperative mood, i.e. "/* reset to default polarity */" > + if (device_property_read_bool(p->dev, "snps,de-active-high")) > + tcr |= DW_UART_TCR_DE_POL; That device property is a duplication of the existing "rs485-rts-active-low" property. Please use the existing one unless there are devices already in the field which use the new property (in which case that should be provided as justification in the commit message). Does the DesignWare UART use dedicated DE and RE pins instead of the RTS pin? That would be quite unusual. > + if (device_property_read_bool(p->dev, "snps,re-active-high")) > + tcr |= DW_UART_TCR_RE_POL; Heiko Stübner (+cc) posted patches in 2020 to support a separate RE pin in addition to a DE pin (which is usually simply the RTS pin): https://lore.kernel.org/linux-serial/20200517215610.2131618-4-heiko@xxxxxxxxx/ He called the devicetree property for the pin "rs485-rx-enable", so perhaps "rs485-rx-active-low" would be a better name here. > + /* > + * XXX: Though we could interpret the "RTS" timings as Driver Enable > + * (DE) assertion/de-assertion timings, initially not supporting that. > + * Ideally we should have timing values for the Driver instead of the > + * RTS signal. > + */ > + rs485->delay_rts_before_send = 0; > + rs485->delay_rts_after_send = 0; I don't quite understand this code comment. > void dw8250_setup_port(struct uart_port *p) > { > + struct dw8250_port_data *d = p->private_data; > struct uart_8250_port *up = up_to_u8250p(p); > u32 reg; > > + d->hw_rs485_support = device_property_read_bool(p->dev, "snps,rs485-interface-en"); > + if (d->hw_rs485_support) > + p->rs485_config = dw8250_rs485_config; > + You wrote in the commit message that rs485 support is present from version 4.0 onward. Can't we just check the IP version and enable rs485 support for >= 4.0? That would seem more appropriate instead of introducing yet another new property. Note that dw8250_setup_port() already reads the version from the DW_UART_UCV register. Thanks, Lukas