1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

tests/periph/spi: allow use on more boards

- Disable the benchmark on low memory boards
- Reduce the help message length on low memory boards
- Update to new shell command interface using XFA
This commit is contained in:
Marian Buschsieweke 2023-11-29 12:57:43 +01:00
parent 20c389870a
commit b90f985d47
No known key found for this signature in database
GPG Key ID: 77AA882EC78084E6
5 changed files with 101 additions and 45 deletions

View File

@ -3,11 +3,32 @@
# This file is subject to the terms and conditions of the GNU Lesser # This file is subject to the terms and conditions of the GNU Lesser
# General Public License v2.1. See the file LICENSE in the top level # General Public License v2.1. See the file LICENSE in the top level
# directory for more details. # directory for more details.
#
config APP_CONSIDERS_BOARD_LOW_MEMORY
bool
help
This disables optional features for boards that are scare on resources
default y if BOARD_ARDUINO_DUEMILANOVE
default y if BOARD_ARDUINO_LEONARDO
default y if BOARD_ARDUINO_NANO
default y if BOARD_ARDUINO_UNO
default y if BOARD_ATMEGA328P
default y if BOARD_ATMEGA328P_XPLAINED_MINI
default y if BOARD_ATMEGA8
default y if BOARD_MSB_430
default y if BOARD_MSB_430H
default y if BOARD_NUCLEO_L011K4
default y if BOARD_OLIMEX_MSP430_H1611
default y if BOARD_OLIMEX_MSP430_H2618
default y if BOARD_SAMD10_XMINI
default y if BOARD_STM32F030F4_DEMO
default y if BOARD_TELOSB
default y if BOARD_Z1
config APPLICATION config APPLICATION
bool bool
default y default y
imply MODULE_PERIPH_SPI_RECONFIGURE
imply MODULE_PERIPH_SPI_ON_QSPI imply MODULE_PERIPH_SPI_ON_QSPI
depends on TEST_KCONFIG depends on TEST_KCONFIG
imply MODULE_PERIPH_SPI_RECONFIGURE if !APP_CONSIDERS_BOARD_LOW_MEMORY
select MODULE_SCHEDSTATISTICS if !APP_CONSIDERS_BOARD_LOW_MEMORY

View File

@ -1,21 +1,55 @@
BOARD ?= samr21-xpro BOARD ?= samr21-xpro
include ../Makefile.periph_common include ../Makefile.periph_common
LOW_MEMORY_BOARDS := samd10-xmini # Disable benchmark, optional features and longer in-app help message
# on boards with low RAM/ROM.
#
# In addition, all MSP430 based boards won't work with schedstatistics, as this
# imposes too much overhead for interrupt handlers (when unblocking the shell
# thread) for UART RX to work correctly.
LOW_MEMORY_BOARDS := \
arduino-duemilanove \
arduino-leonardo \
arduino-nano \
arduino-uno \
atmega328p \
atmega328p-xplained-mini \
atmega8 \
msb-430 \
msb-430h \
nucleo-l011k4 \
olimex-msp430-h1611 \
olimex-msp430-h2618 \
samd10-xmini \
stm32f030f4-demo \
telosb \
z1 \
#
FEATURES_REQUIRED += periph_spi FEATURES_REQUIRED += periph_spi
FEATURES_OPTIONAL += periph_spi_on_qspi FEATURES_OPTIONAL += periph_spi_on_qspi
ifeq (,$(filter $(BOARD),$(LOW_MEMORY_BOARDS))) ifeq (,$(filter $(BOARD),$(LOW_MEMORY_BOARDS)))
FEATURES_OPTIONAL += periph_spi_reconfigure FEATURES_OPTIONAL += periph_spi_reconfigure
ENABLE_BENCHMARK ?= 1
LOW_MEMORY := 0
else
ENABLE_BENCHMARK ?= 0
LOW_MEMORY := 1
endif endif
USEMODULE += ztimer_usec USEMODULE += ztimer_usec
USEMODULE += ztimer_sec USEMODULE += ztimer_sec
USEMODULE += shell_cmds_default USEMODULE += shell_cmds_default
USEMODULE += schedstatistics
ifeq (1,$(ENABLE_BENCHMARK))
USEMODULE += schedstatistics
endif
# avoid running Kconfig by default # avoid running Kconfig by default
SHOULD_RUN_KCONFIG ?= SHOULD_RUN_KCONFIG ?=
include $(RIOTBASE)/Makefile.include include $(RIOTBASE)/Makefile.include
CFLAGS += -DENABLE_BENCHMARK=$(ENABLE_BENCHMARK)
CFLAGS += -DLOW_MEMORY=$(LOW_MEMORY)

View File

@ -1,12 +1,4 @@
BOARD_INSUFFICIENT_MEMORY := \ BOARD_INSUFFICIENT_MEMORY := \
arduino-duemilanove \
arduino-leonardo \
arduino-nano \
arduino-uno \
atmega328p \
atmega328p-xplained-mini \
atmega8 \ atmega8 \
nucleo-l011k4 \ nucleo-l011k4 \
samd10-xmini \
stm32f030f4-demo \
# #

View File

@ -4,7 +4,6 @@ CONFIG_MODULE_PERIPH_SPI=y
CONFIG_MODULE_SHELL=y CONFIG_MODULE_SHELL=y
CONFIG_MODULE_SHELL_CMDS_DEFAULT=y CONFIG_MODULE_SHELL_CMDS_DEFAULT=y
CONFIG_MODULE_SCHEDSTATISTICS=y
CONFIG_MODULE_ZTIMER=y CONFIG_MODULE_ZTIMER=y
CONFIG_MODULE_ZTIMER_SEC=y CONFIG_MODULE_ZTIMER_SEC=y
CONFIG_ZTIMER_USEC=y CONFIG_ZTIMER_USEC=y

View File

@ -44,6 +44,17 @@
#define DEFAULT_SPI_CS_PIN 0 #define DEFAULT_SPI_CS_PIN 0
#endif #endif
#ifndef ENABLE_BENCHMARK
#define ENABLE_BENCHMARK 0
#endif
#ifndef LOW_MEMORY
#define LOW_MEMORY 0
#endif
#define BUF_SIZE (128U)
#if ENABLE_BENCHMARK
/** /**
* @brief Some parameters used for benchmarking * @brief Some parameters used for benchmarking
*/ */
@ -53,8 +64,6 @@
#define BENCH_PAYLOAD ('b') #define BENCH_PAYLOAD ('b')
#define BENCH_REGADDR (0x23) #define BENCH_REGADDR (0x23)
#define BUF_SIZE (512U)
/** /**
* @brief Benchmark buffers * @brief Benchmark buffers
*/ */
@ -62,6 +71,7 @@ static uint8_t bench_wbuf[BENCH_LARGE];
static uint8_t bench_rbuf[BENCH_LARGE]; static uint8_t bench_rbuf[BENCH_LARGE];
extern void sched_statistics_cb(kernel_pid_t active_thread, kernel_pid_t next_thread); extern void sched_statistics_cb(kernel_pid_t active_thread, kernel_pid_t next_thread);
#endif
/** /**
* @brief Generic buffer used for receiving * @brief Generic buffer used for receiving
@ -75,6 +85,7 @@ static struct {
spi_cs_t cs; spi_cs_t cs;
} spiconf; } spiconf;
#if ENABLE_BENCHMARK
/* /*
* @brief Trigger an update of the scheduler runtime statistics. * @brief Trigger an update of the scheduler runtime statistics.
* *
@ -95,8 +106,9 @@ static uint32_t _ztimer_diff_usec(uint32_t stop, uint32_t start)
{ {
return stop - start; return stop - start;
} }
#endif
void print_bytes(char* title, uint8_t* data, size_t len) static void print_bytes(const char *title, const uint8_t *data, size_t len)
{ {
printf("%4s\n", title); printf("%4s\n", title);
for (size_t i = 0; i < len; i++) { for (size_t i = 0; i < len; i++) {
@ -118,7 +130,7 @@ void print_bytes(char* title, uint8_t* data, size_t len)
printf("\n\n"); printf("\n\n");
} }
int cmd_init(int argc, char **argv) static int cmd_init(int argc, char **argv)
{ {
int dev, mode, clk, port, pin, tmp; int dev, mode, clk, port, pin, tmp;
@ -128,22 +140,24 @@ int cmd_init(int argc, char **argv)
for (int i = 0; i < (int)SPI_NUMOF; i++) { for (int i = 0; i < (int)SPI_NUMOF; i++) {
printf("\t\t%i: SPI_DEV(%i)\n", i, i); printf("\t\t%i: SPI_DEV(%i)\n", i, i);
} }
puts("\tmode:"); if (!LOW_MEMORY) {
puts("\t\t0: POL:0, PHASE:0 - on first rising edge"); puts("\tmode:\n"
puts("\t\t1: POL:0, PHASE:1 - on second rising edge"); "\t\t0: POL:0, PHASE:0 - on first rising edge\n"
puts("\t\t2: POL:1, PHASE:0 - on first falling edge"); "\t\t1: POL:0, PHASE:1 - on second rising edge\n"
puts("\t\t3: POL:1, PHASE:1 - on second falling edge"); "\t\t2: POL:1, PHASE:0 - on first falling edge\n"
puts("\tclk:"); "\t\t3: POL:1, PHASE:1 - on second falling edge\n"
puts("\t\t0: 100 KHz"); "\tclk:\n"
puts("\t\t1: 400 KHz"); "\t\t0: 100 KHz\n"
puts("\t\t2: 1 MHz"); "\t\t1: 400 KHz\n"
puts("\t\t3: 5 MHz"); "\t\t2: 1 MHz\n"
puts("\t\t4: 10 MHz"); "\t\t3: 5 MHz\n"
puts("\tcs port:"); "\t\t4: 10 MHz\n"
puts("\t\tPort of the CS pin, set to -1 for hardware chip select"); "\tcs port:\n"
puts("\tcs pin:"); "\t\tPort of the CS pin, set to -1 for hardware chip select\n"
puts("\t\tPin used for chip select. If hardware chip select is enabled,\n" "\tcs pin:\n"
"\t\tthis value specifies the internal HWCS line"); "\t\tPin used for chip select. If hardware chip select is enabled,\n"
"\t\tthis value specifies the internal HWCS line");
}
return 1; return 1;
} }
@ -226,8 +240,9 @@ int cmd_init(int argc, char **argv)
return 0; return 0;
} }
SHELL_COMMAND(init, "Setup a particular SPI configuration", cmd_init);
int cmd_transfer(int argc, char **argv) static int cmd_transfer(int argc, char **argv)
{ {
size_t len; size_t len;
@ -258,7 +273,9 @@ int cmd_transfer(int argc, char **argv)
return 0; return 0;
} }
SHELL_COMMAND(send, "Transfer string to slave", cmd_transfer);
#if ENABLE_BENCHMARK
int cmd_bench(int argc, char **argv) int cmd_bench(int argc, char **argv)
{ {
(void)argc; (void)argc;
@ -520,6 +537,8 @@ int cmd_bench(int argc, char **argv)
return 0; return 0;
} }
SHELL_COMMAND(bench, "Runs some benchmarks", cmd_bench);
#endif
#ifdef MODULE_PERIPH_SPI_RECONFIGURE #ifdef MODULE_PERIPH_SPI_RECONFIGURE
int cmd_spi_gpio(int argc, char **argv) int cmd_spi_gpio(int argc, char **argv)
@ -565,18 +584,9 @@ int cmd_spi_gpio(int argc, char **argv)
printf("Success: spi_%i re-init\n", dev); printf("Success: spi_%i re-init\n", dev);
return 0; return 0;
} }
SHELL_COMMAND(spi_gpio, "Re-configures MISO & MOSI pins to GPIO mode and back.", cmd_spi_gpio);
#endif #endif
static const shell_command_t shell_commands[] = {
{ "init", "Setup a particular SPI configuration", cmd_init },
{ "send", "Transfer string to slave", cmd_transfer },
{ "bench", "Runs some benchmarks", cmd_bench },
#ifdef MODULE_PERIPH_SPI_RECONFIGURE
{ "spi_gpio", "Re-configures MISO & MOSI pins to GPIO mode and back.", cmd_spi_gpio },
#endif
{ NULL, NULL, NULL }
};
int main(void) int main(void)
{ {
puts("Manual SPI peripheral driver test (see README.md)"); puts("Manual SPI peripheral driver test (see README.md)");
@ -589,7 +599,7 @@ int main(void)
/* run the shell */ /* run the shell */
char line_buf[SHELL_DEFAULT_BUFSIZE]; char line_buf[SHELL_DEFAULT_BUFSIZE];
shell_run(shell_commands, line_buf, SHELL_DEFAULT_BUFSIZE); shell_run(NULL, line_buf, SHELL_DEFAULT_BUFSIZE);
return 0; return 0;
} }