diff mbox series

[U-Boot,v2,3/3] sandbox: Add serial test

Message ID 1533139133-27800-4-git-send-email-patrice.chotard@st.com
State Superseded
Headers show
Series Replace serial setparity by setconfig | expand

Commit Message

Patrice CHOTARD Aug. 1, 2018, 3:58 p.m. UTC
Signed-off-by: Patrice Chotard <patrice.chotard@st.com>
---

Changes in v2:
  - Add sandbox serial test

 drivers/serial/sandbox.c | 14 ++++++++++++++
 include/common.h         |  1 +
 test/dm/Makefile         |  1 +
 test/dm/serial.c         | 26 ++++++++++++++++++++++++++
 4 files changed, 42 insertions(+)
 create mode 100644 test/dm/serial.c

Comments

Simon Glass Aug. 2, 2018, 4:57 p.m. UTC | #1
On 1 August 2018 at 09:58, Patrice Chotard <patrice.chotard@st.com> wrote:
> Signed-off-by: Patrice Chotard <patrice.chotard@st.com>
> ---
>
> Changes in v2:
>   - Add sandbox serial test
>
>  drivers/serial/sandbox.c | 14 ++++++++++++++
>  include/common.h         |  1 +
>  test/dm/Makefile         |  1 +
>  test/dm/serial.c         | 26 ++++++++++++++++++++++++++
>  4 files changed, 42 insertions(+)
>  create mode 100644 test/dm/serial.c

Reviewed-by: Simon Glass <sjg@chromium.org>

How about also a test that checks it returns -ENOTSUPP when the wrong
options are specified?

>
> diff --git a/drivers/serial/sandbox.c b/drivers/serial/sandbox.c
> index a60dabe58835..94b4fdfb1714 100644
> --- a/drivers/serial/sandbox.c
> +++ b/drivers/serial/sandbox.c
> @@ -143,6 +143,19 @@ static int sandbox_serial_getc(struct udevice *dev)
>         return result;
>  }
>
> +static int sandbox_serial_setconfig(struct udevice *dev, uint serial_config)
> +{
> +       u8 parity = SERIAL_GET_PARITY(serial_config);
> +       u8 bits = SERIAL_GET_BITS(serial_config);
> +       u8 stop = SERIAL_GET_STOP(serial_config);
> +
> +       if (bits != SERIAL_8_BITS || stop != SERIAL_ONE_STOP ||
> +           parity != SERIAL_PAR_NONE)
> +               return -ENOTSUPP; /* not supported in driver*/
> +
> +       return 0;
> +}
> +
>  static const char * const ansi_colour[] = {
>         "black", "red", "green", "yellow", "blue", "megenta", "cyan",
>         "white",
> @@ -173,6 +186,7 @@ static const struct dm_serial_ops sandbox_serial_ops = {
>         .putc = sandbox_serial_putc,
>         .pending = sandbox_serial_pending,
>         .getc = sandbox_serial_getc,
> +       .setconfig = sandbox_serial_setconfig,
>  };
>
>  static const struct udevice_id sandbox_serial_ids[] = {
> diff --git a/include/common.h b/include/common.h
> index 940161f1758b..5c952af5e319 100644
> --- a/include/common.h
> +++ b/include/common.h
> @@ -359,6 +359,7 @@ void        serial_putc_raw(const char);
>  void   serial_puts   (const char *);
>  int    serial_getc   (void);
>  int    serial_tstc   (void);
> +int    serial_setconfig(uint config);
>
>  /* $(CPU)/speed.c */
>  int    get_clocks (void);
> diff --git a/test/dm/Makefile b/test/dm/Makefile
> index d2ed96c61533..97517c7f825e 100644
> --- a/test/dm/Makefile
> +++ b/test/dm/Makefile
> @@ -44,4 +44,5 @@ obj-$(CONFIG_DM_VIDEO) += video.o
>  obj-$(CONFIG_ADC) += adc.o
>  obj-$(CONFIG_SPMI) += spmi.o
>  obj-$(CONFIG_WDT) += wdt.o
> +obj-$(CONFIG_DM_SERIAL) += serial.o
>  endif
> diff --git a/test/dm/serial.c b/test/dm/serial.c
> new file mode 100644
> index 000000000000..4d8422eebd34
> --- /dev/null
> +++ b/test/dm/serial.c
> @@ -0,0 +1,26 @@
> +// SPDX-License-Identifier: GPL-2.0
> +/*
> + * Copyright (c) 2018, STMicroelectronics
> + */
> +
> +#include <common.h>
> +#include <serial.h>
> +#include <dm.h>
> +#include <dm/test.h>
> +#include <test/ut.h>
> +
> +static int dm_test_serial(struct unit_test_state *uts)
> +{
> +       struct udevice *dev_serial;
> +
> +       ut_assertok(uclass_get_device_by_name(UCLASS_SERIAL, "serial",
> +                                             &dev_serial));
> +
> +       ut_assertok(serial_tstc());
> +
> +       ut_assertok(serial_setconfig(SERIAL_DEFAULT_CONFIG));
> +
> +       return 0;
> +}
> +
> +DM_TEST(dm_test_serial, DM_TESTF_SCAN_FDT);
> --
> 1.9.1
>
Patrice CHOTARD Aug. 3, 2018, 11:30 a.m. UTC | #2
Hi Simon

On 08/02/2018 06:57 PM, Simon Glass wrote:
> On 1 August 2018 at 09:58, Patrice Chotard <patrice.chotard@st.com> wrote:
>> Signed-off-by: Patrice Chotard <patrice.chotard@st.com>
>> ---
>>
>> Changes in v2:
>>    - Add sandbox serial test
>>
>>   drivers/serial/sandbox.c | 14 ++++++++++++++
>>   include/common.h         |  1 +
>>   test/dm/Makefile         |  1 +
>>   test/dm/serial.c         | 26 ++++++++++++++++++++++++++
>>   4 files changed, 42 insertions(+)
>>   create mode 100644 test/dm/serial.c
> 
> Reviewed-by: Simon Glass <sjg@chromium.org>
> 
> How about also a test that checks it returns -ENOTSUPP when the wrong
> options are specified?

Effectively, it currently misses, i will add a specific test.

Thanks

Patrice

> 
>>
>> diff --git a/drivers/serial/sandbox.c b/drivers/serial/sandbox.c
>> index a60dabe58835..94b4fdfb1714 100644
>> --- a/drivers/serial/sandbox.c
>> +++ b/drivers/serial/sandbox.c
>> @@ -143,6 +143,19 @@ static int sandbox_serial_getc(struct udevice *dev)
>>          return result;
>>   }
>>
>> +static int sandbox_serial_setconfig(struct udevice *dev, uint serial_config)
>> +{
>> +       u8 parity = SERIAL_GET_PARITY(serial_config);
>> +       u8 bits = SERIAL_GET_BITS(serial_config);
>> +       u8 stop = SERIAL_GET_STOP(serial_config);
>> +
>> +       if (bits != SERIAL_8_BITS || stop != SERIAL_ONE_STOP ||
>> +           parity != SERIAL_PAR_NONE)
>> +               return -ENOTSUPP; /* not supported in driver*/
>> +
>> +       return 0;
>> +}
>> +
>>   static const char * const ansi_colour[] = {
>>          "black", "red", "green", "yellow", "blue", "megenta", "cyan",
>>          "white",
>> @@ -173,6 +186,7 @@ static const struct dm_serial_ops sandbox_serial_ops = {
>>          .putc = sandbox_serial_putc,
>>          .pending = sandbox_serial_pending,
>>          .getc = sandbox_serial_getc,
>> +       .setconfig = sandbox_serial_setconfig,
>>   };
>>
>>   static const struct udevice_id sandbox_serial_ids[] = {
>> diff --git a/include/common.h b/include/common.h
>> index 940161f1758b..5c952af5e319 100644
>> --- a/include/common.h
>> +++ b/include/common.h
>> @@ -359,6 +359,7 @@ void        serial_putc_raw(const char);
>>   void   serial_puts   (const char *);
>>   int    serial_getc   (void);
>>   int    serial_tstc   (void);
>> +int    serial_setconfig(uint config);
>>
>>   /* $(CPU)/speed.c */
>>   int    get_clocks (void);
>> diff --git a/test/dm/Makefile b/test/dm/Makefile
>> index d2ed96c61533..97517c7f825e 100644
>> --- a/test/dm/Makefile
>> +++ b/test/dm/Makefile
>> @@ -44,4 +44,5 @@ obj-$(CONFIG_DM_VIDEO) += video.o
>>   obj-$(CONFIG_ADC) += adc.o
>>   obj-$(CONFIG_SPMI) += spmi.o
>>   obj-$(CONFIG_WDT) += wdt.o
>> +obj-$(CONFIG_DM_SERIAL) += serial.o
>>   endif
>> diff --git a/test/dm/serial.c b/test/dm/serial.c
>> new file mode 100644
>> index 000000000000..4d8422eebd34
>> --- /dev/null
>> +++ b/test/dm/serial.c
>> @@ -0,0 +1,26 @@
>> +// SPDX-License-Identifier: GPL-2.0
>> +/*
>> + * Copyright (c) 2018, STMicroelectronics
>> + */
>> +
>> +#include <common.h>
>> +#include <serial.h>
>> +#include <dm.h>
>> +#include <dm/test.h>
>> +#include <test/ut.h>
>> +
>> +static int dm_test_serial(struct unit_test_state *uts)
>> +{
>> +       struct udevice *dev_serial;
>> +
>> +       ut_assertok(uclass_get_device_by_name(UCLASS_SERIAL, "serial",
>> +                                             &dev_serial));
>> +
>> +       ut_assertok(serial_tstc());
>> +
>> +       ut_assertok(serial_setconfig(SERIAL_DEFAULT_CONFIG));
>> +
>> +       return 0;
>> +}
>> +
>> +DM_TEST(dm_test_serial, DM_TESTF_SCAN_FDT);
>> --
>> 1.9.1
>>
diff mbox series

Patch

diff --git a/drivers/serial/sandbox.c b/drivers/serial/sandbox.c
index a60dabe58835..94b4fdfb1714 100644
--- a/drivers/serial/sandbox.c
+++ b/drivers/serial/sandbox.c
@@ -143,6 +143,19 @@  static int sandbox_serial_getc(struct udevice *dev)
 	return result;
 }
 
+static int sandbox_serial_setconfig(struct udevice *dev, uint serial_config)
+{
+	u8 parity = SERIAL_GET_PARITY(serial_config);
+	u8 bits = SERIAL_GET_BITS(serial_config);
+	u8 stop = SERIAL_GET_STOP(serial_config);
+
+	if (bits != SERIAL_8_BITS || stop != SERIAL_ONE_STOP ||
+	    parity != SERIAL_PAR_NONE)
+		return -ENOTSUPP; /* not supported in driver*/
+
+	return 0;
+}
+
 static const char * const ansi_colour[] = {
 	"black", "red", "green", "yellow", "blue", "megenta", "cyan",
 	"white",
@@ -173,6 +186,7 @@  static const struct dm_serial_ops sandbox_serial_ops = {
 	.putc = sandbox_serial_putc,
 	.pending = sandbox_serial_pending,
 	.getc = sandbox_serial_getc,
+	.setconfig = sandbox_serial_setconfig,
 };
 
 static const struct udevice_id sandbox_serial_ids[] = {
diff --git a/include/common.h b/include/common.h
index 940161f1758b..5c952af5e319 100644
--- a/include/common.h
+++ b/include/common.h
@@ -359,6 +359,7 @@  void	serial_putc_raw(const char);
 void	serial_puts   (const char *);
 int	serial_getc   (void);
 int	serial_tstc   (void);
+int	serial_setconfig(uint config);
 
 /* $(CPU)/speed.c */
 int	get_clocks (void);
diff --git a/test/dm/Makefile b/test/dm/Makefile
index d2ed96c61533..97517c7f825e 100644
--- a/test/dm/Makefile
+++ b/test/dm/Makefile
@@ -44,4 +44,5 @@  obj-$(CONFIG_DM_VIDEO) += video.o
 obj-$(CONFIG_ADC) += adc.o
 obj-$(CONFIG_SPMI) += spmi.o
 obj-$(CONFIG_WDT) += wdt.o
+obj-$(CONFIG_DM_SERIAL) += serial.o
 endif
diff --git a/test/dm/serial.c b/test/dm/serial.c
new file mode 100644
index 000000000000..4d8422eebd34
--- /dev/null
+++ b/test/dm/serial.c
@@ -0,0 +1,26 @@ 
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Copyright (c) 2018, STMicroelectronics
+ */
+
+#include <common.h>
+#include <serial.h>
+#include <dm.h>
+#include <dm/test.h>
+#include <test/ut.h>
+
+static int dm_test_serial(struct unit_test_state *uts)
+{
+	struct udevice *dev_serial;
+
+	ut_assertok(uclass_get_device_by_name(UCLASS_SERIAL, "serial",
+					      &dev_serial));
+
+	ut_assertok(serial_tstc());
+
+	ut_assertok(serial_setconfig(SERIAL_DEFAULT_CONFIG));
+
+	return 0;
+}
+
+DM_TEST(dm_test_serial, DM_TESTF_SCAN_FDT);