Mauro Carvalho Chehab | 56fc08c | 2005-06-23 22:05:07 -0700 | [diff] [blame] | 1 | /* |
Mauro Carvalho Chehab | 56fc08c | 2005-06-23 22:05:07 -0700 | [diff] [blame] | 2 | */ |
| 3 | |
Hans Verkuil | 49965a8 | 2006-03-19 08:45:38 -0300 | [diff] [blame] | 4 | #ifndef MSP3400_DRIVER_H |
| 5 | #define MSP3400_DRIVER_H |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 6 | |
Hans Verkuil | 2474ed4 | 2006-03-19 12:35:57 -0300 | [diff] [blame] | 7 | #include <media/msp3400.h> |
Hans Verkuil | 76efd62 | 2008-11-24 18:16:46 -0300 | [diff] [blame] | 8 | #include <media/v4l2-device.h> |
Hans Verkuil | ebc3bba | 2010-05-24 10:01:58 -0300 | [diff] [blame] | 9 | #include <media/v4l2-ctrls.h> |
Hans Verkuil | 2474ed4 | 2006-03-19 12:35:57 -0300 | [diff] [blame] | 10 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 | /* ---------------------------------------------------------------------- */ |
| 12 | |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 13 | /* This macro is allowed for *constants* only, gcc must calculate it |
| 14 | at compile time. Remember -- no floats in kernel mode */ |
| 15 | #define MSP_CARRIER(freq) ((int)((float)(freq / 18.432) * (1 << 24))) |
| 16 | |
| 17 | #define MSP_MODE_AM_DETECT 0 |
| 18 | #define MSP_MODE_FM_RADIO 2 |
| 19 | #define MSP_MODE_FM_TERRA 3 |
| 20 | #define MSP_MODE_FM_SAT 4 |
| 21 | #define MSP_MODE_FM_NICAM1 5 |
| 22 | #define MSP_MODE_FM_NICAM2 6 |
| 23 | #define MSP_MODE_AM_NICAM 7 |
| 24 | #define MSP_MODE_BTSC 8 |
| 25 | #define MSP_MODE_EXTERN 9 |
| 26 | |
Hans Verkuil | 4277257 | 2006-03-19 06:48:51 -0300 | [diff] [blame] | 27 | #define SCART_IN1 0 |
| 28 | #define SCART_IN2 1 |
| 29 | #define SCART_IN3 2 |
| 30 | #define SCART_IN4 3 |
| 31 | #define SCART_IN1_DA 4 |
| 32 | #define SCART_IN2_DA 5 |
| 33 | #define SCART_MONO 6 |
| 34 | #define SCART_MUTE 7 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 35 | |
| 36 | #define SCART_DSP_IN 0 |
| 37 | #define SCART1_OUT 1 |
| 38 | #define SCART2_OUT 2 |
| 39 | |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 40 | #define OPMODE_AUTO -1 |
| 41 | #define OPMODE_MANUAL 0 |
| 42 | #define OPMODE_AUTODETECT 1 /* use autodetect (>= msp3410 only) */ |
| 43 | #define OPMODE_AUTOSELECT 2 /* use autodetect & autoselect (>= msp34xxG) */ |
| 44 | |
| 45 | /* module parameters */ |
Mauro Carvalho Chehab | f167cb4 | 2006-01-11 19:41:49 -0200 | [diff] [blame] | 46 | extern int msp_debug; |
| 47 | extern int msp_once; |
| 48 | extern int msp_amsound; |
| 49 | extern int msp_standard; |
| 50 | extern int msp_dolby; |
| 51 | extern int msp_stereo_thresh; |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 52 | |
| 53 | struct msp_state { |
Hans Verkuil | 76efd62 | 2008-11-24 18:16:46 -0300 | [diff] [blame] | 54 | struct v4l2_subdev sd; |
Hans Verkuil | ebc3bba | 2010-05-24 10:01:58 -0300 | [diff] [blame] | 55 | struct v4l2_ctrl_handler hdl; |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 56 | int rev1, rev2; |
Hans Verkuil | 74cab31 | 2007-04-27 12:31:26 -0300 | [diff] [blame] | 57 | int ident; |
Hans Verkuil | 5af0c8f | 2006-01-09 18:21:37 -0200 | [diff] [blame] | 58 | u8 has_nicam; |
| 59 | u8 has_radio; |
| 60 | u8 has_headphones; |
| 61 | u8 has_ntsc_jp_d_k3; |
Hans Verkuil | 0020d3e | 2006-03-30 19:50:34 -0300 | [diff] [blame] | 62 | u8 has_scart2; |
| 63 | u8 has_scart3; |
Hans Verkuil | 5af0c8f | 2006-01-09 18:21:37 -0200 | [diff] [blame] | 64 | u8 has_scart4; |
Hans Verkuil | 0020d3e | 2006-03-30 19:50:34 -0300 | [diff] [blame] | 65 | u8 has_scart2_out; |
Hans Verkuil | 5af0c8f | 2006-01-09 18:21:37 -0200 | [diff] [blame] | 66 | u8 has_scart2_out_volume; |
| 67 | u8 has_i2s_conf; |
| 68 | u8 has_subwoofer; |
| 69 | u8 has_sound_processing; |
| 70 | u8 has_virtual_dolby_surround; |
| 71 | u8 has_dolby_pro_logic; |
Hans Verkuil | de98cda | 2006-10-01 17:56:32 -0300 | [diff] [blame] | 72 | u8 force_btsc; |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 73 | |
Hans Verkuil | 7560d7a | 2006-01-09 18:21:32 -0200 | [diff] [blame] | 74 | int radio; |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 75 | int opmode; |
Hans Verkuil | 5af0c8f | 2006-01-09 18:21:37 -0200 | [diff] [blame] | 76 | int std; |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 77 | int mode; |
Hans Verkuil | 5af0c8f | 2006-01-09 18:21:37 -0200 | [diff] [blame] | 78 | v4l2_std_id v4l2_std; |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 79 | int nicam_on; |
| 80 | int acb; |
| 81 | int in_scart; |
| 82 | int i2s_mode; |
| 83 | int main, second; /* sound carrier */ |
| 84 | int input; |
Hans Verkuil | 5325b42 | 2009-04-02 11:26:22 -0300 | [diff] [blame] | 85 | u32 route_in; |
| 86 | u32 route_out; |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 87 | |
| 88 | /* v4l2 */ |
| 89 | int audmode; |
| 90 | int rxsubchans; |
| 91 | |
Hans Verkuil | ebc3bba | 2010-05-24 10:01:58 -0300 | [diff] [blame] | 92 | struct { |
| 93 | /* volume cluster */ |
| 94 | struct v4l2_ctrl *volume; |
| 95 | struct v4l2_ctrl *muted; |
| 96 | }; |
| 97 | |
Hans Verkuil | 3bbe5a8 | 2006-04-01 15:27:52 -0300 | [diff] [blame] | 98 | int scan_in_progress; |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 99 | |
| 100 | /* thread */ |
| 101 | struct task_struct *kthread; |
| 102 | wait_queue_head_t wq; |
Randy Dunlap | 0a11537 | 2006-06-28 15:05:11 -0300 | [diff] [blame] | 103 | unsigned int restart:1; |
| 104 | unsigned int watch_stereo:1; |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 105 | }; |
| 106 | |
Hans Verkuil | 76efd62 | 2008-11-24 18:16:46 -0300 | [diff] [blame] | 107 | static inline struct msp_state *to_state(struct v4l2_subdev *sd) |
| 108 | { |
| 109 | return container_of(sd, struct msp_state, sd); |
| 110 | } |
| 111 | |
Hans Verkuil | ebc3bba | 2010-05-24 10:01:58 -0300 | [diff] [blame] | 112 | static inline struct msp_state *ctrl_to_state(struct v4l2_ctrl *ctrl) |
| 113 | { |
| 114 | return container_of(ctrl->handler, struct msp_state, hdl); |
| 115 | } |
| 116 | |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 117 | /* msp3400-driver.c */ |
| 118 | int msp_write_dem(struct i2c_client *client, int addr, int val); |
| 119 | int msp_write_dsp(struct i2c_client *client, int addr, int val); |
| 120 | int msp_read_dem(struct i2c_client *client, int addr); |
| 121 | int msp_read_dsp(struct i2c_client *client, int addr); |
| 122 | int msp_reset(struct i2c_client *client); |
| 123 | void msp_set_scart(struct i2c_client *client, int in, int out); |
Hans Verkuil | ebc3bba | 2010-05-24 10:01:58 -0300 | [diff] [blame] | 124 | void msp_update_volume(struct msp_state *state); |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 125 | int msp_sleep(struct msp_state *state, int timeout); |
| 126 | |
| 127 | /* msp3400-kthreads.c */ |
Hans Verkuil | 5af0c8f | 2006-01-09 18:21:37 -0200 | [diff] [blame] | 128 | const char *msp_standard_std_name(int std); |
Hans Verkuil | 8a4b275 | 2006-01-23 17:11:09 -0200 | [diff] [blame] | 129 | void msp_set_audmode(struct i2c_client *client); |
Hans Verkuil | de533cc | 2006-03-19 08:21:56 -0300 | [diff] [blame] | 130 | int msp_detect_stereo(struct i2c_client *client); |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 131 | int msp3400c_thread(void *data); |
| 132 | int msp3410d_thread(void *data); |
| 133 | int msp34xxg_thread(void *data); |
Hans Verkuil | 8a4b275 | 2006-01-23 17:11:09 -0200 | [diff] [blame] | 134 | void msp3400c_set_mode(struct i2c_client *client, int mode); |
| 135 | void msp3400c_set_carrier(struct i2c_client *client, int cdo1, int cdo2); |
Hans Verkuil | 53b0a1c | 2006-01-09 15:32:39 -0200 | [diff] [blame] | 136 | |
Hans Verkuil | 49965a8 | 2006-03-19 08:45:38 -0300 | [diff] [blame] | 137 | #endif /* MSP3400_DRIVER_H */ |