Message ID | 1533139133-27800-4-git-send-email-patrice.chotard@st.com |
---|---|
State | Superseded |
Headers | show |
Series | Replace serial setparity by setconfig | expand |
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 >
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 --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);
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