mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-17 23:12:45 +01:00
1691dbe0d3
19914: boards: complete SD Card MTD definition for several bords r=benpicco a=gschorcht ### Contribution description This PR completes the MTD definition for the following boards: - `seeedstudio-gd32` - `sipeed-longan-nano` including `sipeed-longan-nano-tft` - `waveshare-nrf52840-eval-kit` - ESP32x boards that have an SPI SD Card interface and use `mtd_sdcard_default` ### Testing procedure Green CI ### Issues/PRs references#19465 Prerequisite for PR #19465 19915: drivers/lcd: support MCU 8080 8-bit parallel mode r=benpicco a=gschorcht ### Contribution description LCD driver ICs usually support - SPI serial mode, - MCU 8080 8-bit parallel mode and - MCU 8080 16-bit parallel mode. This PR extends the LCD display driver API to support the MCU 8080 8-/16-bit parallel modes and implements a GPIO-driven MCU 8080 8-bit parallel mode. The following features are already working locally and will be provided as follow-on PRs for which this PR is a prerequisite. - GPIO-driven bit-banging implementation of the 16-bit mode of the MCU 8080 parallel interface - Enabling the display on `stm32f723e-disco` and `stm32l496g-disco` using the feature above - Definition of a low-level API for the parallel modes using the LCD controller of the MCU - Using FMC for the display on `stm32f723e-disco` and `stm32l496g-disco` - Using LCD controller for the display of `esp32-wt32-sc01-plus` (PR #19917) ### Testing procedure The PR can be tested with PR #19917 on top of this PR. ``` BOARD=esp32s3-wt32-sc01-plus make -j8 -C tests/drivers/st77xx flash ``` The following video shows the test. **Please note** The test is pretty slow because the display has 480 x 320 pixels and the MCU 8080 8-bit parallel interface is realized by a GPIO-driven bit-banging implementation where each GPIO of the data bus is set separately. A follow-up PR will use the ESP32-S3 LCD controller and DMA for this board. This PR just defines the extension of the driver by the parallel interface and provides the bit-banging implementation for MCUs that don't have a LCD controller on chip. https://github.com/RIOT-OS/RIOT/assets/31932013/c1e3e3d7-05d9-4ca5-8fff-9a5eaca50fba ### Issues/PRs references Co-authored-by: Gunar Schorcht <gunar@schorcht.net>
106 lines
3.3 KiB
C
106 lines
3.3 KiB
C
/*
|
|
* Copyright (C) 2023 Gunar Schorcht <gunar@schorcht.net>
|
|
*
|
|
* 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
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup boards_sipeed_longan_nano
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Board specific definitions for the Sipeed Longan Nano board
|
|
*
|
|
* @author Koen Zandberg <koen@bergzand.net>
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
*/
|
|
|
|
#ifndef BOARD_H
|
|
#define BOARD_H
|
|
|
|
#include "board_common.h"
|
|
#include "mtd.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @name Button pin definitions
|
|
* @{
|
|
*/
|
|
#define BTN0_PIN GPIO_PIN(PORT_A, 8)
|
|
#define BTN0_MODE GPIO_IN
|
|
#define BTN0_INT_FLANK GPIO_RISING
|
|
/** @} */
|
|
|
|
/**
|
|
* @name LED (on-board) configuration
|
|
* @{
|
|
*/
|
|
#define LED0_PIN GPIO_PIN(PORT_C, 13)
|
|
#define LED0_MASK (1 << 13)
|
|
#define LED0_ON (GPIOC->BC = LED0_MASK)
|
|
#define LED0_OFF (GPIOC->BOP = LED0_MASK)
|
|
#define LED0_TOGGLE (GPIOC->OCTL ^= LED0_MASK)
|
|
|
|
#define LED1_PIN GPIO_PIN(PORT_A, 1)
|
|
#define LED1_MASK (1 << 1)
|
|
#define LED1_ON (GPIOA->BC = LED1_MASK)
|
|
#define LED1_OFF (GPIOA->BOP = LED1_MASK)
|
|
#define LED1_TOGGLE (GPIOA->OCTL ^= LED1_MASK)
|
|
|
|
#define LED2_PIN GPIO_PIN(PORT_A, 2)
|
|
#define LED2_MASK (1 << 2)
|
|
#define LED2_ON (GPIOA->BC = LED2_MASK)
|
|
#define LED2_OFF (GPIOA->BOP = LED2_MASK)
|
|
#define LED2_TOGGLE (GPIOA->OCTL ^= LED2_MASK)
|
|
|
|
#define LED_RED_PIN LED0_PIN /**< LED0 is red */
|
|
#define LED_GREEN_PIN LED1_PIN /**< LED1 is green */
|
|
#define LED_BLUE_PIN LED2_PIN /**< LED2 is blue */
|
|
/** @} */
|
|
|
|
/**
|
|
* @name MTD configuration
|
|
* @{
|
|
*/
|
|
#define MTD_0 mtd0 /**< MTD device for SD Card */
|
|
extern mtd_dev_t *mtd0; /**< MTD device pointer for SD Card */
|
|
/** @} */
|
|
|
|
/**
|
|
* @name SD-Card interface configuration
|
|
* @{
|
|
*/
|
|
#define SDCARD_SPI_PARAM_SPI SPI_DEV(0)
|
|
#define SDCARD_SPI_PARAM_CS GPIO_PIN(PORT_B, 12)
|
|
#define SDCARD_SPI_PARAM_CLK GPIO_PIN(PORT_B, 13)
|
|
#define SDCARD_SPI_PARAM_MISO GPIO_PIN(PORT_B, 14)
|
|
#define SDCARD_SPI_PARAM_MOSI GPIO_PIN(PORT_B, 15)
|
|
/** @} */
|
|
|
|
#if defined(MODULE_ST77XX) && defined(BOARD_SIPEED_LONGAN_NANO_TFT)
|
|
#define ST77XX_PARAM_SPI SPI_DEV(1) /**< SPI device */
|
|
#define ST77XX_PARAM_SPI_CLK SPI_CLK_5MHZ /**< SPI clock frequency */
|
|
#define ST77XX_PARAM_SPI_MODE SPI_MODE_0 /**< SPI mode */
|
|
#define ST77XX_PARAM_CS GPIO_PIN(PORT_B, 2) /**< Chip Select pin */
|
|
#define ST77XX_PARAM_DCX GPIO_PIN(PORT_B, 0) /**< DCX pin */
|
|
#define ST77XX_PARAM_RST GPIO_PIN(PORT_B, 1) /**< Reset pin */
|
|
#define ST77XX_PARAM_RGB 0 /**< RGB mode enable */
|
|
#define ST77XX_PARAM_INVERTED 1 /**< Inverted mode enable */
|
|
#define ST77XX_PARAM_NUM_LINES 160U /**< Number of lines */
|
|
#define ST77XX_PARAM_RGB_CHANNELS 80U /**< Number of columns */
|
|
#define ST77XX_PARAM_ROTATION ST77XX_ROTATION_270 /**< Rotation mode */
|
|
#define ST77XX_PARAM_OFFSET_Y 25 /**< Vertical offset */
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* BOARD_H */
|
|
/** @} */
|