mfd: rave-sp: Initialize flow control and parity of the port
authorAndrey Smirnov <andrew.smirnov@gmail.com>
Sat, 7 Jul 2018 02:41:05 +0000 (19:41 -0700)
committerLee Jones <lee.jones@linaro.org>
Fri, 27 Jul 2018 07:13:25 +0000 (08:13 +0100)
Relying on serial port defaults for flow control and parity can result
in complete breakdown of communication with RAVE SP on some platforms
where defaults are not what we need them to be. One such case is
VF610-base ZII SPU3 board (not supported upstream). To avoid this
problem in the future, add code to explicitly configure both.

Signed-off-by: Andrey Smirnov <andrew.smirnov@gmail.com>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
drivers/mfd/rave-sp.c

index a90ec4986b22681146ee90e6e3cfc2cb505dd514..aa75d5841ca0286906687c8a16d9932653819b4c 100644 (file)
@@ -766,6 +766,13 @@ static int rave_sp_probe(struct serdev_device *serdev)
                return ret;
 
        serdev_device_set_baudrate(serdev, baud);
+       serdev_device_set_flow_control(serdev, false);
+
+       ret = serdev_device_set_parity(serdev, SERDEV_PARITY_NONE);
+       if (ret) {
+               dev_err(dev, "Failed to set parity\n");
+               return ret;
+       }
 
        ret = rave_sp_get_status(sp);
        if (ret) {