cx25840-core.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. /* cx25840 internal API header
  2. *
  3. * Copyright (C) 2003-2004 Chris Kennedy
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU General Public License
  7. * as published by the Free Software Foundation; either version 2
  8. * of the License, or (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18. */
  19. #ifndef _CX25840_CORE_H_
  20. #define _CX25840_CORE_H_
  21. #include <linux/videodev2.h>
  22. #include <media/v4l2-device.h>
  23. #include <media/v4l2-ctrls.h>
  24. #include <linux/i2c.h>
  25. struct cx25840_ir_state;
  26. enum cx25840_model {
  27. CX23885_AV,
  28. CX23887_AV,
  29. CX23888_AV,
  30. CX2310X_AV,
  31. CX25840,
  32. CX25841,
  33. CX25842,
  34. CX25843,
  35. CX25836,
  36. CX25837,
  37. };
  38. enum cx25840_media_pads {
  39. CX25840_PAD_INPUT,
  40. CX25840_PAD_VID_OUT,
  41. CX25840_PAD_VBI_OUT,
  42. CX25840_NUM_PADS
  43. };
  44. struct cx25840_state {
  45. struct i2c_client *c;
  46. struct v4l2_subdev sd;
  47. struct v4l2_ctrl_handler hdl;
  48. struct {
  49. /* volume cluster */
  50. struct v4l2_ctrl *volume;
  51. struct v4l2_ctrl *mute;
  52. };
  53. int pvr150_workaround;
  54. int radio;
  55. v4l2_std_id std;
  56. enum cx25840_video_input vid_input;
  57. enum cx25840_audio_input aud_input;
  58. u32 audclk_freq;
  59. int audmode;
  60. int vbi_line_offset;
  61. enum cx25840_model id;
  62. u32 rev;
  63. int is_initialized;
  64. wait_queue_head_t fw_wait; /* wake up when the fw load is finished */
  65. struct work_struct fw_work; /* work entry for fw load */
  66. struct cx25840_ir_state *ir_state;
  67. #if defined(CONFIG_MEDIA_CONTROLLER)
  68. struct media_pad pads[CX25840_NUM_PADS];
  69. #endif
  70. };
  71. static inline struct cx25840_state *to_state(struct v4l2_subdev *sd)
  72. {
  73. return container_of(sd, struct cx25840_state, sd);
  74. }
  75. static inline struct v4l2_subdev *to_sd(struct v4l2_ctrl *ctrl)
  76. {
  77. return &container_of(ctrl->handler, struct cx25840_state, hdl)->sd;
  78. }
  79. static inline bool is_cx2583x(struct cx25840_state *state)
  80. {
  81. return state->id == CX25836 ||
  82. state->id == CX25837;
  83. }
  84. static inline bool is_cx231xx(struct cx25840_state *state)
  85. {
  86. return state->id == CX2310X_AV;
  87. }
  88. static inline bool is_cx2388x(struct cx25840_state *state)
  89. {
  90. return state->id == CX23885_AV ||
  91. state->id == CX23887_AV ||
  92. state->id == CX23888_AV;
  93. }
  94. static inline bool is_cx23885(struct cx25840_state *state)
  95. {
  96. return state->id == CX23885_AV;
  97. }
  98. static inline bool is_cx23887(struct cx25840_state *state)
  99. {
  100. return state->id == CX23887_AV;
  101. }
  102. static inline bool is_cx23888(struct cx25840_state *state)
  103. {
  104. return state->id == CX23888_AV;
  105. }
  106. /* ----------------------------------------------------------------------- */
  107. /* cx25850-core.c */
  108. int cx25840_write(struct i2c_client *client, u16 addr, u8 value);
  109. int cx25840_write4(struct i2c_client *client, u16 addr, u32 value);
  110. u8 cx25840_read(struct i2c_client *client, u16 addr);
  111. u32 cx25840_read4(struct i2c_client *client, u16 addr);
  112. int cx25840_and_or(struct i2c_client *client, u16 addr, unsigned mask, u8 value);
  113. int cx25840_and_or4(struct i2c_client *client, u16 addr, u32 and_mask,
  114. u32 or_value);
  115. void cx25840_std_setup(struct i2c_client *client);
  116. /* ----------------------------------------------------------------------- */
  117. /* cx25850-firmware.c */
  118. int cx25840_loadfw(struct i2c_client *client);
  119. /* ----------------------------------------------------------------------- */
  120. /* cx25850-audio.c */
  121. void cx25840_audio_set_path(struct i2c_client *client);
  122. int cx25840_s_clock_freq(struct v4l2_subdev *sd, u32 freq);
  123. extern const struct v4l2_ctrl_ops cx25840_audio_ctrl_ops;
  124. /* ----------------------------------------------------------------------- */
  125. /* cx25850-vbi.c */
  126. int cx25840_s_raw_fmt(struct v4l2_subdev *sd, struct v4l2_vbi_format *fmt);
  127. int cx25840_s_sliced_fmt(struct v4l2_subdev *sd, struct v4l2_sliced_vbi_format *fmt);
  128. int cx25840_g_sliced_fmt(struct v4l2_subdev *sd, struct v4l2_sliced_vbi_format *fmt);
  129. int cx25840_decode_vbi_line(struct v4l2_subdev *sd, struct v4l2_decode_vbi_line *vbi);
  130. /* ----------------------------------------------------------------------- */
  131. /* cx25850-ir.c */
  132. extern const struct v4l2_subdev_ir_ops cx25840_ir_ops;
  133. int cx25840_ir_log_status(struct v4l2_subdev *sd);
  134. int cx25840_ir_irq_handler(struct v4l2_subdev *sd, u32 status, bool *handled);
  135. int cx25840_ir_probe(struct v4l2_subdev *sd);
  136. int cx25840_ir_remove(struct v4l2_subdev *sd);
  137. #endif