si476x-platform.h 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. /*
  2. * include/media/si476x-platform.h -- Platform data specific definitions
  3. *
  4. * Copyright (C) 2013 Andrey Smirnov
  5. *
  6. * Author: Andrey Smirnov <andrew.smirnov@gmail.com>
  7. *
  8. * This program is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation; version 2 of the License.
  11. *
  12. * This program is distributed in the hope that it will be useful, but
  13. * WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * General Public License for more details.
  16. *
  17. */
  18. #ifndef __SI476X_PLATFORM_H__
  19. #define __SI476X_PLATFORM_H__
  20. /* It is possible to select one of the four adresses using pins A0
  21. * and A1 on SI476x */
  22. #define SI476X_I2C_ADDR_1 0x60
  23. #define SI476X_I2C_ADDR_2 0x61
  24. #define SI476X_I2C_ADDR_3 0x62
  25. #define SI476X_I2C_ADDR_4 0x63
  26. enum si476x_iqclk_config {
  27. SI476X_IQCLK_NOOP = 0,
  28. SI476X_IQCLK_TRISTATE = 1,
  29. SI476X_IQCLK_IQ = 21,
  30. };
  31. enum si476x_iqfs_config {
  32. SI476X_IQFS_NOOP = 0,
  33. SI476X_IQFS_TRISTATE = 1,
  34. SI476X_IQFS_IQ = 21,
  35. };
  36. enum si476x_iout_config {
  37. SI476X_IOUT_NOOP = 0,
  38. SI476X_IOUT_TRISTATE = 1,
  39. SI476X_IOUT_OUTPUT = 22,
  40. };
  41. enum si476x_qout_config {
  42. SI476X_QOUT_NOOP = 0,
  43. SI476X_QOUT_TRISTATE = 1,
  44. SI476X_QOUT_OUTPUT = 22,
  45. };
  46. enum si476x_dclk_config {
  47. SI476X_DCLK_NOOP = 0,
  48. SI476X_DCLK_TRISTATE = 1,
  49. SI476X_DCLK_DAUDIO = 10,
  50. };
  51. enum si476x_dfs_config {
  52. SI476X_DFS_NOOP = 0,
  53. SI476X_DFS_TRISTATE = 1,
  54. SI476X_DFS_DAUDIO = 10,
  55. };
  56. enum si476x_dout_config {
  57. SI476X_DOUT_NOOP = 0,
  58. SI476X_DOUT_TRISTATE = 1,
  59. SI476X_DOUT_I2S_OUTPUT = 12,
  60. SI476X_DOUT_I2S_INPUT = 13,
  61. };
  62. enum si476x_xout_config {
  63. SI476X_XOUT_NOOP = 0,
  64. SI476X_XOUT_TRISTATE = 1,
  65. SI476X_XOUT_I2S_INPUT = 13,
  66. SI476X_XOUT_MODE_SELECT = 23,
  67. };
  68. enum si476x_icin_config {
  69. SI476X_ICIN_NOOP = 0,
  70. SI476X_ICIN_TRISTATE = 1,
  71. SI476X_ICIN_GPO1_HIGH = 2,
  72. SI476X_ICIN_GPO1_LOW = 3,
  73. SI476X_ICIN_IC_LINK = 30,
  74. };
  75. enum si476x_icip_config {
  76. SI476X_ICIP_NOOP = 0,
  77. SI476X_ICIP_TRISTATE = 1,
  78. SI476X_ICIP_GPO2_HIGH = 2,
  79. SI476X_ICIP_GPO2_LOW = 3,
  80. SI476X_ICIP_IC_LINK = 30,
  81. };
  82. enum si476x_icon_config {
  83. SI476X_ICON_NOOP = 0,
  84. SI476X_ICON_TRISTATE = 1,
  85. SI476X_ICON_I2S = 10,
  86. SI476X_ICON_IC_LINK = 30,
  87. };
  88. enum si476x_icop_config {
  89. SI476X_ICOP_NOOP = 0,
  90. SI476X_ICOP_TRISTATE = 1,
  91. SI476X_ICOP_I2S = 10,
  92. SI476X_ICOP_IC_LINK = 30,
  93. };
  94. enum si476x_lrout_config {
  95. SI476X_LROUT_NOOP = 0,
  96. SI476X_LROUT_TRISTATE = 1,
  97. SI476X_LROUT_AUDIO = 2,
  98. SI476X_LROUT_MPX = 3,
  99. };
  100. enum si476x_intb_config {
  101. SI476X_INTB_NOOP = 0,
  102. SI476X_INTB_TRISTATE = 1,
  103. SI476X_INTB_DAUDIO = 10,
  104. SI476X_INTB_IRQ = 40,
  105. };
  106. enum si476x_a1_config {
  107. SI476X_A1_NOOP = 0,
  108. SI476X_A1_TRISTATE = 1,
  109. SI476X_A1_IRQ = 40,
  110. };
  111. struct si476x_pinmux {
  112. enum si476x_dclk_config dclk;
  113. enum si476x_dfs_config dfs;
  114. enum si476x_dout_config dout;
  115. enum si476x_xout_config xout;
  116. enum si476x_iqclk_config iqclk;
  117. enum si476x_iqfs_config iqfs;
  118. enum si476x_iout_config iout;
  119. enum si476x_qout_config qout;
  120. enum si476x_icin_config icin;
  121. enum si476x_icip_config icip;
  122. enum si476x_icon_config icon;
  123. enum si476x_icop_config icop;
  124. enum si476x_lrout_config lrout;
  125. enum si476x_intb_config intb;
  126. enum si476x_a1_config a1;
  127. };
  128. enum si476x_ibias6x {
  129. SI476X_IBIAS6X_OTHER = 0,
  130. SI476X_IBIAS6X_RCVR1_NON_4MHZ_CLK = 1,
  131. };
  132. enum si476x_xstart {
  133. SI476X_XSTART_MULTIPLE_TUNER = 0x11,
  134. SI476X_XSTART_NORMAL = 0x77,
  135. };
  136. enum si476x_freq {
  137. SI476X_FREQ_4_MHZ = 0,
  138. SI476X_FREQ_37P209375_MHZ = 1,
  139. SI476X_FREQ_36P4_MHZ = 2,
  140. SI476X_FREQ_37P8_MHZ = 3,
  141. };
  142. enum si476x_xmode {
  143. SI476X_XMODE_CRYSTAL_RCVR1 = 1,
  144. SI476X_XMODE_EXT_CLOCK = 2,
  145. SI476X_XMODE_CRYSTAL_RCVR2_3 = 3,
  146. };
  147. enum si476x_xbiashc {
  148. SI476X_XBIASHC_SINGLE_RECEIVER = 0,
  149. SI476X_XBIASHC_MULTIPLE_RECEIVER = 1,
  150. };
  151. enum si476x_xbias {
  152. SI476X_XBIAS_RCVR2_3 = 0,
  153. SI476X_XBIAS_4MHZ_RCVR1 = 3,
  154. SI476X_XBIAS_RCVR1 = 7,
  155. };
  156. enum si476x_func {
  157. SI476X_FUNC_BOOTLOADER = 0,
  158. SI476X_FUNC_FM_RECEIVER = 1,
  159. SI476X_FUNC_AM_RECEIVER = 2,
  160. SI476X_FUNC_WB_RECEIVER = 3,
  161. };
  162. /**
  163. * @xcload: Selects the amount of additional on-chip capacitance to
  164. * be connected between XTAL1 and gnd and between XTAL2 and
  165. * GND. One half of the capacitance value shown here is the
  166. * additional load capacitance presented to the xtal. The
  167. * minimum step size is 0.277 pF. Recommended value is 0x28
  168. * but it will be layout dependent. Range is 0–0x3F i.e.
  169. * (0–16.33 pF)
  170. * @ctsien: enable CTSINT(interrupt request when CTS condition
  171. * arises) when set
  172. * @intsel: when set A1 pin becomes the interrupt pin; otherwise,
  173. * INTB is the interrupt pin
  174. * @func: selects the boot function of the device. I.e.
  175. * SI476X_BOOTLOADER - Boot loader
  176. * SI476X_FM_RECEIVER - FM receiver
  177. * SI476X_AM_RECEIVER - AM receiver
  178. * SI476X_WB_RECEIVER - Weatherband receiver
  179. * @freq: oscillator's crystal frequency:
  180. * SI476X_XTAL_37P209375_MHZ - 37.209375 Mhz
  181. * SI476X_XTAL_36P4_MHZ - 36.4 Mhz
  182. * SI476X_XTAL_37P8_MHZ - 37.8 Mhz
  183. */
  184. struct si476x_power_up_args {
  185. enum si476x_ibias6x ibias6x;
  186. enum si476x_xstart xstart;
  187. u8 xcload;
  188. bool fastboot;
  189. enum si476x_xbiashc xbiashc;
  190. enum si476x_xbias xbias;
  191. enum si476x_func func;
  192. enum si476x_freq freq;
  193. enum si476x_xmode xmode;
  194. };
  195. /**
  196. * enum si476x_phase_diversity_mode - possbile phase diversity modes
  197. * for SI4764/5/6/7 chips.
  198. *
  199. * @SI476X_PHDIV_DISABLED: Phase diversity feature is
  200. * disabled.
  201. * @SI476X_PHDIV_PRIMARY_COMBINING: Tuner works as a primary tuner
  202. * in combination with a
  203. * secondary one.
  204. * @SI476X_PHDIV_PRIMARY_ANTENNA: Tuner works as a primary tuner
  205. * using only its own antenna.
  206. * @SI476X_PHDIV_SECONDARY_ANTENNA: Tuner works as a primary tuner
  207. * usning seconary tuner's antenna.
  208. * @SI476X_PHDIV_SECONDARY_COMBINING: Tuner works as a secondary
  209. * tuner in combination with the
  210. * primary one.
  211. */
  212. enum si476x_phase_diversity_mode {
  213. SI476X_PHDIV_DISABLED = 0,
  214. SI476X_PHDIV_PRIMARY_COMBINING = 1,
  215. SI476X_PHDIV_PRIMARY_ANTENNA = 2,
  216. SI476X_PHDIV_SECONDARY_ANTENNA = 3,
  217. SI476X_PHDIV_SECONDARY_COMBINING = 5,
  218. };
  219. /*
  220. * Platform dependent definition
  221. */
  222. struct si476x_platform_data {
  223. int gpio_reset; /* < 0 if not used */
  224. struct si476x_power_up_args power_up_parameters;
  225. enum si476x_phase_diversity_mode diversity_mode;
  226. struct si476x_pinmux pinmux;
  227. };
  228. #endif /* __SI476X_PLATFORM_H__ */