2020-02-22 23:37:29 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2020 Benjamin Valentin
|
|
|
|
*
|
|
|
|
* 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_serpente
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Board specific implementations for the Serpente board
|
|
|
|
*
|
|
|
|
* @author Benjamin Valentin <benpicco@googlemail.com>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "board.h"
|
|
|
|
#include "mtd.h"
|
|
|
|
#include "mtd_spi_nor.h"
|
|
|
|
#include "periph/gpio.h"
|
|
|
|
#include "periph/spi.h"
|
|
|
|
#include "timex.h"
|
|
|
|
|
|
|
|
#ifdef MODULE_MTD
|
|
|
|
/* GD25Q32C */
|
|
|
|
static const mtd_spi_nor_params_t _serpente_nor_params = {
|
|
|
|
.opcode = &mtd_spi_nor_opcode_default,
|
|
|
|
.wait_chip_erase = 15LU * US_PER_SEC,
|
|
|
|
.wait_32k_erase = 250LU * US_PER_MS,
|
|
|
|
.wait_sector_erase = 50LU * US_PER_MS,
|
|
|
|
.wait_chip_wake_up = 1LU * US_PER_MS,
|
|
|
|
.clk = SERPENTE_NOR_SPI_CLK,
|
|
|
|
.flag = SERPENTE_NOR_FLAGS,
|
|
|
|
.spi = SERPENTE_NOR_SPI_DEV,
|
|
|
|
.mode = SERPENTE_NOR_SPI_MODE,
|
|
|
|
.cs = SERPENTE_NOR_SPI_CS,
|
2020-11-02 02:42:45 +01:00
|
|
|
.wp = GPIO_UNDEF,
|
|
|
|
.hold = GPIO_UNDEF,
|
2020-02-22 23:37:29 +01:00
|
|
|
.addr_width = 3,
|
|
|
|
};
|
|
|
|
|
|
|
|
static mtd_spi_nor_t serpente_nor_dev = {
|
|
|
|
.base = {
|
|
|
|
.driver = &mtd_spi_nor_driver,
|
|
|
|
.page_size = SERPENTE_NOR_PAGE_SIZE,
|
|
|
|
.pages_per_sector = SERPENTE_NOR_PAGES_PER_SECTOR,
|
|
|
|
.sector_count = SERPENTE_NOR_SECTOR_COUNT,
|
|
|
|
},
|
|
|
|
.params = &_serpente_nor_params,
|
|
|
|
};
|
|
|
|
|
|
|
|
mtd_dev_t *mtd0 = (mtd_dev_t *)&serpente_nor_dev;
|
|
|
|
#endif /* MODULE_MTD */
|
|
|
|
|
|
|
|
void board_init(void)
|
|
|
|
{
|
|
|
|
/* initialize the on-board red LEDs */
|
|
|
|
gpio_init(LED0_PIN, GPIO_OUT);
|
|
|
|
gpio_init(LED1_PIN, GPIO_OUT);
|
|
|
|
gpio_init(LED2_PIN, GPIO_OUT);
|
|
|
|
|
|
|
|
LED0_OFF;
|
|
|
|
LED1_OFF;
|
|
|
|
LED2_OFF;
|
|
|
|
}
|