您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

123 行
3.4KB

  1. #ifndef _NRF_GPIO_H
  2. #define _NRF_GPIO_H
  3. #include "stm32f10x.h"
  4. #include "spi.h"
  5. //位带操作,实现51类似的GPIO控制功能
  6. //具体实现思想,参考<<CM3权威指南>>第五章(87页~92页).
  7. //IO口操作宏定义
  8. #define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
  9. #define MEM_ADDR(addr) *((volatile unsigned long *)(addr))
  10. #define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum))
  11. //IO口地址映射
  12. #define GPIOA_ODR_Addr (GPIOA_BASE+12) //0x4001080C
  13. #define GPIOB_ODR_Addr (GPIOB_BASE+12) //0x40010C0C
  14. #define GPIOC_ODR_Addr (GPIOC_BASE+12) //0x4001100C
  15. #define GPIOD_ODR_Addr (GPIOD_BASE+12) //0x4001140C
  16. #define GPIOE_ODR_Addr (GPIOE_BASE+12) //0x4001180C
  17. #define GPIOF_ODR_Addr (GPIOF_BASE+12) //0x40011A0C
  18. #define GPIOG_ODR_Addr (GPIOG_BASE+12) //0x40011E0C
  19. #define GPIOA_IDR_Addr (GPIOA_BASE+8) //0x40010808
  20. #define GPIOB_IDR_Addr (GPIOB_BASE+8) //0x40010C08
  21. #define GPIOC_IDR_Addr (GPIOC_BASE+8) //0x40011008
  22. #define GPIOD_IDR_Addr (GPIOD_BASE+8) //0x40011408
  23. #define GPIOE_IDR_Addr (GPIOE_BASE+8) //0x40011808
  24. #define GPIOF_IDR_Addr (GPIOF_BASE+8) //0x40011A08
  25. #define GPIOG_IDR_Addr (GPIOG_BASE+8) //0x40011E08
  26. //IO口操作,只对单一的IO口!
  27. //确保n的值小于16!
  28. #define PAout(n) BIT_ADDR(GPIOA_ODR_Addr,n) //输出
  29. #define PAin(n) BIT_ADDR(GPIOA_IDR_Addr,n) //输入
  30. #define PBout(n) BIT_ADDR(GPIOB_ODR_Addr,n) //输出
  31. #define PBin(n) BIT_ADDR(GPIOB_IDR_Addr,n) //输入
  32. #define PCout(n) BIT_ADDR(GPIOC_ODR_Addr,n) //输出
  33. #define PCin(n) BIT_ADDR(GPIOC_IDR_Addr,n) //输入
  34. #define PDout(n) BIT_ADDR(GPIOD_ODR_Addr,n) //输出
  35. #define PDin(n) BIT_ADDR(GPIOD_IDR_Addr,n) //输入
  36. #define PEout(n) BIT_ADDR(GPIOE_ODR_Addr,n) //输出
  37. #define PEin(n) BIT_ADDR(GPIOE_IDR_Addr,n) //输入
  38. #define PFout(n) BIT_ADDR(GPIOF_ODR_Addr,n) //输出
  39. #define PFin(n) BIT_ADDR(GPIOF_IDR_Addr,n) //输入
  40. #define PGout(n) BIT_ADDR(GPIOG_ODR_Addr,n) //输出
  41. #define PGin(n) BIT_ADDR(GPIOG_IDR_Addr,n) //输入
  42. //--------------------------------------------------------------
  43. // IO Port define
  44. #if 0
  45. #define SPI1_IRQ_Port GPIOA
  46. #define SPI1_IRQ_Pin GPIO_Pin_0
  47. #else
  48. #define SPI1_IRQ_Port GPIOB
  49. #define SPI1_IRQ_Pin GPIO_Pin_7
  50. #endif
  51. #define SPI1_CS_Port GPIOA //PORTA
  52. #define SPI1_CS_Pin GPIO_Pin_4
  53. #define SPI1_SCK_Port GPIOA
  54. #define SPI1_SCK_Pin GPIO_Pin_5
  55. #define SPI1_MISO_Port GPIOA
  56. #define SPI1_MISO_Pin GPIO_Pin_6
  57. #define SPI1_MOSI_Port GPIOA
  58. #define SPI1_MOSI_Pin GPIO_Pin_7
  59. #define SPI1_CE_Port GPIOB // PORTB
  60. #define SPI1_CE_Pin GPIO_Pin_6
  61. //----------------------------------------
  62. #define SPI2_CS_Port GPIOB
  63. #define SPI2_CS_Pin GPIO_Pin_12
  64. #define SPI2_SCK_Port GPIOB
  65. #define SPI2_SCK_Pin GPIO_Pin_13
  66. #define SPI2_MISO_Port GPIOB
  67. #define SPI2_MISO_Pin GPIO_Pin_14
  68. #define SPI2_MOSI_Port GPIOB
  69. #define SPI2_MOSI_Pin GPIO_Pin_15
  70. #define SPI2_CE_Port GPIOB
  71. #define SPI2_CE_Pin GPIO_Pin_9
  72. #define SPI2_IRQ_Port GPIOB
  73. #define SPI2_IRQ_Pin GPIO_Pin_8
  74. //SI24R1----SPI1 位操作
  75. #define SPI1_CE PBout(6) // SPI1 片选信号
  76. #define SPI1_CSN PAout(4) // SPI片选信号
  77. #if 0
  78. #define SPI1_IRQ PAin(0) // IRQ主机数据输入
  79. #else
  80. #define SPI1_IRQ PBin(7) // IRQ主机数据输入
  81. #endif
  82. //SI24R1----SPI2 位操作
  83. #define SPI2_CE PBout(9) // SPI1 片选信号
  84. #define SPI2_CSN PBout(12) // SPI片选信号
  85. #define SPI2_IRQ PBin(8) // IRQ主机数据输入
  86. #endif