2019-03-12 14:01:06 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 ML!PA Consulting GmbH
|
|
|
|
*
|
|
|
|
* 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_same54-xpro
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Board specific implementations for the Microchip SAM E54 Xplained
|
|
|
|
* Pro board
|
|
|
|
*
|
|
|
|
* @author Benjamin Valentin <benjamin.valentin@ml-pa.com>
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "board.h"
|
|
|
|
#include "periph/gpio.h"
|
2020-11-01 23:51:23 +01:00
|
|
|
#include "timex.h"
|
2022-03-20 21:06:13 +01:00
|
|
|
#ifdef MODULE_VFS_DEFAULT
|
|
|
|
#include "vfs_default.h"
|
|
|
|
#endif
|
2020-11-01 23:51:23 +01:00
|
|
|
|
2022-03-20 21:06:13 +01:00
|
|
|
#ifdef MODULE_MTD_SPI_NOR
|
|
|
|
#include "mtd_spi_nor.h"
|
2022-02-03 21:49:49 +01:00
|
|
|
/* N25Q256A or SST26VF064B */
|
2020-11-01 23:51:23 +01:00
|
|
|
static const mtd_spi_nor_params_t _same54_nor_params = {
|
|
|
|
.opcode = &mtd_spi_nor_opcode_default,
|
|
|
|
.wait_chip_erase = 240 * US_PER_SEC,
|
|
|
|
.wait_64k_erase = 700 * US_PER_MS,
|
|
|
|
.wait_sector_erase = 250 * US_PER_MS,
|
|
|
|
.wait_chip_wake_up = 1 * US_PER_MS,
|
|
|
|
.clk = MHZ(54),
|
|
|
|
.flag = SPI_NOR_F_SECT_4K | SPI_NOR_F_SECT_64K,
|
|
|
|
.spi = SPI_DEV(2),
|
|
|
|
.mode = SPI_MODE_0,
|
|
|
|
.cs = SAM0_QSPI_PIN_CS,
|
|
|
|
.wp = SAM0_QSPI_PIN_DATA_2,
|
|
|
|
.hold = SAM0_QSPI_PIN_DATA_3,
|
|
|
|
};
|
|
|
|
|
|
|
|
static mtd_spi_nor_t same54_nor_dev = {
|
|
|
|
.base = {
|
|
|
|
.driver = &mtd_spi_nor_driver,
|
|
|
|
.page_size = 256,
|
|
|
|
.pages_per_sector = 16,
|
|
|
|
},
|
|
|
|
.params = &_same54_nor_params,
|
|
|
|
};
|
|
|
|
mtd_dev_t *mtd0 = (mtd_dev_t *)&same54_nor_dev;
|
2021-01-24 00:26:12 +01:00
|
|
|
|
2022-03-20 21:06:13 +01:00
|
|
|
#ifdef MODULE_VFS_DEFAULT
|
|
|
|
VFS_AUTO_MOUNT(littlefs2, VFS_MTD(same54_nor_dev), VFS_DEFAULT_NVM(0), 0);
|
|
|
|
#endif
|
|
|
|
#endif /* MODULE_MTD_SPI_NOR */
|
|
|
|
|
|
|
|
#ifdef MODULE_MTD_AT24CXXX
|
2021-01-24 00:26:12 +01:00
|
|
|
#include "mtd_at24cxxx.h"
|
|
|
|
#include "at24cxxx_params.h"
|
|
|
|
static at24cxxx_t at24cxxx_dev;
|
|
|
|
static mtd_at24cxxx_t at24mac_dev = {
|
|
|
|
.base = {
|
|
|
|
.driver = &mtd_at24cxxx_driver,
|
|
|
|
},
|
|
|
|
.at24cxxx_eeprom = &at24cxxx_dev,
|
|
|
|
.params = at24cxxx_params,
|
|
|
|
};
|
|
|
|
mtd_dev_t *mtd1 = (mtd_dev_t *)&at24mac_dev;
|
2022-03-20 21:06:13 +01:00
|
|
|
#endif /* MODULE_MTD_AT24CXXX */
|
|
|
|
|
|
|
|
#ifdef MODULE_SAM0_SDHC
|
|
|
|
#include "mtd_sam0_sdhc.h"
|
|
|
|
static mtd_sam0_sdhc_t sdhc_dev = {
|
|
|
|
.base = {
|
|
|
|
.driver = &mtd_sam0_sdhc_driver,
|
|
|
|
},
|
|
|
|
.state = {
|
|
|
|
.dev = SDHC1,
|
|
|
|
.cd = GPIO_PIN(PD, 20),
|
|
|
|
.wp = GPIO_PIN(PD, 21),
|
|
|
|
},
|
|
|
|
};
|
|
|
|
mtd_dev_t *mtd2 = (mtd_dev_t *)&sdhc_dev;
|
2022-02-11 16:46:56 +01:00
|
|
|
|
|
|
|
#ifdef MODULE_VFS_DEFAULT
|
2022-03-20 21:06:13 +01:00
|
|
|
VFS_AUTO_MOUNT(fatfs, VFS_MTD(sdhc_dev), VFS_DEFAULT_SD(0), 1);
|
2022-02-11 16:46:56 +01:00
|
|
|
#endif
|
2022-03-20 21:06:13 +01:00
|
|
|
#endif /* MODULE_SAM0_SDHC */
|