2023-06-27 08:20:45 +08:00

44 lines
1.4 KiB
C

/*
* Copyright (c) 2006-2018, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2021-04-11 RiceChen the first version
*
*/
#include <rthw.h>
#include <rtdevice.h>
#include "board.h"
#include "mmu.h"
#include "ioremap.h"
#include "fsl_iomuxc.h"
#include "drv_common.h"
void *imx6ull_get_periph_vaddr(rt_uint32_t paddr)
{
return rt_ioremap((void *)paddr, sizeof(sizeof(rt_uint32_t)));
}
void *imx6ull_get_periph_paddr(rt_uint32_t vaddr)
{
return rt_kmem_v2p((void *)vaddr);
}
void imx6ull_gpio_init(const struct imx6ull_iomuxc *gpio)
{
rt_uint32_t mux_reg_vaddr = 0;
rt_uint32_t input_reg_vaddr = 0;
rt_uint32_t config_reg_vaddr = 0;
mux_reg_vaddr = (rt_uint32_t)(gpio->muxRegister ? (rt_uint32_t)imx6ull_get_periph_vaddr(gpio->muxRegister) : gpio->muxRegister);
input_reg_vaddr = (rt_uint32_t)(gpio->inputRegister ? (rt_uint32_t)imx6ull_get_periph_vaddr(gpio->inputRegister) : gpio->inputRegister);
config_reg_vaddr = (rt_uint32_t)(gpio->configRegister ? (rt_uint32_t)imx6ull_get_periph_vaddr(gpio->configRegister) : gpio->configRegister);
IOMUXC_SetPinMux(mux_reg_vaddr, gpio->muxMode, input_reg_vaddr, gpio->inputDaisy, config_reg_vaddr, gpio->inputOnfield);
IOMUXC_SetPinConfig(mux_reg_vaddr, gpio->muxMode, input_reg_vaddr, gpio->inputDaisy, config_reg_vaddr, gpio->configValue);
}