blob: 4a7f362c5e3ab316b4a5352b28c9df33cec49a5a [file] [log] [blame]
wdenkc6097192002-11-03 00:24:07 +00001/*
2 * (C) Copyright 2002
3 * Custom IDEAS, Inc. <www.cideas.com>
4 * Jon Diekema <diekema@cideas.com>
5 *
6 * See file CREDITS for list of people who contributed to this
7 * project.
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License as
11 * published by the Free Software Foundation; either version 2 of
12 * the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
22 * MA 02111-1307 USA
23 */
24
25#include <common.h>
26#include <ioports.h>
27#include <mpc8260.h>
28#include <asm/cpm_8260.h>
29#include <configs/sacsng.h>
30
31#include "clkinit.h"
32
Wolfgang Denkd87080b2006-03-31 18:32:53 +020033DECLARE_GLOBAL_DATA_PTR;
34
wdenkc6097192002-11-03 00:24:07 +000035int Daq64xSampling = 0;
36
37
38void Daq_BRG_Reset(uint brg)
39{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020040 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +000041 volatile uint *brg_ptr;
42
43 brg_ptr = (uint *)&immr->im_brgc1;
44
45 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +000046 brg_ptr = (uint *)&immr->im_brgc5;
47 brg -= 4;
wdenkc6097192002-11-03 00:24:07 +000048 }
49 brg_ptr += brg;
50 *brg_ptr |= CPM_BRG_RST;
51 *brg_ptr &= ~CPM_BRG_RST;
52}
53
54void Daq_BRG_Disable(uint brg)
55{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020056 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +000057 volatile uint *brg_ptr;
58
59 brg_ptr = (uint *)&immr->im_brgc1;
60
61 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +000062 brg_ptr = (uint *)&immr->im_brgc5;
63 brg -= 4;
wdenkc6097192002-11-03 00:24:07 +000064 }
65 brg_ptr += brg;
66 *brg_ptr &= ~CPM_BRG_EN;
67}
68
69void Daq_BRG_Enable(uint brg)
70{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020071 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +000072 volatile uint *brg_ptr;
73
74 brg_ptr = (uint *)&immr->im_brgc1;
75 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +000076 brg_ptr = (uint *)&immr->im_brgc5;
77 brg -= 4;
wdenkc6097192002-11-03 00:24:07 +000078 }
79 brg_ptr += brg;
80 *brg_ptr |= CPM_BRG_EN;
81}
82
83uint Daq_BRG_Get_Div16(uint brg)
84{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020085 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +000086 uint *brg_ptr;
87
88 brg_ptr = (uint *)&immr->im_brgc1;
89 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +000090 brg_ptr = (uint *)&immr->im_brgc5;
91 brg -= 4;
wdenkc6097192002-11-03 00:24:07 +000092 }
93 brg_ptr += brg;
94
95 if (*brg_ptr & CPM_BRG_DIV16) {
wdenk8bde7f72003-06-27 21:31:46 +000096 /* DIV16 active */
97 return (TRUE);
wdenkc6097192002-11-03 00:24:07 +000098 }
99 else {
wdenk8bde7f72003-06-27 21:31:46 +0000100 /* DIV16 inactive */
101 return (FALSE);
wdenkc6097192002-11-03 00:24:07 +0000102 }
103}
104
105void Daq_BRG_Set_Div16(uint brg, uint div16)
106{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200107 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +0000108 uint *brg_ptr;
109
110 brg_ptr = (uint *)&immr->im_brgc1;
111 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +0000112 brg_ptr = (uint *)&immr->im_brgc5;
113 brg -= 4;
wdenkc6097192002-11-03 00:24:07 +0000114 }
115 brg_ptr += brg;
116
117 if (div16) {
wdenk8bde7f72003-06-27 21:31:46 +0000118 /* DIV16 active */
119 *brg_ptr |= CPM_BRG_DIV16;
wdenkc6097192002-11-03 00:24:07 +0000120 }
121 else {
wdenk8bde7f72003-06-27 21:31:46 +0000122 /* DIV16 inactive */
123 *brg_ptr &= ~CPM_BRG_DIV16;
wdenkc6097192002-11-03 00:24:07 +0000124 }
125}
126
127uint Daq_BRG_Get_Count(uint brg)
128{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200129 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +0000130 uint *brg_ptr;
131 uint brg_cnt;
132
133 brg_ptr = (uint *)&immr->im_brgc1;
134 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +0000135 brg_ptr = (uint *)&immr->im_brgc5;
136 brg -= 4;
wdenkc6097192002-11-03 00:24:07 +0000137 }
138 brg_ptr += brg;
139
140 /* Get the clock divider
141 *
142 * Note: A clock divider of 0 means divide by 1,
143 * therefore we need to add 1 to the count.
144 */
145 brg_cnt = (*brg_ptr & CPM_BRG_CD_MASK) >> CPM_BRG_DIV16_SHIFT;
146 brg_cnt++;
147 if (*brg_ptr & CPM_BRG_DIV16) {
wdenk8bde7f72003-06-27 21:31:46 +0000148 brg_cnt *= 16;
wdenkc6097192002-11-03 00:24:07 +0000149 }
150
151 return (brg_cnt);
152}
153
154void Daq_BRG_Set_Count(uint brg, uint brg_cnt)
155{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200156 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +0000157 uint *brg_ptr;
158
159 brg_ptr = (uint *)&immr->im_brgc1;
160 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +0000161 brg_ptr = (uint *)&immr->im_brgc5;
162 brg -= 4;
wdenkc6097192002-11-03 00:24:07 +0000163 }
164 brg_ptr += brg;
165
166 /*
167 * Note: A clock divider of 0 means divide by 1,
168 * therefore we need to subtract 1 from the count.
169 */
170 if (brg_cnt > 4096) {
wdenk8bde7f72003-06-27 21:31:46 +0000171 /* Prescale = Divide by 16 */
172 *brg_ptr = (*brg_ptr & ~CPM_BRG_CD_MASK) |
wdenkc6097192002-11-03 00:24:07 +0000173 (((brg_cnt / 16) - 1) << CPM_BRG_DIV16_SHIFT);
174 *brg_ptr |= CPM_BRG_DIV16;
175 }
176 else {
wdenk8bde7f72003-06-27 21:31:46 +0000177 /* Prescale = Divide by 1 */
178 *brg_ptr = (*brg_ptr & ~CPM_BRG_CD_MASK) |
wdenkc6097192002-11-03 00:24:07 +0000179 ((brg_cnt - 1) << CPM_BRG_DIV16_SHIFT);
180 *brg_ptr &= ~CPM_BRG_DIV16;
181 }
182}
183
184uint Daq_BRG_Get_ExtClk(uint brg)
185{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200186 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +0000187 uint *brg_ptr;
188
189 brg_ptr = (uint *)&immr->im_brgc1;
190 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +0000191 brg_ptr = (uint *)&immr->im_brgc5;
192 brg -= 4;
wdenkc6097192002-11-03 00:24:07 +0000193 }
194 brg_ptr += brg;
195
196 return ((*brg_ptr & CPM_BRG_EXTC_MASK) >> CPM_BRG_EXTC_SHIFT);
197}
198
199char* Daq_BRG_Get_ExtClk_Description(uint brg)
200{
201 uint extc;
202
203 extc = Daq_BRG_Get_ExtClk(brg);
204
205 switch (brg + 1) {
wdenk8bde7f72003-06-27 21:31:46 +0000206 case 1:
207 case 2:
208 case 5:
209 case 6: {
210 switch (extc) {
211 case 0: {
212 return ("BRG_INT");
213 }
214 case 1: {
215 return ("CLK3");
216 }
217 case 2: {
218 return ("CLK5");
219 }
220 }
221 return ("??1245??");
222 }
223 case 3:
224 case 4:
225 case 7:
226 case 8: {
227 switch (extc) {
228 case 0: {
229 return ("BRG_INT");
230 }
231 case 1: {
232 return ("CLK9");
233 }
234 case 2: {
235 return ("CLK15");
236 }
237 }
238 return ("??3478??");
239 }
wdenkc6097192002-11-03 00:24:07 +0000240 }
241 return ("??9876??");
242}
243
244void Daq_BRG_Set_ExtClk(uint brg, uint extc)
245{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200246 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +0000247 uint *brg_ptr;
248
249 brg_ptr = (uint *)&immr->im_brgc1;
250 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +0000251 brg_ptr = (uint *)&immr->im_brgc5;
252 brg -= 4;
wdenkc6097192002-11-03 00:24:07 +0000253 }
254 brg_ptr += brg;
255
256 *brg_ptr = (*brg_ptr & ~CPM_BRG_EXTC_MASK) |
wdenk8bde7f72003-06-27 21:31:46 +0000257 ((extc << CPM_BRG_EXTC_SHIFT) & CPM_BRG_EXTC_MASK);
wdenkc6097192002-11-03 00:24:07 +0000258}
259
260uint Daq_BRG_Rate(uint brg)
261{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200262 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +0000263 uint *brg_ptr;
264 uint brg_cnt;
265 uint brg_freq = 0;
266
267 brg_ptr = (uint *)&immr->im_brgc1;
268 brg_ptr += brg;
269 if (brg >= 5) {
wdenk8bde7f72003-06-27 21:31:46 +0000270 brg_ptr = (uint *)&immr->im_brgc5;
271 brg_ptr += (brg - 4);
wdenkc6097192002-11-03 00:24:07 +0000272 }
273
274 brg_cnt = Daq_BRG_Get_Count(brg);
275
276 switch (Daq_BRG_Get_ExtClk(brg)) {
wdenk8bde7f72003-06-27 21:31:46 +0000277 case CPM_BRG_EXTC_CLK3:
278 case CPM_BRG_EXTC_CLK5: {
wdenkc6097192002-11-03 00:24:07 +0000279 brg_freq = brg_cnt;
280 break;
281 }
282 default: {
283 brg_freq = (uint)BRG_INT_CLK / brg_cnt;
284 }
285 }
286 return (brg_freq);
287}
288
289uint Daq_Get_SampleRate(void)
wdenkc6097192002-11-03 00:24:07 +0000290{
291 /*
292 * Read the BRG's to return the actual sample rate.
293 */
294 return (Daq_BRG_Rate(MCLK_BRG) / (MCLK_DIVISOR * SCLK_DIVISOR));
295}
296
wdenkeb9401e2002-11-11 02:11:37 +0000297void Daq_Init_Clocks(int sample_rate, int sample_64x)
wdenkc6097192002-11-03 00:24:07 +0000298{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200299 volatile ioport_t *iopa = ioport_addr((immap_t *)CONFIG_SYS_IMMR, 0 /* port A */);
wdenkeb9401e2002-11-11 02:11:37 +0000300 uint mclk_divisor; /* MCLK divisor */
wdenk8bde7f72003-06-27 21:31:46 +0000301 int flag; /* Interrupt state */
wdenkc6097192002-11-03 00:24:07 +0000302
303 /* Save off the clocking data */
304 Daq64xSampling = sample_64x;
305
306 /*
307 * Limit the sample rate to some sensible values.
308 */
wdenkeb9401e2002-11-11 02:11:37 +0000309 if (sample_rate > MAX_64x_SAMPLE_RATE) {
wdenk8bde7f72003-06-27 21:31:46 +0000310 sample_rate = MAX_64x_SAMPLE_RATE;
wdenkc6097192002-11-03 00:24:07 +0000311 }
312 if (sample_rate < MIN_SAMPLE_RATE) {
wdenk8bde7f72003-06-27 21:31:46 +0000313 sample_rate = MIN_SAMPLE_RATE;
wdenkc6097192002-11-03 00:24:07 +0000314 }
315
316 /*
317 * Initialize the MCLK/SCLK/LRCLK baud rate generators.
318 */
319
320 /* Setup MCLK */
321 Daq_BRG_Set_ExtClk(MCLK_BRG, CPM_BRG_EXTC_BRGCLK);
322
323 /* Setup SCLK */
324# ifdef RUN_SCLK_ON_BRG_INT
wdenk8bde7f72003-06-27 21:31:46 +0000325 Daq_BRG_Set_ExtClk(SCLK_BRG, CPM_BRG_EXTC_BRGCLK);
wdenkc6097192002-11-03 00:24:07 +0000326# else
wdenk8bde7f72003-06-27 21:31:46 +0000327 Daq_BRG_Set_ExtClk(SCLK_BRG, CPM_BRG_EXTC_CLK9);
wdenkc6097192002-11-03 00:24:07 +0000328# endif
329
330 /* Setup LRCLK */
331# ifdef RUN_LRCLK_ON_BRG_INT
wdenk8bde7f72003-06-27 21:31:46 +0000332 Daq_BRG_Set_ExtClk(LRCLK_BRG, CPM_BRG_EXTC_BRGCLK);
wdenkc6097192002-11-03 00:24:07 +0000333# else
wdenk8bde7f72003-06-27 21:31:46 +0000334 Daq_BRG_Set_ExtClk(LRCLK_BRG, CPM_BRG_EXTC_CLK5);
wdenkc6097192002-11-03 00:24:07 +0000335# endif
336
wdenkeb9401e2002-11-11 02:11:37 +0000337 /*
338 * Dynamically adjust MCLK based on the new sample rate.
339 */
340
341 /* Compute the divisors */
342 mclk_divisor = BRG_INT_CLK / (sample_rate * MCLK_DIVISOR * SCLK_DIVISOR);
343
344 /*
345 * Disable interrupt and save the current state
346 */
347 flag = disable_interrupts();
348
349 /* Setup MCLK */
350 Daq_BRG_Set_Count(MCLK_BRG, mclk_divisor);
351
352 /* Setup SCLK */
353# ifdef RUN_SCLK_ON_BRG_INT
354 Daq_BRG_Set_Count(SCLK_BRG, mclk_divisor * MCLK_DIVISOR);
355# else
356 Daq_BRG_Set_Count(SCLK_BRG, MCLK_DIVISOR);
357# endif
358
359# ifdef RUN_LRCLK_ON_BRG_INT
wdenk8bde7f72003-06-27 21:31:46 +0000360 Daq_BRG_Set_Count(LRCLK_BRG,
wdenkeb9401e2002-11-11 02:11:37 +0000361 mclk_divisor * MCLK_DIVISOR * SCLK_DIVISOR);
362# else
363 Daq_BRG_Set_Count(LRCLK_BRG, SCLK_DIVISOR);
364# endif
365
366 /*
367 * Restore the Interrupt state
368 */
369 if (flag) {
wdenk8bde7f72003-06-27 21:31:46 +0000370 enable_interrupts();
wdenkeb9401e2002-11-11 02:11:37 +0000371 }
wdenkc6097192002-11-03 00:24:07 +0000372
373 /* Enable the clock drivers */
374 iopa->pdat &= ~SLRCLK_EN_MASK;
375}
376
377void Daq_Stop_Clocks(void)
378
379{
380#ifdef TIGHTEN_UP_BRG_TIMING
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200381 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkeb9401e2002-11-11 02:11:37 +0000382 register uint mclk_brg; /* MCLK BRG value */
383 register uint sclk_brg; /* SCLK BRG value */
384 register uint lrclk_brg; /* LRCLK BRG value */
385 unsigned long flag; /* Interrupt flags */
wdenkc6097192002-11-03 00:24:07 +0000386#endif
387
388# ifdef TIGHTEN_UP_BRG_TIMING
wdenk8bde7f72003-06-27 21:31:46 +0000389 /*
390 * Obtain MCLK BRG reset/disabled value
391 */
wdenkc6097192002-11-03 00:24:07 +0000392# if (MCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000393 mclk_brg = (*IM_BRGC1 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000394# endif
395# if (MCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000396 mclk_brg = (*IM_BRGC2 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000397# endif
398# if (MCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000399 mclk_brg = (*IM_BRGC3 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000400# endif
401# if (MCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000402 mclk_brg = (*IM_BRGC4 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000403# endif
404# if (MCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000405 mclk_brg = (*IM_BRGC5 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000406# endif
407# if (MCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000408 mclk_brg = (*IM_BRGC6 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000409# endif
410# if (MCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000411 mclk_brg = (*IM_BRGC7 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000412# endif
413# if (MCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000414 mclk_brg = (*IM_BRGC8 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000415# endif
416
wdenk8bde7f72003-06-27 21:31:46 +0000417 /*
418 * Obtain SCLK BRG reset/disabled value
419 */
wdenkc6097192002-11-03 00:24:07 +0000420# if (SCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000421 sclk_brg = (*IM_BRGC1 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000422# endif
423# if (SCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000424 sclk_brg = (*IM_BRGC2 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000425# endif
426# if (SCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000427 sclk_brg = (*IM_BRGC3 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000428# endif
429# if (SCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000430 sclk_brg = (*IM_BRGC4 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000431# endif
432# if (SCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000433 sclk_brg = (*IM_BRGC5 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000434# endif
435# if (SCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000436 sclk_brg = (*IM_BRGC6 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000437# endif
438# if (SCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000439 sclk_brg = (*IM_BRGC7 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000440# endif
441# if (SCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000442 sclk_brg = (*IM_BRGC8 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000443# endif
444
wdenk8bde7f72003-06-27 21:31:46 +0000445 /*
446 * Obtain LRCLK BRG reset/disabled value
447 */
wdenkc6097192002-11-03 00:24:07 +0000448# if (LRCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000449 lrclk_brg = (*IM_BRGC1 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000450# endif
451# if (LRCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000452 lrclk_brg = (*IM_BRGC2 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000453# endif
454# if (LRCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000455 lrclk_brg = (*IM_BRGC3 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000456# endif
457# if (LRCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000458 lrclk_brg = (*IM_BRGC4 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000459# endif
460# if (LRCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000461 lrclk_brg = (*IM_BRGC5 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000462# endif
463# if (LRCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000464 lrclk_brg = (*IM_BRGC6 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000465# endif
466# if (LRCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000467 lrclk_brg = (*IM_BRGC7 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000468# endif
469# if (LRCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000470 lrclk_brg = (*IM_BRGC8 | CPM_BRG_RST) & ~CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000471# endif
wdenk8bde7f72003-06-27 21:31:46 +0000472
wdenkeb9401e2002-11-11 02:11:37 +0000473 /*
474 * Disable interrupt and save the current state
475 */
476 flag = disable_interrupts();
477
wdenk8bde7f72003-06-27 21:31:46 +0000478 /*
479 * Set reset on MCLK BRG
480 */
wdenkeb9401e2002-11-11 02:11:37 +0000481# if (MCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000482 *IM_BRGC1 = mclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000483# endif
484# if (MCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000485 *IM_BRGC2 = mclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000486# endif
487# if (MCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000488 *IM_BRGC3 = mclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000489# endif
490# if (MCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000491 *IM_BRGC4 = mclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000492# endif
493# if (MCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000494 *IM_BRGC5 = mclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000495# endif
496# if (MCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000497 *IM_BRGC6 = mclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000498# endif
499# if (MCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000500 *IM_BRGC7 = mclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000501# endif
502# if (MCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000503 *IM_BRGC8 = mclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000504# endif
505
wdenk8bde7f72003-06-27 21:31:46 +0000506 /*
507 * Set reset on SCLK BRG
508 */
wdenkeb9401e2002-11-11 02:11:37 +0000509# if (SCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000510 *IM_BRGC1 = sclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000511# endif
512# if (SCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000513 *IM_BRGC2 = sclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000514# endif
515# if (SCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000516 *IM_BRGC3 = sclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000517# endif
518# if (SCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000519 *IM_BRGC4 = sclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000520# endif
521# if (SCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000522 *IM_BRGC5 = sclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000523# endif
524# if (SCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000525 *IM_BRGC6 = sclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000526# endif
527# if (SCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000528 *IM_BRGC7 = sclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000529# endif
530# if (SCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000531 *IM_BRGC8 = sclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000532# endif
533
wdenk8bde7f72003-06-27 21:31:46 +0000534 /*
535 * Set reset on LRCLK BRG
536 */
wdenkeb9401e2002-11-11 02:11:37 +0000537# if (LRCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000538 *IM_BRGC1 = lrclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000539# endif
540# if (LRCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000541 *IM_BRGC2 = lrclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000542# endif
543# if (LRCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000544 *IM_BRGC3 = lrclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000545# endif
546# if (LRCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000547 *IM_BRGC4 = lrclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000548# endif
549# if (LRCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000550 *IM_BRGC5 = lrclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000551# endif
552# if (LRCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000553 *IM_BRGC6 = lrclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000554# endif
555# if (LRCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000556 *IM_BRGC7 = lrclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000557# endif
558# if (LRCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000559 *IM_BRGC8 = lrclk_brg;
wdenkeb9401e2002-11-11 02:11:37 +0000560# endif
wdenk8bde7f72003-06-27 21:31:46 +0000561
562 /*
563 * Clear reset on MCLK BRG
564 */
wdenkeb9401e2002-11-11 02:11:37 +0000565# if (MCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000566 *IM_BRGC1 = mclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000567# endif
568# if (MCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000569 *IM_BRGC2 = mclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000570# endif
571# if (MCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000572 *IM_BRGC3 = mclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000573# endif
574# if (MCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000575 *IM_BRGC4 = mclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000576# endif
577# if (MCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000578 *IM_BRGC5 = mclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000579# endif
580# if (MCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000581 *IM_BRGC6 = mclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000582# endif
583# if (MCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000584 *IM_BRGC7 = mclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000585# endif
586# if (MCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000587 *IM_BRGC8 = mclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000588# endif
589
wdenk8bde7f72003-06-27 21:31:46 +0000590 /*
591 * Clear reset on SCLK BRG
592 */
wdenkeb9401e2002-11-11 02:11:37 +0000593# if (SCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000594 *IM_BRGC1 = sclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000595# endif
596# if (SCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000597 *IM_BRGC2 = sclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000598# endif
599# if (SCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000600 *IM_BRGC3 = sclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000601# endif
602# if (SCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000603 *IM_BRGC4 = sclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000604# endif
605# if (SCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000606 *IM_BRGC5 = sclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000607# endif
608# if (SCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000609 *IM_BRGC6 = sclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000610# endif
611# if (SCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000612 *IM_BRGC7 = sclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000613# endif
614# if (SCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000615 *IM_BRGC8 = sclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000616# endif
617
wdenk8bde7f72003-06-27 21:31:46 +0000618 /*
619 * Clear reset on LRCLK BRG
620 */
wdenkeb9401e2002-11-11 02:11:37 +0000621# if (LRCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000622 *IM_BRGC1 = lrclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000623# endif
624# if (LRCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000625 *IM_BRGC2 = lrclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000626# endif
627# if (LRCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000628 *IM_BRGC3 = lrclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000629# endif
630# if (LRCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000631 *IM_BRGC4 = lrclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000632# endif
633# if (LRCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000634 *IM_BRGC5 = lrclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000635# endif
636# if (LRCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000637 *IM_BRGC6 = lrclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000638# endif
639# if (LRCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000640 *IM_BRGC7 = lrclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000641# endif
642# if (LRCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000643 *IM_BRGC8 = lrclk_brg & ~CPM_BRG_RST;
wdenkeb9401e2002-11-11 02:11:37 +0000644# endif
wdenk8bde7f72003-06-27 21:31:46 +0000645
wdenkeb9401e2002-11-11 02:11:37 +0000646 /*
647 * Restore the Interrupt state
648 */
649 if (flag) {
wdenk8bde7f72003-06-27 21:31:46 +0000650 enable_interrupts();
wdenkeb9401e2002-11-11 02:11:37 +0000651 }
wdenkc6097192002-11-03 00:24:07 +0000652# else
wdenk8bde7f72003-06-27 21:31:46 +0000653 /*
654 * Reset the clocks
655 */
656 Daq_BRG_Reset(MCLK_BRG);
657 Daq_BRG_Reset(SCLK_BRG);
658 Daq_BRG_Reset(LRCLK_BRG);
wdenkc6097192002-11-03 00:24:07 +0000659# endif
660}
661
662void Daq_Start_Clocks(int sample_rate)
663
664{
665#ifdef TIGHTEN_UP_BRG_TIMING
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200666 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +0000667
wdenkeb9401e2002-11-11 02:11:37 +0000668 register uint mclk_brg; /* MCLK BRG value */
669 register uint sclk_brg; /* SCLK BRG value */
670 register uint temp_lrclk_brg; /* Temporary LRCLK BRG value */
671 register uint real_lrclk_brg; /* Permanent LRCLK BRG value */
wdenkc6097192002-11-03 00:24:07 +0000672 uint lrclk_brg; /* LRCLK BRG value */
wdenkc6097192002-11-03 00:24:07 +0000673 unsigned long flags; /* Interrupt flags */
674 uint sclk_cnt; /* SCLK count */
675 uint delay_cnt; /* Delay count */
676#endif
677
678# ifdef TIGHTEN_UP_BRG_TIMING
wdenk8bde7f72003-06-27 21:31:46 +0000679 /*
680 * Obtain the enabled MCLK BRG value
681 */
wdenkc6097192002-11-03 00:24:07 +0000682# if (MCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000683 mclk_brg = (*IM_BRGC1 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000684# endif
685# if (MCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000686 mclk_brg = (*IM_BRGC2 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000687# endif
688# if (MCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000689 mclk_brg = (*IM_BRGC3 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000690# endif
691# if (MCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000692 mclk_brg = (*IM_BRGC4 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000693# endif
694# if (MCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000695 mclk_brg = (*IM_BRGC5 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000696# endif
697# if (MCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000698 mclk_brg = (*IM_BRGC6 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000699# endif
700# if (MCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000701 mclk_brg = (*IM_BRGC7 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000702# endif
703# if (MCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000704 mclk_brg = (*IM_BRGC8 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000705# endif
706
wdenk8bde7f72003-06-27 21:31:46 +0000707 /*
708 * Obtain the enabled SCLK BRG value
709 */
wdenkc6097192002-11-03 00:24:07 +0000710# if (SCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000711 sclk_brg = (*IM_BRGC1 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000712# endif
713# if (SCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000714 sclk_brg = (*IM_BRGC2 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000715# endif
716# if (SCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000717 sclk_brg = (*IM_BRGC3 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000718# endif
719# if (SCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000720 sclk_brg = (*IM_BRGC4 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000721# endif
722# if (SCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000723 sclk_brg = (*IM_BRGC5 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000724# endif
725# if (SCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000726 sclk_brg = (*IM_BRGC6 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000727# endif
728# if (SCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000729 sclk_brg = (*IM_BRGC7 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000730# endif
731# if (SCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000732 sclk_brg = (*IM_BRGC8 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000733# endif
734
wdenk8bde7f72003-06-27 21:31:46 +0000735 /*
736 * Obtain the enabled LRCLK BRG value
737 */
wdenkc6097192002-11-03 00:24:07 +0000738# if (LRCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000739 lrclk_brg = (*IM_BRGC1 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000740# endif
741# if (LRCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000742 lrclk_brg = (*IM_BRGC2 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000743# endif
744# if (LRCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000745 lrclk_brg = (*IM_BRGC3 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000746# endif
747# if (LRCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000748 lrclk_brg = (*IM_BRGC4 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000749# endif
750# if (LRCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000751 lrclk_brg = (*IM_BRGC5 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000752# endif
753# if (LRCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000754 lrclk_brg = (*IM_BRGC6 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000755# endif
756# if (LRCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000757 lrclk_brg = (*IM_BRGC7 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000758# endif
759# if (LRCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000760 lrclk_brg = (*IM_BRGC8 & ~CPM_BRG_RST) | CPM_BRG_EN;
wdenkc6097192002-11-03 00:24:07 +0000761# endif
762
763 /* Save off the real LRCLK value */
764 real_lrclk_brg = lrclk_brg;
765
766 /* Obtain the current SCLK count */
767 sclk_cnt = ((sclk_brg & 0x00001FFE) >> 1) + 1;
768
769 /* Compute the delay as a function of SCLK count */
wdenk8bde7f72003-06-27 21:31:46 +0000770 delay_cnt = ((sclk_cnt / 4) - 2) * 10 + 6;
wdenkeb9401e2002-11-11 02:11:37 +0000771 if (DaqSampleRate == 43402) {
wdenkc6097192002-11-03 00:24:07 +0000772 delay_cnt++;
773 }
774
wdenk8bde7f72003-06-27 21:31:46 +0000775 /* Clear out the count */
wdenkc6097192002-11-03 00:24:07 +0000776 temp_lrclk_brg = sclk_brg & ~0x00001FFE;
777
wdenk8bde7f72003-06-27 21:31:46 +0000778 /* Insert the count */
wdenkc6097192002-11-03 00:24:07 +0000779 temp_lrclk_brg |= ((delay_cnt + (sclk_cnt / 2) - 1) << 1) & 0x00001FFE;
780
wdenkeb9401e2002-11-11 02:11:37 +0000781 /*
782 * Disable interrupt and save the current state
783 */
784 flag = disable_interrupts();
785
wdenk8bde7f72003-06-27 21:31:46 +0000786 /*
787 * Enable MCLK BRG
788 */
wdenkc6097192002-11-03 00:24:07 +0000789# if (MCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000790 *IM_BRGC1 = mclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000791# endif
792# if (MCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000793 *IM_BRGC2 = mclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000794# endif
795# if (MCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000796 *IM_BRGC3 = mclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000797# endif
798# if (MCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000799 *IM_BRGC4 = mclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000800# endif
801# if (MCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000802 *IM_BRGC5 = mclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000803# endif
804# if (MCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000805 *IM_BRGC6 = mclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000806# endif
807# if (MCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000808 *IM_BRGC7 = mclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000809# endif
810# if (MCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000811 *IM_BRGC8 = mclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000812# endif
813
wdenk8bde7f72003-06-27 21:31:46 +0000814 /*
815 * Enable SCLK BRG
816 */
wdenkc6097192002-11-03 00:24:07 +0000817# if (SCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000818 *IM_BRGC1 = sclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000819# endif
820# if (SCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000821 *IM_BRGC2 = sclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000822# endif
823# if (SCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000824 *IM_BRGC3 = sclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000825# endif
826# if (SCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000827 *IM_BRGC4 = sclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000828# endif
829# if (SCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000830 *IM_BRGC5 = sclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000831# endif
832# if (SCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000833 *IM_BRGC6 = sclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000834# endif
835# if (SCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000836 *IM_BRGC7 = sclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000837# endif
838# if (SCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000839 *IM_BRGC8 = sclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000840# endif
841
wdenk8bde7f72003-06-27 21:31:46 +0000842 /*
843 * Enable LRCLK BRG (1st time - temporary)
844 */
wdenkc6097192002-11-03 00:24:07 +0000845# if (LRCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000846 *IM_BRGC1 = temp_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000847# endif
848# if (LRCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000849 *IM_BRGC2 = temp_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000850# endif
851# if (LRCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000852 *IM_BRGC3 = temp_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000853# endif
854# if (LRCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000855 *IM_BRGC4 = temp_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000856# endif
857# if (LRCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000858 *IM_BRGC5 = temp_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000859# endif
860# if (LRCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000861 *IM_BRGC6 = temp_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000862# endif
863# if (LRCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000864 *IM_BRGC7 = temp_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000865# endif
866# if (LRCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000867 *IM_BRGC8 = temp_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000868# endif
wdenk8bde7f72003-06-27 21:31:46 +0000869
870 /*
871 * Enable LRCLK BRG (2nd time - permanent)
872 */
wdenkc6097192002-11-03 00:24:07 +0000873# if (LRCLK_BRG == 0)
wdenk8bde7f72003-06-27 21:31:46 +0000874 *IM_BRGC1 = real_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000875# endif
876# if (LRCLK_BRG == 1)
wdenk8bde7f72003-06-27 21:31:46 +0000877 *IM_BRGC2 = real_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000878# endif
879# if (LRCLK_BRG == 2)
wdenk8bde7f72003-06-27 21:31:46 +0000880 *IM_BRGC3 = real_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000881# endif
882# if (LRCLK_BRG == 3)
wdenk8bde7f72003-06-27 21:31:46 +0000883 *IM_BRGC4 = real_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000884# endif
885# if (LRCLK_BRG == 4)
wdenk8bde7f72003-06-27 21:31:46 +0000886 *IM_BRGC5 = real_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000887# endif
888# if (LRCLK_BRG == 5)
wdenk8bde7f72003-06-27 21:31:46 +0000889 *IM_BRGC6 = real_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000890# endif
891# if (LRCLK_BRG == 6)
wdenk8bde7f72003-06-27 21:31:46 +0000892 *IM_BRGC7 = real_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000893# endif
894# if (LRCLK_BRG == 7)
wdenk8bde7f72003-06-27 21:31:46 +0000895 *IM_BRGC8 = real_lrclk_brg;
wdenkc6097192002-11-03 00:24:07 +0000896# endif
wdenkeb9401e2002-11-11 02:11:37 +0000897
898 /*
899 * Restore the Interrupt state
900 */
901 if (flag) {
902 enable_interrupts();
wdenk8bde7f72003-06-27 21:31:46 +0000903 }
wdenkc6097192002-11-03 00:24:07 +0000904# else
wdenk8bde7f72003-06-27 21:31:46 +0000905 /*
906 * Enable the clocks
907 */
908 Daq_BRG_Enable(LRCLK_BRG);
909 Daq_BRG_Enable(SCLK_BRG);
910 Daq_BRG_Enable(MCLK_BRG);
wdenkc6097192002-11-03 00:24:07 +0000911# endif
912}
913
914void Daq_Display_Clocks(void)
915
916{
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200917 volatile immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
wdenkc6097192002-11-03 00:24:07 +0000918 uint mclk_divisor; /* Detected MCLK divisor */
919 uint sclk_divisor; /* Detected SCLK divisor */
920
921 printf("\nBRG:\n");
922 if (immr->im_brgc4 != 0) {
wdenk8bde7f72003-06-27 21:31:46 +0000923 printf("\tbrgc4\t0x%08x @ 0x%08x, %5d count, %d extc, %8s, MCLK\n",
wdenkc6097192002-11-03 00:24:07 +0000924 immr->im_brgc4,
925 (uint)&(immr->im_brgc4),
926 Daq_BRG_Get_Count(3),
927 Daq_BRG_Get_ExtClk(3),
928 Daq_BRG_Get_ExtClk_Description(3));
929 }
930 if (immr->im_brgc8 != 0) {
wdenk8bde7f72003-06-27 21:31:46 +0000931 printf("\tbrgc8\t0x%08x @ 0x%08x, %5d count, %d extc, %8s, SCLK\n",
wdenkc6097192002-11-03 00:24:07 +0000932 immr->im_brgc8,
933 (uint)&(immr->im_brgc8),
934 Daq_BRG_Get_Count(7),
935 Daq_BRG_Get_ExtClk(7),
936 Daq_BRG_Get_ExtClk_Description(7));
937 }
938 if (immr->im_brgc6 != 0) {
wdenk8bde7f72003-06-27 21:31:46 +0000939 printf("\tbrgc6\t0x%08x @ 0x%08x, %5d count, %d extc, %8s, LRCLK\n",
wdenkc6097192002-11-03 00:24:07 +0000940 immr->im_brgc6,
941 (uint)&(immr->im_brgc6),
942 Daq_BRG_Get_Count(5),
943 Daq_BRG_Get_ExtClk(5),
944 Daq_BRG_Get_ExtClk_Description(5));
945 }
946 if (immr->im_brgc1 != 0) {
wdenk8bde7f72003-06-27 21:31:46 +0000947 printf("\tbrgc1\t0x%08x @ 0x%08x, %5d count, %d extc, %8s, SMC1\n",
wdenkc6097192002-11-03 00:24:07 +0000948 immr->im_brgc1,
949 (uint)&(immr->im_brgc1),
950 Daq_BRG_Get_Count(0),
951 Daq_BRG_Get_ExtClk(0),
952 Daq_BRG_Get_ExtClk_Description(0));
953 }
954 if (immr->im_brgc2 != 0) {
wdenk8bde7f72003-06-27 21:31:46 +0000955 printf("\tbrgc2\t0x%08x @ 0x%08x, %5d count, %d extc, %8s, SMC2\n",
wdenkc6097192002-11-03 00:24:07 +0000956 immr->im_brgc2,
957 (uint)&(immr->im_brgc2),
958 Daq_BRG_Get_Count(1),
959 Daq_BRG_Get_ExtClk(1),
960 Daq_BRG_Get_ExtClk_Description(1));
961 }
962 if (immr->im_brgc3 != 0) {
wdenk8bde7f72003-06-27 21:31:46 +0000963 printf("\tbrgc3\t0x%08x @ 0x%08x, %5d count, %d extc, %8s, SCC1\n",
wdenkc6097192002-11-03 00:24:07 +0000964 immr->im_brgc3,
965 (uint)&(immr->im_brgc3),
966 Daq_BRG_Get_Count(2),
967 Daq_BRG_Get_ExtClk(2),
968 Daq_BRG_Get_ExtClk_Description(2));
969 }
970 if (immr->im_brgc5 != 0) {
wdenk8bde7f72003-06-27 21:31:46 +0000971 printf("\tbrgc5\t0x%08x @ 0x%08x, %5d count, %d extc, %8s\n",
wdenkc6097192002-11-03 00:24:07 +0000972 immr->im_brgc5,
973 (uint)&(immr->im_brgc5),
974 Daq_BRG_Get_Count(4),
975 Daq_BRG_Get_ExtClk(4),
976 Daq_BRG_Get_ExtClk_Description(4));
977 }
978 if (immr->im_brgc7 != 0) {
wdenk8bde7f72003-06-27 21:31:46 +0000979 printf("\tbrgc7\t0x%08x @ 0x%08x, %5d count, %d extc, %8s\n",
wdenkc6097192002-11-03 00:24:07 +0000980 immr->im_brgc7,
981 (uint)&(immr->im_brgc7),
982 Daq_BRG_Get_Count(6),
983 Daq_BRG_Get_ExtClk(6),
984 Daq_BRG_Get_ExtClk_Description(6));
985 }
986
987# ifdef RUN_SCLK_ON_BRG_INT
wdenk8bde7f72003-06-27 21:31:46 +0000988 mclk_divisor = Daq_BRG_Rate(MCLK_BRG) / Daq_BRG_Rate(SCLK_BRG);
wdenkc6097192002-11-03 00:24:07 +0000989# else
wdenk8bde7f72003-06-27 21:31:46 +0000990 mclk_divisor = Daq_BRG_Get_Count(SCLK_BRG);
wdenkc6097192002-11-03 00:24:07 +0000991# endif
992# ifdef RUN_LRCLK_ON_BRG_INT
wdenk8bde7f72003-06-27 21:31:46 +0000993 sclk_divisor = Daq_BRG_Rate(SCLK_BRG) / Daq_BRG_Rate(LRCLK_BRG);
wdenkc6097192002-11-03 00:24:07 +0000994# else
wdenk8bde7f72003-06-27 21:31:46 +0000995 sclk_divisor = Daq_BRG_Get_Count(LRCLK_BRG);
wdenkc6097192002-11-03 00:24:07 +0000996# endif
997
998 printf("\nADC/DAC Clocking (%d/%d):\n", sclk_divisor, mclk_divisor);
999 printf("\tMCLK %8d Hz, or %3dx SCLK, or %3dx LRCLK\n",
1000 Daq_BRG_Rate(MCLK_BRG),
1001 mclk_divisor,
1002 mclk_divisor * sclk_divisor);
1003# ifdef RUN_SCLK_ON_BRG_INT
wdenk8bde7f72003-06-27 21:31:46 +00001004 printf("\tSCLK %8d Hz, or %3dx LRCLK\n",
wdenkc6097192002-11-03 00:24:07 +00001005 Daq_BRG_Rate(SCLK_BRG),
1006 sclk_divisor);
1007# else
wdenk8bde7f72003-06-27 21:31:46 +00001008 printf("\tSCLK %8d Hz, or %3dx LRCLK\n",
wdenkc6097192002-11-03 00:24:07 +00001009 Daq_BRG_Rate(MCLK_BRG) / mclk_divisor,
1010 sclk_divisor);
1011# endif
1012# ifdef RUN_LRCLK_ON_BRG_INT
wdenk8bde7f72003-06-27 21:31:46 +00001013 printf("\tLRCLK %8d Hz\n",
wdenkc6097192002-11-03 00:24:07 +00001014 Daq_BRG_Rate(LRCLK_BRG));
1015# else
1016# ifdef RUN_SCLK_ON_BRG_INT
wdenk8bde7f72003-06-27 21:31:46 +00001017 printf("\tLRCLK %8d Hz\n",
wdenkc6097192002-11-03 00:24:07 +00001018 Daq_BRG_Rate(SCLK_BRG) / sclk_divisor);
1019# else
wdenk8bde7f72003-06-27 21:31:46 +00001020 printf("\tLRCLK %8d Hz\n",
wdenkc6097192002-11-03 00:24:07 +00001021 Daq_BRG_Rate(MCLK_BRG) / (mclk_divisor * sclk_divisor));
1022# endif
1023# endif
1024 printf("\n");
1025}