soc/mediatek/mt8189: Add NOR-Flash support
Add NOR-Flash drivers for flash read/write. BUG=b:379008996 BRANCH=none TEST=Read NOR flash data successfully. Signed-off-by: Noah Shen <noah.shen@mediatek.corp-partner.google.com> Change-Id: I3a5b7682e4093f9eddf825bc57267b0180cf8b3c Reviewed-on: https://review.coreboot.org/c/coreboot/+/86997 Reviewed-by: Yu-Ping Wu <yupingso@google.com> Reviewed-by: Yidi Lin <yidilin@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
504cfaa41b
commit
4c967ea167
4 changed files with 24 additions and 4 deletions
|
|
@ -9,6 +9,7 @@ config SOC_MEDIATEK_MT8189
|
|||
select ARCH_RAMSTAGE_ARMV8_64
|
||||
select HAVE_UART_SPECIAL
|
||||
select SOC_MEDIATEK_COMMON
|
||||
select FLASH_DUAL_IO_READ
|
||||
select ARM64_USE_ARCH_TIMER
|
||||
|
||||
if SOC_MEDIATEK_MT8189
|
||||
|
|
|
|||
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
ifeq ($(CONFIG_SOC_MEDIATEK_MT8189),y)
|
||||
|
||||
all-y += ../common/flash_controller.c
|
||||
all-y += ../common/gpio.c ../common/gpio_op.c gpio.c
|
||||
all-$(CONFIG_SPI_FLASH) += spi.c
|
||||
all-y += ../common/timer_prepare.c timer.c
|
||||
|
|
|
|||
|
|
@ -8,6 +8,7 @@
|
|||
#ifndef __SOC_MEDIATEK_MT8189_INCLUDE_SOC_SPI_H__
|
||||
#define __SOC_MEDIATEK_MT8189_INCLUDE_SOC_SPI_H__
|
||||
|
||||
#include <spi-generic.h>
|
||||
/* Initialize SPI NOR Flash Controller */
|
||||
void mtk_snfc_init(void);
|
||||
|
||||
#endif /* __SOC_MEDIATEK_MT8189_INCLUDE_SOC_SPI_H__ */
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -5,17 +5,34 @@
|
|||
* Chapter number: 9.17
|
||||
*/
|
||||
|
||||
#include <device/mmio.h>
|
||||
#include <soc/addressmap.h>
|
||||
#include <gpio.h>
|
||||
#include <soc/flash_controller_common.h>
|
||||
#include <soc/spi.h>
|
||||
#include <spi_flash.h>
|
||||
|
||||
static const struct pad_func nor_pinmux[4] = {
|
||||
PAD_FUNC(SPINOR_CK, SPINOR_CK, GPIO_PULL_DOWN),
|
||||
PAD_FUNC(SPINOR_CS, SPINOR_CS, GPIO_PULL_UP),
|
||||
PAD_FUNC(SPINOR_IO0, SPINOR_IO0, GPIO_PULL_DOWN),
|
||||
PAD_FUNC(SPINOR_IO1, SPINOR_IO1, GPIO_PULL_DOWN),
|
||||
};
|
||||
|
||||
void mtk_snfc_init(void)
|
||||
{
|
||||
for (size_t i = 0; i < ARRAY_SIZE(nor_pinmux); i++)
|
||||
mtk_snfc_init_pad_func(&nor_pinmux[i], GPIO_DRV_8_MA);
|
||||
}
|
||||
|
||||
static const struct spi_ctrlr spi_flash_ctrlr = {
|
||||
.max_xfer_size = 65535,
|
||||
.flash_probe = mtk_spi_flash_probe,
|
||||
};
|
||||
|
||||
const struct spi_ctrlr_buses spi_ctrlr_bus_map[] = {
|
||||
{
|
||||
.ctrlr = &spi_flash_ctrlr,
|
||||
.bus_start = CONFIG_BOOT_DEVICE_SPI_FLASH_BUS,
|
||||
.bus_end = CONFIG_BOOT_DEVICE_SPI_FLASH_BUS,
|
||||
},
|
||||
};
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue