rtl-sdr.h 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. /*
  2. * rtl-sdr, turns your Realtek RTL2832 based DVB dongle into a SDR receiver
  3. * Copyright (C) 2012 by Steve Markgraf <steve@steve-m.de>
  4. * Copyright (C) 2012 by Dimitri Stolnikov <horiz0n@gmx.net>
  5. *
  6. * This program is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation, either version 2 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. */
  19. #ifndef __RTL_SDR_H
  20. #define __RTL_SDR_H
  21. #ifdef __cplusplus
  22. extern "C" {
  23. #endif
  24. #include <stdint.h>
  25. #include <rtl-sdr_export.h>
  26. typedef struct rtlsdr_dev rtlsdr_dev_t;
  27. RTLSDR_API uint32_t rtlsdr_get_device_count(void);
  28. RTLSDR_API const char* rtlsdr_get_device_name(uint32_t index);
  29. /*!
  30. * Get USB device strings.
  31. *
  32. * NOTE: The string arguments must provide space for up to 256 bytes.
  33. *
  34. * \param index the device index
  35. * \param manufact manufacturer name, may be NULL
  36. * \param product product name, may be NULL
  37. * \param serial serial number, may be NULL
  38. * \return 0 on success
  39. */
  40. RTLSDR_API int rtlsdr_get_device_usb_strings(uint32_t index,
  41. char *manufact,
  42. char *product,
  43. char *serial);
  44. RTLSDR_API int rtlsdr_open(rtlsdr_dev_t **dev, uint32_t index);
  45. RTLSDR_API int rtlsdr_close(rtlsdr_dev_t *dev);
  46. /* configuration functions */
  47. /*!
  48. * Set crystal oscillator frequencies used for the RTL2832 and the tuner IC.
  49. *
  50. * Usually both ICs use the same clock. Changing the clock may make sense if
  51. * you are applying an external clock to the tuner or to compensate the
  52. * frequency (and samplerate) error caused by the original cheap crystal.
  53. *
  54. * NOTE: Call this function only if you know what you are doing.
  55. *
  56. * \param dev the device handle given by rtlsdr_open()
  57. * \param rtl_freq frequency value used to clock the RTL2832 in Hz
  58. * \param tuner_freq frequency value used to clock the tuner IC in Hz
  59. * \return 0 on success
  60. */
  61. RTLSDR_API int rtlsdr_set_xtal_freq(rtlsdr_dev_t *dev, uint32_t rtl_freq,
  62. uint32_t tuner_freq);
  63. /*!
  64. * Get crystal oscillator frequencies used for the RTL2832 and the tuner IC.
  65. *
  66. * Usually both ICs use the same clock.
  67. *
  68. * \param dev the device handle given by rtlsdr_open()
  69. * \param rtl_freq frequency value used to clock the RTL2832 in Hz
  70. * \param tuner_freq frequency value used to clock the tuner IC in Hz
  71. * \return 0 on success
  72. */
  73. RTLSDR_API int rtlsdr_get_xtal_freq(rtlsdr_dev_t *dev, uint32_t *rtl_freq,
  74. uint32_t *tuner_freq);
  75. /*!
  76. * Get USB device strings.
  77. *
  78. * NOTE: The string arguments must provide space for up to 256 bytes.
  79. *
  80. * \param dev the device handle given by rtlsdr_open()
  81. * \param manufact manufacturer name, may be NULL
  82. * \param product product name, may be NULL
  83. * \param serial serial number, may be NULL
  84. * \return 0 on success
  85. */
  86. RTLSDR_API int rtlsdr_get_usb_strings(rtlsdr_dev_t *dev, char *manufact,
  87. char *product, char *serial);
  88. RTLSDR_API int rtlsdr_set_center_freq(rtlsdr_dev_t *dev, uint32_t freq);
  89. /*!
  90. * Get actual frequency the device is tuned to.
  91. *
  92. * \param dev the device handle given by rtlsdr_open()
  93. * \return 0 on error, frequency in Hz otherwise
  94. */
  95. RTLSDR_API uint32_t rtlsdr_get_center_freq(rtlsdr_dev_t *dev);
  96. RTLSDR_API int rtlsdr_set_freq_correction(rtlsdr_dev_t *dev, int ppm);
  97. RTLSDR_API int rtlsdr_get_freq_correction(rtlsdr_dev_t *dev);
  98. enum rtlsdr_tuner {
  99. RTLSDR_TUNER_UNKNOWN = 0,
  100. RTLSDR_TUNER_E4000,
  101. RTLSDR_TUNER_FC0012,
  102. RTLSDR_TUNER_FC0013,
  103. RTLSDR_TUNER_FC2580
  104. };
  105. /*!
  106. * Get the tuner type.
  107. *
  108. * \param dev the device handle given by rtlsdr_open()
  109. * \return <= 0 on error, tuner type otherwise
  110. */
  111. RTLSDR_API enum rtlsdr_tuner rtlsdr_get_tuner_type(rtlsdr_dev_t *dev);
  112. /*!
  113. * Get a list of gains supported by the tuner.
  114. *
  115. * NOTE: The gains argument must be preallocated by the caller. If NULL is
  116. * being given instead, the number of available gain values will be returned.
  117. *
  118. * \param dev the device handle given by rtlsdr_open()
  119. * \param gains array of gain values. In tenths of a dB, 115 means 11.5 dB.
  120. * \return <= 0 on error, number of available (returned) gain values otherwise
  121. */
  122. RTLSDR_API int rtlsdr_get_tuner_gains(rtlsdr_dev_t *dev, int *gains);
  123. /*!
  124. * Set the gain for the device.
  125. * Manual gain mode must be enabled for this to work.
  126. *
  127. * Valid gain values (in tenths of a dB) for the E4000 tuner:
  128. * -10, 15, 40, 65, 90, 115, 140, 165, 190,
  129. * 215, 240, 290, 340, 420, 430, 450, 470, 490
  130. *
  131. * Valid gain values may be queried with \ref rtlsdr_get_tuner_gains function.
  132. *
  133. * \param dev the device handle given by rtlsdr_open()
  134. * \param gain in tenths of a dB, 115 means 11.5 dB.
  135. * \return 0 on success
  136. */
  137. RTLSDR_API int rtlsdr_set_tuner_gain(rtlsdr_dev_t *dev, int gain);
  138. /*!
  139. * Get actual gain the device is configured to.
  140. *
  141. * \param dev the device handle given by rtlsdr_open()
  142. * \return 0 on error, gain in tenths of a dB, 115 means 11.5 dB.
  143. */
  144. RTLSDR_API int rtlsdr_get_tuner_gain(rtlsdr_dev_t *dev);
  145. /*!
  146. * Set the intermediate frequency gain for the device.
  147. *
  148. * \param dev the device handle given by rtlsdr_open()
  149. * \param stage intermediate frequency gain stage number (1 to 6 for E4000)
  150. * \param gain in tenths of a dB, -30 means -3.0 dB.
  151. * \return 0 on success
  152. */
  153. RTLSDR_API int rtlsdr_set_tuner_if_gain(rtlsdr_dev_t *dev, int stage, int gain);
  154. /*!
  155. * Set the gain mode (automatic/manual) for the device.
  156. * Manual gain mode must be enabled for the gain setter function to work.
  157. *
  158. * \param dev the device handle given by rtlsdr_open()
  159. * \param manual gain mode, 1 means manual gain mode shall be enabled.
  160. * \return 0 on success
  161. */
  162. RTLSDR_API int rtlsdr_set_tuner_gain_mode(rtlsdr_dev_t *dev, int manual);
  163. /* this will select the baseband filters according to the requested sample rate */
  164. RTLSDR_API int rtlsdr_set_sample_rate(rtlsdr_dev_t *dev, uint32_t rate);
  165. /*!
  166. * Get actual sample rate the device is configured to.
  167. *
  168. * \param dev the device handle given by rtlsdr_open()
  169. * \return 0 on error, sample rate in Hz otherwise
  170. */
  171. RTLSDR_API uint32_t rtlsdr_get_sample_rate(rtlsdr_dev_t *dev);
  172. /*!
  173. * Enable test mode that returns an 8 bit counter instead of the samples.
  174. * The counter is generated inside the RTL2832.
  175. *
  176. * \param dev the device handle given by rtlsdr_open()
  177. * \param test mode, 1 means enabled, 0 disabled
  178. * \return 0 on success
  179. */
  180. RTLSDR_API int rtlsdr_set_testmode(rtlsdr_dev_t *dev, int on);
  181. /* streaming functions */
  182. RTLSDR_API int rtlsdr_reset_buffer(rtlsdr_dev_t *dev);
  183. RTLSDR_API int rtlsdr_read_sync(rtlsdr_dev_t *dev, void *buf, int len, int *n_read);
  184. typedef void(*rtlsdr_read_async_cb_t)(unsigned char *buf, uint32_t len, void *ctx);
  185. /*!
  186. * Read samples from the device asynchronously. This function will block until
  187. * it is being canceled using rtlsdr_cancel_async()
  188. *
  189. * NOTE: This function is deprecated and is subject for removal.
  190. *
  191. * \param dev the device handle given by rtlsdr_open()
  192. * \param cb callback function to return received samples
  193. * \param ctx user specific context to pass via the callback function
  194. * \return 0 on success
  195. */
  196. RTLSDR_API int rtlsdr_wait_async(rtlsdr_dev_t *dev, rtlsdr_read_async_cb_t cb, void *ctx);
  197. /*!
  198. * Read samples from the device asynchronously. This function will block until
  199. * it is being canceled using rtlsdr_cancel_async()
  200. *
  201. * \param dev the device handle given by rtlsdr_open()
  202. * \param cb callback function to return received samples
  203. * \param ctx user specific context to pass via the callback function
  204. * \param buf_num optional buffer count, buf_num * buf_len = overall buffer size
  205. * set to 0 for default buffer count (32)
  206. * \param buf_len optional buffer length, must be multiple of 512,
  207. * set to 0 for default buffer length (16 * 32 * 512)
  208. * \return 0 on success
  209. */
  210. RTLSDR_API int rtlsdr_read_async(rtlsdr_dev_t *dev,
  211. rtlsdr_read_async_cb_t cb,
  212. void *ctx,
  213. uint32_t buf_num,
  214. uint32_t buf_len);
  215. /*!
  216. * Cancel all pending asynchronous operations on the device.
  217. *
  218. * \param dev the device handle given by rtlsdr_open()
  219. * \return 0 on success
  220. */
  221. RTLSDR_API int rtlsdr_cancel_async(rtlsdr_dev_t *dev);
  222. #ifdef __cplusplus
  223. }
  224. #endif
  225. #endif /* __RTL_SDR_H */