A low cost DIY sound pressure level sensor for enabling environmental noise awareness. https://lukasschwarz.org/noise-sensor
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

96 lines
1.7 KiB

  1. /**
  2. * Author Wojciech Domski <Wojciech.Domski@gmail.com>
  3. * www: www.Domski.pl
  4. *
  5. * Hardware layer for SX1278 LoRa module
  6. */
  7. #ifndef __SX1278_HW_HEADER
  8. #define __SX1278_HW_HEADER
  9. #include <stdint.h>
  10. typedef struct {
  11. int pin;
  12. void *port;
  13. } SX1278_hw_dio_t;
  14. typedef struct {
  15. SX1278_hw_dio_t reset;
  16. SX1278_hw_dio_t dio0;
  17. SX1278_hw_dio_t nss;
  18. void *spi;
  19. } SX1278_hw_t;
  20. /**
  21. * \brief Initialize hardware layer
  22. *
  23. * Clears NSS and resets LoRa module.
  24. *
  25. * \param[in] hw Pointer to hardware structure
  26. */
  27. void SX1278_hw_init(SX1278_hw_t *hw);
  28. /**
  29. * \brief Control NSS
  30. *
  31. * Clears and sets NSS according to passed value.
  32. *
  33. * \param[in] hw Pointer to hardware structure.
  34. * \param[in] value 1 sets NSS high, other value sets NSS low.
  35. */
  36. void SX1278_hw_SetNSS(SX1278_hw_t *hw, int value);
  37. /**
  38. * \brief Resets LoRa module
  39. *
  40. * Resets LoRa module.
  41. *
  42. * \param[in] hw Pointer to hardware structure
  43. */
  44. void SX1278_hw_Reset(SX1278_hw_t *hw);
  45. /**
  46. * \brief Send command via SPI.
  47. *
  48. * Send single byte via SPI interface.
  49. *
  50. * \param[in] hw Pointer to hardware structure
  51. * \param[in] cmd Command
  52. */
  53. void SX1278_hw_SPICommand(SX1278_hw_t *hw, uint8_t cmd);
  54. /**
  55. * \brief Reads data via SPI
  56. *
  57. * Reads data via SPI interface.
  58. *
  59. * \param[in] hw Pointer to hardware structure
  60. *
  61. * \return Read value
  62. */
  63. uint8_t SX1278_hw_SPIReadByte(SX1278_hw_t *hw);
  64. /**
  65. * \brief ms delay
  66. *
  67. * Milisecond delay.
  68. *
  69. * \param[in] msec Number of milliseconds to wait
  70. */
  71. void SX1278_hw_DelayMs(uint32_t msec);
  72. /**
  73. * \brief Reads DIO0 state
  74. *
  75. * Reads LoRa DIO0 state using GPIO.
  76. *
  77. * \param[in] hw Pointer to hardware structure
  78. *
  79. * \return 0 if DIO0 low, 1 if DIO high
  80. */
  81. int SX1278_hw_GetDIO0(SX1278_hw_t *hw);
  82. #endif