Rev 2 | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
2 | pj | 1 | /***************************************************************************** |
2 | * Filename: DAC.C * * |
||
3 | * Author: Marco Ziglioli (Doctor Stein) * * |
||
4 | * Date: 06/06/2001 * * |
||
5 | * Description: Digital 2 analog conversion functions * |
||
6 | *----------------------------------------------------------------------------* |
||
7 | * Notes: Only module one of Analog Output Timing Module are programmed yet * |
||
8 | * No waveform staging and local buffer mode with pauses are * |
||
9 | * implemented yet * |
||
10 | * Please refer to STC-DAC Technical Reference Manual and PCI E-Series * |
||
11 | * Programmer Level Manual for further information * |
||
12 | *****************************************************************************/ |
||
13 | |||
14 | /* This file is part of the S.Ha.R.K. Project - http://shark.sssup.it |
||
15 | * |
||
16 | * Copyright (C) 2001 Marco Ziglioli |
||
17 | * |
||
18 | * This program is free software; you can redistribute it and/or modify |
||
19 | * it under the terms of the GNU General Public License as published by |
||
20 | * the Free Software Foundation; either version 2 of the License, or |
||
21 | * (at your option) any later version. |
||
22 | * |
||
23 | * This program is distributed in the hope that it will be useful, |
||
24 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
||
25 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||
26 | * GNU General Public License for more details. |
||
27 | * |
||
28 | * You should have received a copy of the GNU General Public License |
||
29 | * along with this program; if not, write to the Free Software |
||
30 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
||
31 | * |
||
32 | */ |
||
33 | |||
34 | |||
35 | |||
36 | #include <drivers/pci6025e/dac.h> |
||
37 | |||
38 | //Software copies of useful registers |
||
39 | static WORD ao_command_1, ao_command_2, ao_personal, ao_mode_1, ao_mode_2, |
||
40 | ao_mode_3, ao_output_control, ao_start_select, ao_trigger_select; |
||
41 | |||
42 | static BYTE DAC_Initialized = 0; |
||
43 | |||
44 | /***************************************************************************** |
||
45 | * void DAC_reset(void) * |
||
46 | *----------------------------------------------------------------------------* |
||
47 | * Reset both two DACs and the timing system * |
||
48 | *****************************************************************************/ |
||
49 | void DAC_reset(void) |
||
50 | { |
||
51 | set(joint_reset, 5); //Enable AOTM configuration |
||
52 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
53 | clr(joint_reset, 5); |
||
54 | |||
55 | //Disarm Timing module |
||
56 | set(ao_command_1, 13); |
||
57 | DAQ_STC_Windowed_Mode_Write(AO_COMMAND_1, ao_command_1); |
||
58 | clr(ao_command_1, 13); |
||
59 | |||
60 | //Clear all registers |
||
61 | DAQ_STC_Windowed_Mode_Write(AO_PERSONAL, 0x0000); |
||
62 | DAQ_STC_Windowed_Mode_Write(AO_COMMAND_1, 0x0000); |
||
63 | DAQ_STC_Windowed_Mode_Write(AO_COMMAND_2, 0x0000); |
||
64 | DAQ_STC_Windowed_Mode_Write(AO_MODE_1, 0x0000); |
||
65 | DAQ_STC_Windowed_Mode_Write(AO_MODE_2, 0x0000); |
||
66 | DAQ_STC_Windowed_Mode_Write(AO_MODE_3, 0x0000); |
||
67 | DAQ_STC_Windowed_Mode_Write(AO_OUTPUT_CONTROL, 0x0000); |
||
68 | DAQ_STC_Windowed_Mode_Write(AO_START_SELECT, 0x0000); |
||
69 | DAQ_STC_Windowed_Mode_Write(AO_TRIGGER_SELECT, 0x0000); |
||
70 | |||
71 | //Clear software copies |
||
72 | ao_personal = ao_command_1 = ao_command_2 = ao_mode_1 = ao_mode_2 = |
||
73 | ao_mode_3 = ao_output_control = ao_start_select = ao_trigger_select = 0; |
||
74 | |||
75 | //Disable related interrupt flags |
||
76 | interrupt_b_enable &= 0xFE80; |
||
77 | DAQ_STC_Windowed_Mode_Write(INTERRUPT_B_ENABLE, interrupt_b_enable); |
||
78 | |||
79 | //Enable related interrupt request flags |
||
80 | interrupt_b_ack |= 0x3F98; |
||
81 | DAQ_STC_Windowed_Mode_Write(INTERRUPT_B_ACK, interrupt_b_ack); |
||
82 | |||
83 | set(ao_personal, 4); |
||
84 | DAQ_STC_Windowed_Mode_Write(AO_PERSONAL, ao_personal); |
||
85 | |||
86 | set(joint_reset, 9); //Disable AOTM configuration |
||
87 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
88 | clr(joint_reset, 9); |
||
89 | } |
||
90 | |||
91 | /***************************************************************************** |
||
92 | * void DAC_boardInit(BYTE clock, WORD personal) * |
||
93 | *----------------------------------------------------------------------------* |
||
94 | * Use this function to program software selectable options in the primary * |
||
95 | * module. The options include source, polarity and pulsewidth of the most * |
||
96 | * common used signals. This function must be executed after every invoke of * |
||
97 | * DAC_reset and before executing any output operation. * |
||
98 | * Parameters: * |
||
99 | * clock * |
||
100 | * -bit 0: if sets to 1 AO_IN_TIMEBASE is IN_TIMEBASE divided by 2 * |
||
101 | * -bit 1: if sets to 1 AO_OUT_TIMEBASE is IN_TIMEBASE divideb by 2* |
||
102 | * -bit 2..9 NOT USED |
||
103 | * personal * |
||
104 | * -bit 0...1: update output signal select 0(high Z); 1(GND); * |
||
105 | * 2(enable active low); 3(enable active high) * |
||
106 | * -bit 2...4: not used (let this bit to 0) * |
||
107 | * -bit 5: update pulse width 0(3-3.5 AO_OUT_TIMEBASE period) * |
||
108 | * 1(1-1.5 AO_OUT_TIMEBASE period) * |
||
109 | * -bit 6: update pulse timabase 0(selected by AO_UPDATE pulse_Wi) * |
||
110 | * 1(selected by AO_UPDATE original) * |
||
111 | * -bit 7: not used * |
||
112 | * -bit 8: DMA PIO control 0(FIFO Data interface mode) * |
||
113 | * 1(unbuffered data interface mode) * |
||
114 | * -bit 9: not used * |
||
115 | * -bit 10: enable TMRDACWR which control Analog Output FIFO * |
||
116 | * -bit 11: FIFO flags polarity 0(active low) * |
||
117 | * -bit 12: TMRDACWR pulse width 0(3 AO_OUT_TIMEBASE period) * |
||
118 | * 1(2 AO_OUT_TIMEBASE period) * |
||
119 | * -bit 13: not used * |
||
120 | * -bit 14: number of DAC packages 0(dual-DAC mode) * |
||
121 | * 1(single-DAC mode) * |
||
122 | * -bit 15: NOT USED * |
||
123 | *****************************************************************************/ |
||
124 | void DAC_boardInit(BYTE clock, WORD personal) |
||
125 | { |
||
126 | set(joint_reset, 5); |
||
127 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
128 | clr(joint_reset, 5); |
||
129 | |||
130 | //Setup AOTM clock module |
||
131 | clock_and_fout = (clock_and_fout & 0xFFFC) | (clock & 0x03); |
||
132 | DAQ_STC_Windowed_Mode_Write(CLOCK_AND_FOUT, clock_and_fout); |
||
133 | |||
134 | //Setup Update signal |
||
135 | ao_output_control = (ao_output_control & 0xFFFC) | (personal & 0x0003); |
||
136 | DAQ_STC_Windowed_Mode_Write(AO_OUTPUT_CONTROL, ao_output_control); |
||
137 | |||
138 | ao_personal = (ao_personal & 0x229F) | (personal & 0xDD6F); |
||
139 | DAQ_STC_Windowed_Mode_Write(AO_PERSONAL, ao_personal); |
||
140 | |||
141 | clr(ao_start_select, 12); |
||
142 | DAQ_STC_Windowed_Mode_Write(AO_START_SELECT, ao_start_select); |
||
143 | |||
144 | set(joint_reset, 9); |
||
145 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
146 | clr(joint_reset, 9); |
||
147 | } |
||
148 | |||
149 | /***************************************************************************** |
||
150 | * void DAC_trigger(WORD trigger) * |
||
151 | *----------------------------------------------------------------------------* |
||
152 | * With this function you can select which is the signal which trigger the * |
||
153 | * analog output operation * |
||
154 | * parameter: * |
||
155 | * bit 0...4: start1 source select 0 -> bitfiled AO_START_1 pulse * |
||
156 | * 1..10 -> PFI<0..9> * |
||
157 | * 11..17 -> RTSI<0..6> * |
||
158 | * bit 5: edge detection 0(disable) 1(enable) * |
||
159 | * bit 6: synchronization 0(disable) 1(enable) * |
||
160 | * bit 13: start1 polarity 0(active hi) 1(active lo) * |
||
161 | * bit 14: synchronized with BC source 0(disable) 1(enable) * |
||
162 | * bit 15: set this bit for single operation or clear for continuos mode * |
||
163 | * bit 7..12: NOT USED * |
||
164 | *****************************************************************************/ |
||
165 | void DAC_trigger(WORD trigger) |
||
166 | { |
||
167 | set(joint_reset, 5); |
||
168 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
169 | clr(joint_reset, 5); |
||
170 | |||
171 | //Select continuos or one shoot mode |
||
172 | if(trigger&0x8000) set(ao_mode_1, 0); |
||
173 | else clr(ao_mode_1, 0); |
||
174 | DAQ_STC_Windowed_Mode_Write(AO_MODE_1, ao_mode_1); |
||
175 | |||
176 | //select source |
||
177 | if( (trigger&0x001F) == 0 ) |
||
178 | ao_trigger_select = (ao_trigger_select & 0xDF80) | 0x0060; |
||
179 | else |
||
180 | ao_trigger_select = (ao_trigger_select & 0xDF80) | (trigger & 0x007F); |
||
181 | |||
182 | //triger signal synchronization |
||
183 | ao_trigger_select = (ao_trigger_select & 0x9FFF) | (trigger & 0x6000); |
||
184 | DAQ_STC_Windowed_Mode_Write(AO_TRIGGER_SELECT, ao_trigger_select); |
||
185 | |||
186 | clr(ao_mode_3, 11); |
||
187 | DAQ_STC_Windowed_Mode_Write(AO_MODE_3, ao_mode_3); |
||
188 | |||
189 | set(joint_reset, 9); |
||
190 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
191 | clr(joint_reset, 9); |
||
192 | } |
||
193 | |||
194 | /***************************************************************************** |
||
195 | * void DAC_numSetup(DWORD n_updates, DWORD n_iter) * |
||
196 | *----------------------------------------------------------------------------* |
||
197 | * Use this function to set up number of updates that must be performed and * |
||
198 | * the number of buffer iterations. No Local buffered mode with pauses and * |
||
199 | * waveform staging are implemented yet. Please refer to DAQ STC Technical * |
||
200 | * Reference Manual for this features * |
||
201 | * Parameters: * |
||
202 | * n_updates: number of updates in each buffer operation * |
||
203 | * n_iter: number of iterations that must be performed * |
||
204 | *****************************************************************************/ |
||
205 | void DAC_numSetup(DWORD n_updates, DWORD n_iter) |
||
206 | { |
||
207 | set(joint_reset, 5); |
||
208 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
209 | clr(joint_reset, 5); |
||
210 | |||
211 | set(ao_mode_1, 1); |
||
212 | DAQ_STC_Windowed_Mode_Write(AO_MODE_1, ao_mode_1); |
||
213 | |||
214 | clr(ao_mode_2, 2); |
||
215 | DAQ_STC_Windowed_Mode_Write(AO_MODE_2, ao_mode_2); |
||
216 | |||
217 | //Load numbre of updates for each iteration |
||
218 | DAQ_STC_Windowed_Mode_Write(AO_BC_LOAD_A_LO, (WORD)n_updates); |
||
219 | DAQ_STC_Windowed_Mode_Write(AO_BC_LOAD_A_HI, (WORD)(n_updates>>16)); |
||
220 | |||
221 | set(ao_command_1, 5); |
||
222 | DAQ_STC_Windowed_Mode_Write(AO_COMMAND_1, ao_command_1); |
||
223 | clr(ao_command_1, 5); |
||
224 | |||
225 | clr(ao_mode_2, 11); |
||
226 | DAQ_STC_Windowed_Mode_Write(AO_MODE_2, ao_mode_2); |
||
227 | |||
228 | //load number of iteration |
||
229 | DAQ_STC_Windowed_Mode_Write(AO_UC_LOAD_A_LO, (WORD)n_iter); |
||
230 | DAQ_STC_Windowed_Mode_Write(AO_UC_LOAD_A_HI, (WORD)(n_iter>>16)); |
||
231 | |||
232 | set(ao_command_1, 7); |
||
233 | DAQ_STC_Windowed_Mode_Write(AO_COMMAND_1, ao_command_1); |
||
234 | clr(ao_command_1, 7); |
||
235 | |||
236 | set(joint_reset, 9); |
||
237 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
238 | clr(joint_reset, 9); |
||
239 | } |
||
240 | |||
241 | /***************************************************************************** |
||
242 | * void DAC_update(BYTE source, BYTE ui) * |
||
243 | *----------------------------------------------------------------------------* |
||
244 | * Use this function to select the update event. No waveform staging or local * |
||
245 | * buffer mode with pauses are implemented yet. * |
||
246 | * Parameters: * |
||
247 | * source: bit 0..4: update signal source * |
||
248 | * bit 5: polarity of update signal * |
||
249 | * bit 6..7 NOT USED * |
||
250 | * ui : bit 0..4: UI source select * |
||
251 | * bit 5: polarity of UI signal * |
||
252 | * bit 6..7: NOT USED * |
||
253 | *****************************************************************************/ |
||
254 | void DAC_update(BYTE source, BYTE ui) |
||
255 | { |
||
256 | set(joint_reset, 5); |
||
257 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
258 | clr(joint_reset, 5); |
||
259 | |||
260 | if( (source&0x1F)==0 ){ |
||
261 | clr(ao_command_2, 11); |
||
262 | |||
263 | ao_mode_1 &= 0x07FF; |
||
264 | clr(ao_mode_1, 4); |
||
265 | if( (ui&0x1F)==0 ){ |
||
266 | ao_mode_1 &= 0xF83F; |
||
267 | clr(ao_mode_1, 3); |
||
268 | } else { |
||
269 | if( (ui&0x1F)==20 ){ |
||
270 | ao_mode_1 = (ao_mode_1 & 0xF83F) | 0x0500; |
||
271 | clr(ao_mode_1, 3); |
||
272 | } else { |
||
273 | ao_mode_1 = (ao_mode_1 & 0xF83F) | (((WORD)ui & 0x001F)<<6); |
||
274 | if(ui & 0x20) set(ao_mode_1, 3); |
||
275 | else clr(ao_mode_1, 3); |
||
276 | } |
||
277 | } |
||
278 | } else { |
||
279 | if( (source&0x1F)==19 ){ |
||
280 | set(ao_command_2, 11); |
||
281 | ao_mode_1 = (ao_mode_1 & 0x07FF) | 0x9800; |
||
282 | clr(ao_mode_1, 4); |
||
283 | } else { |
||
284 | set(ao_command_2, 11); |
||
285 | ao_mode_1 = (ao_mode_1 & 0x07FF) | (((WORD)source&0x001F)<<11); |
||
286 | if(source&0x20) set(ao_mode_1, 4); |
||
287 | else clr(ao_mode_1, 4); |
||
288 | } |
||
289 | } |
||
290 | |||
291 | DAQ_STC_Windowed_Mode_Write(AO_COMMAND_2, ao_command_2); |
||
292 | DAQ_STC_Windowed_Mode_Write(AO_MODE_1, ao_mode_1); |
||
293 | |||
294 | set(joint_reset, 9); |
||
295 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
296 | clr(joint_reset, 9); |
||
297 | } |
||
298 | |||
299 | /***************************************************************************** |
||
300 | * void DAC_channel(BYTE num) * |
||
301 | *----------------------------------------------------------------------------* |
||
302 | * Use this function to select hom many analog input channel must be updated * |
||
303 | * every UPDATE event * |
||
304 | * Parameters: multi: if it's different from 0 multiple channel feature are* |
||
305 | * enabled * |
||
306 | * num: number of channels that must be updated * |
||
307 | * Note: With PCI6025E only two channel (DAC0 DAC1) are available * |
||
308 | *****************************************************************************/ |
||
309 | void DAC_channel(BYTE multi, BYTE num) |
||
310 | { |
||
311 | set(joint_reset, 5); |
||
312 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
313 | clr(joint_reset, 5); |
||
314 | |||
315 | if(multi) set(ao_mode_1, 5); |
||
316 | else clr(ao_mode_1, 5); |
||
317 | |||
318 | ao_output_control = (ao_output_control & 0xFC3F) | (((WORD)num&0x0F)<<6); |
||
319 | |||
320 | DAQ_STC_Windowed_Mode_Write(AO_MODE_1, ao_mode_1); |
||
321 | DAQ_STC_Windowed_Mode_Write(AO_OUTPUT_CONTROL, ao_output_control); |
||
322 | |||
323 | set(joint_reset, 9); |
||
324 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
325 | clr(joint_reset, 9); |
||
326 | } |
||
327 | |||
328 | /***************************************************************************** |
||
329 | * void DAC_LDACSourceUpdate(BYTE pref) * |
||
330 | *----------------------------------------------------------------------------* |
||
331 | * Use this function to set source and update mode for LDAC<0..1> signals * |
||
332 | * Parameter: pref: bit 0: LDAC0 source; if 0 LDAC will output on UPDATE * |
||
333 | * else will output on UPDATE2 * |
||
334 | * bit 1: DAC0 update mode; 0 DAC will update immediately * |
||
335 | * 1 timed update mode * |
||
336 | * bit 2: same of bit 0 but for LDAC1 * |
||
337 | * bit 3: same of bit 1 but for DAC1 * |
||
338 | * bit 4..7 NOT USED * |
||
339 | *****************************************************************************/ |
||
340 | void DAC_LDACSourceUpdate(BYTE pref) |
||
341 | { |
||
342 | set(joint_reset, 5); |
||
343 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
344 | clr(joint_reset, 5); |
||
345 | |||
346 | ao_command_1 = (ao_command_1 & 0xFFE1) | (((WORD)pref&0x001E)<<1); |
||
347 | DAQ_STC_Windowed_Mode_Write(AO_COMMAND_1, ao_command_1); |
||
348 | |||
349 | set(joint_reset, 9); |
||
350 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
351 | clr(joint_reset, 9); |
||
352 | } |
||
353 | |||
354 | /***************************************************************************** |
||
355 | * void DAC_stopError(BYTE error) * |
||
356 | *----------------------------------------------------------------------------* |
||
357 | * Use this function to set up the error conditions upon which the Timing * |
||
358 | * Module of Analog Output will stop * |
||
359 | * Parameter: error: bit 0 Stop on BC_TC error * |
||
360 | * bit 1 Stop on BC_TC Trigger error * |
||
361 | * bit 2 Stop on Overrun error * |
||
362 | * bit 3..7 NOT USED * |
||
363 | * Set this bits means that Timing Module will stop. Clear this bits means * |
||
364 | * Timing Module ignores error. * |
||
365 | *****************************************************************************/ |
||
366 | void DAC_stopError(BYTE error) |
||
367 | { |
||
368 | set(joint_reset, 5); |
||
369 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
370 | clr(joint_reset, 5); |
||
371 | |||
372 | ao_mode_3 = (ao_mode_3 & 0xFFC7) | (((WORD)error & 0x0038)<<3); |
||
373 | DAQ_STC_Windowed_Mode_Write(AO_MODE_3, ao_mode_3); |
||
374 | |||
375 | set(joint_reset, 9); |
||
376 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
377 | clr(joint_reset, 9); |
||
378 | } |
||
379 | |||
380 | /***************************************************************************** |
||
381 | * void DAC_FIFOFlags(BYTE flags) * |
||
382 | *----------------------------------------------------------------------------* |
||
383 | * Use this function to select the data FIFO condition on which Interrupt or * |
||
384 | * DMA request are asserted * |
||
385 | * Parameter: flags: bit 0..1 0 generate on empty FIFO * |
||
386 | * 1 generate on less than half full FIFO * |
||
387 | * 2 generate on less than full FIFO * |
||
388 | * 3 generate on less than half full FIFO but * |
||
389 | * keep asserted until FIFO is full * |
||
390 | * bit 2..7 NOT USED * |
||
391 | *****************************************************************************/ |
||
392 | void DAC_FIFOFlags(BYTE flags) |
||
393 | { |
||
394 | set(joint_reset, 5); |
||
395 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
396 | clr(joint_reset, 5); |
||
397 | |||
398 | ao_mode_2 = (ao_mode_2 & 0x1FFF) | (((WORD)flags & 0x0003) << 14); |
||
399 | DAQ_STC_Windowed_Mode_Write(AO_MODE_2, ao_mode_2); |
||
400 | |||
401 | set(joint_reset, 9); |
||
402 | DAQ_STC_Windowed_Mode_Write(JOINT_RESET, joint_reset); |
||
403 | clr(joint_reset, 9); |
||
404 | } |
||
405 | |||
406 | /***************************************************************************** |
||
407 | * void DAC_enableInterrupts(WORD itr) * |
||
408 | *----------------------------------------------------------------------------* |
||
409 | * With this function it's possible to enable event on which Timing Module * |
||
410 | * can generate Interrupt Request * |
||
411 | * Parameter: int: bit 0: BC_TC Interrupt * |
||
412 | * bit 1: START1 Interrupt * |
||
413 | * bit 2: UPDATE Interrupt * |
||
414 | * bit 3: START Interrupt * |
||
415 | * bit 4: NOT USED * |
||
416 | * bit 5: Error Interrupt * |
||
417 | * bit 6: UC_TC Interrupt * |
||
418 | * bit 7: NOT USED * |
||
419 | * bit 8: FIFO Interrupt * |
||
420 | * bit 9..15 NOT USED * |
||
421 | * Set bits to enable interrupt generation or clear to avoid interrupt * |
||
422 | * generation * |
||
423 | *****************************************************************************/ |
||
424 | void DAC_enableInterrupts(WORD itr) |
||
425 | { |
||
426 | interrupt_b_enable = (interrupt_b_enable & 0xFE90) | (itr & 0x016F); |
||
427 | |||
428 | DAQ_STC_Windowed_Mode_Write(INTERRUPT_B_ENABLE, interrupt_b_enable); |
||
429 | } |
||
430 | |||
431 | /***************************************************************************** |
||
432 | * void DAC_arm(void) * |
||
433 | *----------------------------------------------------------------------------* |
||
434 | * With this function Analog Output counters will be armed and the first value* |
||
435 | * is preloaded into DACs * |
||
436 | *****************************************************************************/ |
||
437 | void DAC_arm(void) |
||
438 | { |
||
439 | set(ao_mode_3, 2); |
||
440 | DAQ_STC_Windowed_Mode_Write(AO_MODE_3, ao_mode_3); |
||
441 | |||
442 | clr(ao_mode_3, 2); |
||
443 | DAQ_STC_Windowed_Mode_Write(AO_MODE_3, ao_mode_3); |
||
444 | |||
445 | while( (DAQ_STC_Windowed_Mode_Read(JOINT_STATUS_2) & 0x0020) != 0 ); |
||
446 | |||
447 | ao_command_1 |= 0x0540; |
||
448 | DAQ_STC_Windowed_Mode_Write(AO_COMMAND_1, ao_command_1); |
||
449 | } |
||
450 | |||
451 | /***************************************************************************** |
||
452 | * void DAC_startOperation(void) * |
||
453 | *----------------------------------------------------------------------------* |
||
454 | * If software trigger was previously selected this function initiate an * |
||
455 | * analog output operation. If trigger wasn't software driven this function * |
||
456 | * has no effects * |
||
457 | *****************************************************************************/ |
||
458 | void DAC_startOperation(void) |
||
459 | { |
||
460 | set(ao_command_2, 0); |
||
461 | DAQ_STC_Windowed_Mode_Write(AO_COMMAND_2, ao_command_2); |
||
462 | clr(ao_command_2, 0); |
||
463 | } |
||
464 | |||
465 | /***************************************************************************** |
||
466 | * void DAC_Init(void) * |
||
467 | *----------------------------------------------------------------------------* |
||
468 | * This function must be called previously any DAC settings or DAC operations * |
||
469 | * It preapers the envirorment to work with DACs in right way and calls the * |
||
470 | * reset function (DAC_reset) * |
||
471 | *****************************************************************************/ |
||
472 | void DAC_Init(void) |
||
473 | { |
||
474 | DAC_Initialized = 1; |
||
475 | /*DAC0: Bipolar mode, Internal referenced, ReGlitch disabled*/ |
||
476 | Immediate_Writew(DAC_CONFIG, 0x0001); |
||
477 | |||
478 | /*DAC1: Bipolar mode, Internal referenced, ReGlitch disabled*/ |
||
479 | Immediate_Writew(DAC_CONFIG, 0x0101); |
||
480 | |||
481 | DAC_reset(); |
||
482 | } |
||
483 | |||
484 | /***************************************************************************** |
||
485 | * void DAC_output(BYTE DAC_ID, WORD value) * |
||
486 | *----------------------------------------------------------------------------* |
||
487 | * Write "value" in "DAC_ID" register and put out the releted analog value * |
||
488 | * Parameters: DAC_ID: This can be DAC0 or DAC1 * |
||
489 | * value: first 12-bit output value * |
||
490 | * last 4 bits NOT USED * |
||
491 | *****************************************************************************/ |
||
492 | void DAC_output(BYTE DAC_ID, WORD value) |
||
493 | { |
||
494 | if(DAC_Initialized){ |
||
495 | if(DAC_ID) Immediate_Writew(DAC1_DATA, (value & 0x0FFF)); |
||
496 | else Immediate_Writew(DAC0_DATA, (value & 0x0FFF)); |
||
497 | } |
||
498 | } |
||
499 | /*End of file: DAC.C*/ |