| Michael Hennerich | cd1678f | 2012-05-29 12:41:19 +0200 | [diff] [blame] | 1 | /* | 
|  | 2 | * AD9523 SPI Low Jitter Clock Generator | 
|  | 3 | * | 
|  | 4 | * Copyright 2012 Analog Devices Inc. | 
|  | 5 | * | 
|  | 6 | * Licensed under the GPL-2. | 
|  | 7 | */ | 
|  | 8 |  | 
|  | 9 | #ifndef IIO_FREQUENCY_AD9523_H_ | 
|  | 10 | #define IIO_FREQUENCY_AD9523_H_ | 
|  | 11 |  | 
|  | 12 | enum outp_drv_mode { | 
|  | 13 | TRISTATE, | 
|  | 14 | LVPECL_8mA, | 
|  | 15 | LVDS_4mA, | 
|  | 16 | LVDS_7mA, | 
|  | 17 | HSTL0_16mA, | 
|  | 18 | HSTL1_8mA, | 
|  | 19 | CMOS_CONF1, | 
|  | 20 | CMOS_CONF2, | 
|  | 21 | CMOS_CONF3, | 
|  | 22 | CMOS_CONF4, | 
|  | 23 | CMOS_CONF5, | 
|  | 24 | CMOS_CONF6, | 
|  | 25 | CMOS_CONF7, | 
|  | 26 | CMOS_CONF8, | 
|  | 27 | CMOS_CONF9 | 
|  | 28 | }; | 
|  | 29 |  | 
|  | 30 | enum ref_sel_mode { | 
|  | 31 | NONEREVERTIVE_STAY_ON_REFB, | 
|  | 32 | REVERT_TO_REFA, | 
|  | 33 | SELECT_REFA, | 
|  | 34 | SELECT_REFB, | 
|  | 35 | EXT_REF_SEL | 
|  | 36 | }; | 
|  | 37 |  | 
|  | 38 | /** | 
|  | 39 | * struct ad9523_channel_spec - Output channel configuration | 
|  | 40 | * | 
|  | 41 | * @channel_num: Output channel number. | 
|  | 42 | * @divider_output_invert_en: Invert the polarity of the output clock. | 
|  | 43 | * @sync_ignore_en: Ignore chip-level SYNC signal. | 
|  | 44 | * @low_power_mode_en: Reduce power used in the differential output modes. | 
|  | 45 | * @use_alt_clock_src: Channel divider uses alternative clk source. | 
|  | 46 | * @output_dis: Disables, powers down the entire channel. | 
|  | 47 | * @driver_mode: Output driver mode (logic level family). | 
|  | 48 | * @divider_phase: Divider initial phase after a SYNC. Range 0..63 | 
|  | 49 | LSB = 1/2 of a period of the divider input clock. | 
|  | 50 | * @channel_divider: 10-bit channel divider. | 
|  | 51 | * @extended_name: Optional descriptive channel name. | 
|  | 52 | */ | 
|  | 53 |  | 
|  | 54 | struct ad9523_channel_spec { | 
|  | 55 | unsigned		channel_num; | 
|  | 56 | bool			divider_output_invert_en; | 
|  | 57 | bool			sync_ignore_en; | 
|  | 58 | bool			low_power_mode_en; | 
|  | 59 | /* CH0..CH3 VCXO, CH4..CH9 VCO2 */ | 
|  | 60 | bool			use_alt_clock_src; | 
|  | 61 | bool			output_dis; | 
|  | 62 | enum outp_drv_mode	driver_mode; | 
|  | 63 | unsigned char		divider_phase; | 
|  | 64 | unsigned short		channel_divider; | 
|  | 65 | char			extended_name[16]; | 
|  | 66 | }; | 
|  | 67 |  | 
|  | 68 | enum pll1_rzero_resistor { | 
|  | 69 | RZERO_883_OHM, | 
|  | 70 | RZERO_677_OHM, | 
|  | 71 | RZERO_341_OHM, | 
|  | 72 | RZERO_135_OHM, | 
|  | 73 | RZERO_10_OHM, | 
|  | 74 | RZERO_USE_EXT_RES = 8, | 
|  | 75 | }; | 
|  | 76 |  | 
|  | 77 | enum rpole2_resistor { | 
|  | 78 | RPOLE2_900_OHM, | 
|  | 79 | RPOLE2_450_OHM, | 
|  | 80 | RPOLE2_300_OHM, | 
|  | 81 | RPOLE2_225_OHM, | 
|  | 82 | }; | 
|  | 83 |  | 
|  | 84 | enum rzero_resistor { | 
|  | 85 | RZERO_3250_OHM, | 
|  | 86 | RZERO_2750_OHM, | 
|  | 87 | RZERO_2250_OHM, | 
|  | 88 | RZERO_2100_OHM, | 
|  | 89 | RZERO_3000_OHM, | 
|  | 90 | RZERO_2500_OHM, | 
|  | 91 | RZERO_2000_OHM, | 
|  | 92 | RZERO_1850_OHM, | 
|  | 93 | }; | 
|  | 94 |  | 
|  | 95 | enum cpole1_capacitor { | 
|  | 96 | CPOLE1_0_PF, | 
|  | 97 | CPOLE1_8_PF, | 
|  | 98 | CPOLE1_16_PF, | 
|  | 99 | CPOLE1_24_PF, | 
|  | 100 | _CPOLE1_24_PF, /* place holder */ | 
|  | 101 | CPOLE1_32_PF, | 
|  | 102 | CPOLE1_40_PF, | 
|  | 103 | CPOLE1_48_PF, | 
|  | 104 | }; | 
|  | 105 |  | 
|  | 106 | /** | 
|  | 107 | * struct ad9523_platform_data - platform specific information | 
|  | 108 | * | 
|  | 109 | * @vcxo_freq: External VCXO frequency in Hz | 
|  | 110 | * @refa_diff_rcv_en: REFA differential/single-ended input selection. | 
|  | 111 | * @refb_diff_rcv_en: REFB differential/single-ended input selection. | 
|  | 112 | * @zd_in_diff_en: Zero Delay differential/single-ended input selection. | 
|  | 113 | * @osc_in_diff_en: OSC differential/ single-ended input selection. | 
|  | 114 | * @refa_cmos_neg_inp_en: REFA single-ended neg./pos. input enable. | 
|  | 115 | * @refb_cmos_neg_inp_en: REFB single-ended neg./pos. input enable. | 
|  | 116 | * @zd_in_cmos_neg_inp_en: Zero Delay single-ended neg./pos. input enable. | 
|  | 117 | * @osc_in_cmos_neg_inp_en: OSC single-ended neg./pos. input enable. | 
|  | 118 | * @refa_r_div: PLL1 10-bit REFA R divider. | 
|  | 119 | * @refb_r_div: PLL1 10-bit REFB R divider. | 
|  | 120 | * @pll1_feedback_div: PLL1 10-bit Feedback N divider. | 
|  | 121 | * @pll1_charge_pump_current_nA: Magnitude of PLL1 charge pump current (nA). | 
|  | 122 | * @zero_delay_mode_internal_en: Internal, external Zero Delay mode selection. | 
|  | 123 | * @osc_in_feedback_en: PLL1 feedback path, local feedback from | 
|  | 124 | *			the OSC_IN receiver or zero delay mode | 
|  | 125 | * @pll1_loop_filter_rzero: PLL1 Loop Filter Zero Resistor selection. | 
|  | 126 | * @ref_mode: Reference selection mode. | 
|  | 127 | * @pll2_charge_pump_current_nA: Magnitude of PLL2 charge pump current (nA). | 
|  | 128 | * @pll2_ndiv_a_cnt: PLL2 Feedback N-divider, A Counter, range 0..4. | 
|  | 129 | * @pll2_ndiv_b_cnt: PLL2 Feedback N-divider, B Counter, range 0..63. | 
|  | 130 | * @pll2_freq_doubler_en: PLL2 frequency doubler enable. | 
|  | 131 | * @pll2_r2_div: PLL2 R2 divider, range 0..31. | 
|  | 132 | * @pll2_vco_diff_m1: VCO1 divider, range 3..5. | 
|  | 133 | * @pll2_vco_diff_m2: VCO2 divider, range 3..5. | 
|  | 134 | * @rpole2: PLL2 loop filter Rpole resistor value. | 
|  | 135 | * @rzero: PLL2 loop filter Rzero resistor value. | 
|  | 136 | * @cpole1: PLL2 loop filter Cpole capacitor value. | 
|  | 137 | * @rzero_bypass_en: PLL2 loop filter Rzero bypass enable. | 
|  | 138 | * @num_channels: Array size of struct ad9523_channel_spec. | 
|  | 139 | * @channels: Pointer to channel array. | 
|  | 140 | * @name: Optional alternative iio device name. | 
|  | 141 | */ | 
|  | 142 |  | 
|  | 143 | struct ad9523_platform_data { | 
|  | 144 | unsigned long vcxo_freq; | 
|  | 145 |  | 
|  | 146 | /* Differential/ Single-Ended Input Configuration */ | 
|  | 147 | bool				refa_diff_rcv_en; | 
|  | 148 | bool				refb_diff_rcv_en; | 
|  | 149 | bool				zd_in_diff_en; | 
|  | 150 | bool				osc_in_diff_en; | 
|  | 151 |  | 
|  | 152 | /* | 
|  | 153 | * Valid if differential input disabled | 
|  | 154 | * if false defaults to pos input | 
|  | 155 | */ | 
|  | 156 | bool				refa_cmos_neg_inp_en; | 
|  | 157 | bool				refb_cmos_neg_inp_en; | 
|  | 158 | bool				zd_in_cmos_neg_inp_en; | 
|  | 159 | bool				osc_in_cmos_neg_inp_en; | 
|  | 160 |  | 
|  | 161 | /* PLL1 Setting */ | 
|  | 162 | unsigned short			refa_r_div; | 
|  | 163 | unsigned short			refb_r_div; | 
|  | 164 | unsigned short			pll1_feedback_div; | 
|  | 165 | unsigned short			pll1_charge_pump_current_nA; | 
|  | 166 | bool				zero_delay_mode_internal_en; | 
|  | 167 | bool				osc_in_feedback_en; | 
|  | 168 | enum pll1_rzero_resistor	pll1_loop_filter_rzero; | 
|  | 169 |  | 
|  | 170 | /* Reference */ | 
|  | 171 | enum ref_sel_mode		ref_mode; | 
|  | 172 |  | 
|  | 173 | /* PLL2 Setting */ | 
|  | 174 | unsigned int			pll2_charge_pump_current_nA; | 
|  | 175 | unsigned char			pll2_ndiv_a_cnt; | 
|  | 176 | unsigned char			pll2_ndiv_b_cnt; | 
|  | 177 | bool				pll2_freq_doubler_en; | 
|  | 178 | unsigned char			pll2_r2_div; | 
|  | 179 | unsigned char			pll2_vco_diff_m1; /* 3..5 */ | 
|  | 180 | unsigned char			pll2_vco_diff_m2; /* 3..5 */ | 
|  | 181 |  | 
|  | 182 | /* Loop Filter PLL2 */ | 
|  | 183 | enum rpole2_resistor		rpole2; | 
|  | 184 | enum rzero_resistor		rzero; | 
|  | 185 | enum cpole1_capacitor		cpole1; | 
|  | 186 | bool				rzero_bypass_en; | 
|  | 187 |  | 
|  | 188 | /* Output Channel Configuration */ | 
|  | 189 | int				num_channels; | 
|  | 190 | struct ad9523_channel_spec	*channels; | 
|  | 191 |  | 
|  | 192 | char				name[SPI_NAME_SIZE]; | 
|  | 193 | }; | 
|  | 194 |  | 
|  | 195 | #endif /* IIO_FREQUENCY_AD9523_H_ */ |