| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | /*
 | 
					
						
							|  |  |  |     Samsung S5H1409 VSB/QAM demodulator driver | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-03 17:12:12 -03:00
										 |  |  |     Copyright (C) 2006 Steven Toth <stoth@linuxtv.org> | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     This program is free software; you can redistribute it and/or modify | 
					
						
							|  |  |  |     it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |     the Free Software Foundation; either version 2 of the License, or | 
					
						
							|  |  |  |     (at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |     but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |     GNU General Public License for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |     along with this program; if not, write to the Free Software | 
					
						
							|  |  |  |     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-28 20:02:55 -03:00
										 |  |  | #ifndef __S5H1409_H__
 | 
					
						
							|  |  |  | #define __S5H1409_H__
 | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-21 16:11:54 -03:00
										 |  |  | #include <linux/kconfig.h>
 | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | #include <linux/dvb/frontend.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-16 20:27:11 -03:00
										 |  |  | struct s5h1409_config { | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | 	/* the demodulator's i2c address */ | 
					
						
							|  |  |  | 	u8 demod_address; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* serial/parallel output */ | 
					
						
							|  |  |  | #define S5H1409_PARALLEL_OUTPUT 0
 | 
					
						
							|  |  |  | #define S5H1409_SERIAL_OUTPUT   1
 | 
					
						
							|  |  |  | 	u8 output_mode; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* GPIO Setting */ | 
					
						
							|  |  |  | #define S5H1409_GPIO_OFF 0
 | 
					
						
							|  |  |  | #define S5H1409_GPIO_ON  1
 | 
					
						
							|  |  |  | 	u8 gpio; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-13 10:04:10 -03:00
										 |  |  | 	/* IF Freq for QAM in KHz, VSB is hardcoded to 5380 */ | 
					
						
							|  |  |  | 	u16 qam_if; | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Spectral Inversion */ | 
					
						
							|  |  |  | #define S5H1409_INVERSION_OFF 0
 | 
					
						
							|  |  |  | #define S5H1409_INVERSION_ON  1
 | 
					
						
							|  |  |  | 	u8 inversion; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Return lock status based on tuner lock, or demod lock */ | 
					
						
							|  |  |  | #define S5H1409_TUNERLOCKING 0
 | 
					
						
							|  |  |  | #define S5H1409_DEMODLOCKING 1
 | 
					
						
							|  |  |  | 	u8 status_mode; | 
					
						
							| 
									
										
										
										
											2008-01-15 21:35:22 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* MPEG signal timing */ | 
					
						
							|  |  |  | #define S5H1409_MPEGTIMING_CONTINOUS_INVERTING_CLOCK       0
 | 
					
						
							|  |  |  | #define S5H1409_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK    1
 | 
					
						
							|  |  |  | #define S5H1409_MPEGTIMING_NONCONTINOUS_INVERTING_CLOCK    2
 | 
					
						
							|  |  |  | #define S5H1409_MPEGTIMING_NONCONTINOUS_NONINVERTING_CLOCK 3
 | 
					
						
							|  |  |  | 	u16 mpeg_timing; | 
					
						
							| 
									
										
										
										
											2009-10-27 23:33:21 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* HVR-1600 optimizations (to better work with MXL5005s)
 | 
					
						
							|  |  |  | 	   Note: some of these are likely to be folded into the generic driver | 
					
						
							|  |  |  | 	   after being regression tested with other boards */ | 
					
						
							|  |  |  | #define S5H1409_HVR1600_NOOPTIMIZE 0
 | 
					
						
							|  |  |  | #define S5H1409_HVR1600_OPTIMIZE   1
 | 
					
						
							|  |  |  | 	u8 hvr1600_opt; | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-21 16:11:54 -03:00
										 |  |  | #if IS_ENABLED(CONFIG_DVB_S5H1409)
 | 
					
						
							| 
									
										
										
										
											2008-10-16 20:27:11 -03:00
										 |  |  | extern struct dvb_frontend *s5h1409_attach(const struct s5h1409_config *config, | 
					
						
							|  |  |  | 					   struct i2c_adapter *i2c); | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2008-10-16 20:27:11 -03:00
										 |  |  | static inline struct dvb_frontend *s5h1409_attach( | 
					
						
							|  |  |  | 	const struct s5h1409_config *config, | 
					
						
							|  |  |  | 	struct i2c_adapter *i2c) | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-04-08 23:20:00 -03:00
										 |  |  | 	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__); | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | 	return NULL; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2007-07-28 20:02:55 -03:00
										 |  |  | #endif /* CONFIG_DVB_S5H1409 */
 | 
					
						
							| 
									
										
										
										
											2007-07-28 19:34:52 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-28 20:02:55 -03:00
										 |  |  | #endif /* __S5H1409_H__ */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Local variables: | 
					
						
							|  |  |  |  * c-basic-offset: 8 | 
					
						
							|  |  |  |  */ |