drv_gpio.h 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2020-06-16 guohp1128 first version
  9. */
  10. #ifndef __DRV_GPIO_H__
  11. #define __DRV_GPIO_H__
  12. #include <board.h>
  13. #include <rtdevice.h>
  14. #include <hal/nrf_gpio.h>
  15. #include <drivers/include/nrfx_gpiote.h>
  16. #define __NRF5X_PORT(port) NRF_P##port##_BASE
  17. #define GET_PIN(PORTx,PIN) (rt_base_t)((32 * ( ((rt_base_t)__NRF5X_PORT(PORTx) - (rt_base_t)NRF_P0_BASE)/(0x0300UL) )) + PIN)
  18. #define __NRF5X_PIN(index, gpio, gpio_index) \
  19. { \
  20. index, NRF_P##gpio, gpio_index \
  21. }
  22. #define __NRF5X_PIN_RESERVE \
  23. { \
  24. -1, 0, 0 \
  25. }
  26. /* nrf5x GPIO driver */
  27. struct pin_index
  28. {
  29. int index;
  30. NRF_GPIO_Type *gpio;//NRF_P0 or NRF_P1
  31. uint32_t pin;
  32. };
  33. static void nrf5x_pin_write(rt_device_t dev, rt_base_t pin, rt_base_t value);
  34. static int nrf5x_pin_read(rt_device_t dev, rt_base_t pin);
  35. static void nrf5x_pin_mode(rt_device_t dev, rt_base_t pin, rt_base_t mode);
  36. static rt_err_t nrf5x_pin_attach_irq(struct rt_device *device, rt_int32_t pin,
  37. rt_uint32_t mode, void (*hdr)(void *args), void *args);
  38. static rt_err_t nrf5x_pin_dettach_irq(struct rt_device *device, rt_int32_t pin);
  39. static rt_err_t nrf5x_pin_irq_enable(struct rt_device *device, rt_base_t pin,
  40. rt_uint32_t enabled);
  41. int rt_hw_pin_init(void);
  42. #endif /* __DRV_GPIO_H__ */