drv_common.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. /*
  2. * Copyright (c) 2006-2018, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2021-04-11 RiceChen the first version
  9. *
  10. */
  11. #include <rthw.h>
  12. #include <rtdevice.h>
  13. #include "board.h"
  14. #include "mmu.h"
  15. #include "ioremap.h"
  16. #include "fsl_iomuxc.h"
  17. #include "drv_common.h"
  18. void *imx6ull_get_periph_vaddr(rt_uint32_t paddr)
  19. {
  20. return rt_ioremap((void *)paddr, sizeof(sizeof(rt_uint32_t)));
  21. }
  22. void *imx6ull_get_periph_paddr(rt_uint32_t vaddr)
  23. {
  24. return rt_kmem_v2p((void *)vaddr);
  25. }
  26. void imx6ull_gpio_init(const struct imx6ull_iomuxc *gpio)
  27. {
  28. rt_uint32_t mux_reg_vaddr = 0;
  29. rt_uint32_t input_reg_vaddr = 0;
  30. rt_uint32_t config_reg_vaddr = 0;
  31. mux_reg_vaddr = (rt_uint32_t)(gpio->muxRegister ? (rt_uint32_t)imx6ull_get_periph_vaddr(gpio->muxRegister) : gpio->muxRegister);
  32. input_reg_vaddr = (rt_uint32_t)(gpio->inputRegister ? (rt_uint32_t)imx6ull_get_periph_vaddr(gpio->inputRegister) : gpio->inputRegister);
  33. config_reg_vaddr = (rt_uint32_t)(gpio->configRegister ? (rt_uint32_t)imx6ull_get_periph_vaddr(gpio->configRegister) : gpio->configRegister);
  34. IOMUXC_SetPinMux(mux_reg_vaddr, gpio->muxMode, input_reg_vaddr, gpio->inputDaisy, config_reg_vaddr, gpio->inputOnfield);
  35. IOMUXC_SetPinConfig(mux_reg_vaddr, gpio->muxMode, input_reg_vaddr, gpio->inputDaisy, config_reg_vaddr, gpio->configValue);
  36. }