0
|
1
|
|
2 ; OSTC - diving computer code
|
|
3 ; Copyright (C) 2008 HeinrichsWeikamp GbR
|
|
4
|
|
5 ; This program is free software: you can redistribute it and/or modify
|
|
6 ; it under the terms of the GNU General Public License as published by
|
|
7 ; the Free Software Foundation, either version 3 of the License, or
|
|
8 ; (at your option) any later version.
|
|
9
|
|
10 ; This program is distributed in the hope that it will be useful,
|
|
11 ; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
12 ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
13 ; GNU General Public License for more details.
|
|
14
|
|
15 ; You should have received a copy of the GNU General Public License
|
|
16 ; along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
17
|
|
18
|
|
19 ; routines for Surface mode
|
|
20 ; written by: Matthias Heinrichs, info@heinrichsweikamp.com
|
|
21 ; written: 10/01/05
|
|
22 ; last updated: 080905
|
|
23 ; known bugs:
|
|
24 ; ToDo:
|
|
25
|
|
26 surfloop:
|
|
27 ; Boot tasks for all modes
|
|
28 call restart_set_modes_and_flags ; Sets decomode flags
|
|
29 clrf lo
|
|
30 movff lo,char_I_const_ppO2 ; reset to standard mode, OSTC assumes Air breathing at the surface!
|
|
31
|
|
32 call PLED_brightness_full ;max. brightness
|
|
33
|
|
34 call I2CReset
|
|
35 call enable_rs232
|
|
36 call PLED_boot
|
|
37 call PLED_serial ; Show OSTC serial and firmware version
|
|
38 call PLED_clock ; display time
|
|
39 call update_date ; display date
|
|
40 movff last_surfpressure_30min+0,int_I_pres_respiration+0 ; copy surface air pressure to deco routine
|
|
41 movff last_surfpressure_30min+1,int_I_pres_respiration+1 ; 30min old values
|
|
42 movff last_surfpressure_30min+0,int_I_pres_surface+0 ; copy surface air pressure to deco routine
|
|
43 movff last_surfpressure_30min+1,int_I_pres_surface+1 ; 30min old values
|
|
44
|
|
45 btfsc gauge_mode ; Ignore in gauge mode
|
|
46 bra surfloop1
|
|
47 btfsc FLAG_apnoe_mode ; Ignore in Apnoe mode
|
|
48 bra surfloop1
|
|
49
|
|
50 ; Startup tasks for decompression modes
|
43
|
51 call PLED_display_cns_surface ; Update surface CNS display (If allowed by CF15)
|
0
|
52 call PLED_desaturation_time ; display desaturation time
|
|
53 call PLED_nofly_time ; display nofly time
|
13
|
54
|
|
55 btfss pre_dive_screen ; Show predive screen
|
|
56 call PLED_tissue_saturation_graph ; no, display saturation graph
|
|
57 btfsc pre_dive_screen ; Show predive screen
|
|
58 call PLED_pre_dive_screen ; yes, display Pre-Dive Screen
|
|
59
|
0
|
60 call PLED_active_gas_surfmode ; Show start gas
|
|
61 call PLED_display_decotype_surface ; Show deco mode (ZH-L16, const. ppO2 or Multi-GF)
|
|
62
|
|
63 surfloop1:
|
|
64 btfss gauge_mode ; Display only in gauge mode
|
|
65 bra surfloop2
|
|
66 DISPLAYTEXT d'103' ; Gauge mode
|
|
67 surfloop2:
|
|
68 btfss FLAG_apnoe_mode ; Display only in Apnoe mode
|
|
69 bra surfloop3
|
|
70 DISPLAYTEXT d'116' ; Apnoe mode
|
|
71
|
|
72 surfloop3:
|
|
73 ; Startup tasks for all modes
|
|
74 clrf timeout_counter2
|
|
75 clrf timeout_counter3
|
|
76 bcf premenu ; clear premenu flag
|
|
77 bcf menubit ; clear menu flag
|
|
78 bcf pressure_refresh
|
|
79 clrf last_pressure+0
|
|
80 clrf last_pressure+1
|
|
81 clrf last_temperature+0
|
|
82 clrf last_temperature+1
|
|
83
|
|
84 movlw d'5'
|
|
85 movwf timeout_counter ; reload counter
|
|
86
|
21
|
87 bcf LED_blue
|
|
88 bcf LED_red
|
0
|
89 bcf simulatormode_active ; Quit simulator mode (if active)
|
|
90 bcf standalone_simulator ; Quit simulator mode (if active)
|
|
91 WIN_TOP .0
|
|
92 WIN_LEFT .0
|
|
93 WIN_FONT FT_SMALL
|
|
94 WIN_INVERT .0 ; Init new Wordprocessor
|
3
|
95 call PLED_standard_color
|
|
96
|
0
|
97 bcf switch_left
|
|
98 bcf switch_right
|
4
|
99 call PLED_active_gas_surfmode ; Show start gas / SetPoint
|
0
|
100 call PLED_custom_text ; Displays custom text
|
|
101 movlw d'1' ; next cf to check
|
|
102 movwf cf_checker_counter ;
|
|
103 ostc_debug 'G' ; Sends debug-information to screen if debugmode active
|
|
104 GETCUSTOM8 d'12' ; Desaturation multiplier %
|
|
105 movwf wait_temp
|
|
106 movff wait_temp,char_I_desaturation_multiplier
|
|
107 GETCUSTOM8 d'11' ; Saturation multiplier %
|
|
108 movwf wait_temp
|
|
109 movff wait_temp,char_I_saturation_multiplier
|
|
110 call deco_main_calc_desaturation_time; calculate desaturation time
|
|
111 movlb b'00000001' ; select ram bank 1
|
|
112 ostc_debug 'H' ; Sends debug-information to screen if debugmode active
|
|
113
|
|
114 call wait_switches ; Waits until switches are released, resets flag if button stays pressed!
|
|
115
|
|
116 surfloop_loop:
|
|
117 btfss onesecupdate ; do every second tasks?
|
|
118 bra surfloop_loop2 ; no, loop
|
|
119
|
|
120 btfss FLAG_const_ppO2_mode ; are we in const. ppO2 mode?
|
|
121 bra surfloop_loop1 ; No
|
|
122 ; One Second tasks for ppO2 modes
|
|
123
|
|
124 bra surfloop_loop1 ; Do not search for sensor in CC mode
|
|
125
|
|
126
|
|
127 surfloop_loop1:
|
|
128 ; One Second tasks for all modes
|
|
129 call PLED_clock ; update clock
|
|
130 call test_charger ; check if charger IC is active
|
|
131 call timeout_surfmode ; check timeout
|
|
132 call get_battery_voltage ; get battery voltage
|
|
133 call update_batt_voltage ; display battery voltage
|
|
134 call timeout_premenu ; timeout premenu
|
|
135 call set_leds_surfmode ; Sets Warning and No-Fly LEDs
|
|
136 call custom_functions_check_surfmode ; Checks CF functions and displays warning symbol if something critical is wrong
|
4
|
137 ; call PLED_active_gas_surfmode ; Show start gas / SetPoint
|
0
|
138 call PLED_display_decotype_surface ; Show deco mode
|
|
139 btfsc enter_error_sleep ; Enter Fatal Error Routine?
|
16
|
140 call fatal_error_sleep ; Yes (In Sleepmode_vxx.asm!)
|
0
|
141 bcf onesecupdate ; every second tasks done
|
|
142
|
|
143 surfloop_loop2:
|
|
144 ; Tasks approx. every 50ms for all modes
|
|
145 call test_switches_surfmode ; check switches
|
|
146
|
|
147 ; Sensor tasks for all modes
|
|
148 btfsc pressure_refresh ; new pressure available?
|
|
149 call update_surf_press ; display surface pressure
|
|
150 btfsc pressure_refresh ; new temperature available?
|
|
151 call PLED_temp_surfmode ; Displays temperature
|
|
152 btfsc pressure_refresh ; new pressure available?
|
|
153 call set_dive_modes ; tests if depth>threshold
|
|
154 bcf pressure_refresh ; until new pressure is available
|
|
155
|
|
156 ; One minute tasks for all modes
|
|
157 btfsc oneminupdate ; do every minute tasks
|
|
158 call update_surfloop60 ; yes, e.g. update time and date
|
|
159
|
|
160 ; Mode tasks
|
|
161 btfsc menubit ; Menu?
|
|
162 goto menu ; Menu!
|
|
163 btfsc divemode ; Divemode active?
|
|
164 goto diveloop ; Yes, switch into Divemode!
|
|
165 btfsc sleepmode ; Sleepmode active?
|
|
166 goto sleeploop ; Yes, switch into sleepmode!
|
|
167 ; Check for the different UART flags
|
|
168 btfsc dump_external_eeprom ; Start interface (dumps EEPROM BANK 0 + additional data)?
|
|
169 goto menu_interface ; Yes!
|
|
170 btfsc uart_settime ; Sync clock with PC?
|
|
171 goto sync_clock ; Yes!
|
|
172 btfsc internal_eeprom_write ; Access internal EEPROM BANK 0 via UART module
|
|
173 goto internal_eeprom_access_b0 ; Yes!
|
|
174 btfsc internal_eeprom_write2 ; Access internal EEPROM BANK 1 via UART module
|
|
175 goto internal_eeprom_access_b1 ; Yes!
|
|
176 btfsc uart_send_hash ; Send MD2 hash values
|
|
177 goto send_md2_hash ; Yes!
|
|
178 btfsc uart_send_int_eeprom ; Send internal EEPROM BANK 0
|
|
179 goto send_int_eeprom_b0 ; Yes!
|
|
180 btfsc uart_reset_decodata ; Reset Deco Data?
|
|
181 goto reset_decodata ; Yes!
|
|
182 btfsc uart_send_int_eeprom2 ; Send internal EEPROM BANK 1
|
|
183 goto send_int_eeprom_b1 ; Yes!
|
|
184 btfsc uart_store_tissue_data ; Store tissue data?`
|
|
185 goto uart_store_tissues ; Yes!
|
|
186
|
|
187 bra surfloop_loop ; loop surfacemode
|
|
188
|
|
189
|
|
190 update_surfloop60:
|
|
191 ; One minute tasks for all modes
|
4
|
192 ; call PLED_active_gas_surfmode ; Show start gas / SetPoint
|
0
|
193 call update_date ; and date in divemode
|
|
194 call calc_deko_surfmode ; calculate desaturation every minute
|
|
195 call check_temp_extrema ; check for new temperature extremas
|
|
196 call PLED_custom_text ; Displays custom text
|
|
197 call calc_surface_interval ; Increases Surface-Interval time
|
|
198
|
|
199 btfsc gauge_mode ; Ignore in gauge mode
|
|
200 bra update_surfloop60_2
|
|
201 btfsc FLAG_apnoe_mode ; Ignore in Apnoe mode
|
|
202 bra update_surfloop60_2
|
|
203
|
|
204 ; One Minute tasks for deco modes
|
43
|
205 call PLED_display_cns_surface ; Update surface CNS display (If allowed by CF15)
|
0
|
206 call PLED_nofly_time ; display nofly time
|
|
207 call PLED_desaturation_time ; display desaturation time
|
13
|
208 btfsc premenu ; Not when "Menu?" is displayed!
|
|
209 bra update_surfloop60_2
|
|
210
|
|
211 btfss pre_dive_screen ; Show predive screen
|
|
212 call PLED_tissue_saturation_graph ; no, display saturation graph
|
|
213 btfsc pre_dive_screen ; Show predive screen
|
|
214 call PLED_pre_dive_screen ; yes, display Pre-Dive Screen
|
0
|
215
|
|
216 update_surfloop60_2:
|
|
217 call nofly_timeout60 ; checks if nofly time is > 0
|
|
218 bcf oneminupdate
|
|
219 return
|
|
220
|
|
221 nofly_timeout60:
|
|
222 bsf nofly_active ; Set flag
|
|
223 movlw d'1'
|
|
224 subwf nofly_time+0,F
|
|
225 movlw d'0'
|
|
226 subwfb nofly_time+1,F ; reduce by one
|
|
227 tstfsz nofly_time+0 ; =0?
|
|
228 return
|
|
229 tstfsz nofly_time+1 ; =0?
|
|
230 return
|
|
231 bcf nofly_active ; Clear flag
|
21
|
232 bcf LED_blue
|
0
|
233 incf nofly_time+0,F ; =1
|
|
234 return
|
|
235
|
|
236 calc_surface_interval:
|
|
237 movff int_O_desaturation_time+0,lo ; divide by 60...
|
|
238 movff int_O_desaturation_time+1,hi
|
|
239 tstfsz lo ;=0?
|
|
240 bra calc_surface_interval2 ; No
|
|
241 tstfsz hi ;=0?
|
|
242 bra calc_surface_interval2 ; No
|
|
243 clrf surface_interval+0
|
|
244 clrf surface_interval+1 ; Clear surface interval timer
|
|
245 return
|
|
246
|
|
247 calc_surface_interval2: ; Increase surface interval timer
|
|
248 movlw d'1'
|
|
249 addwf surface_interval+0,F
|
|
250 movlw d'0'
|
|
251 addwfc surface_interval+1,F
|
|
252 return
|
|
253
|
|
254 set_leds_surfmode:
|
|
255 btfsc nofly_active
|
21
|
256 btg LED_blue
|
0
|
257 return
|
|
258
|
|
259 calc_deko_surfmode:
|
21
|
260 bsf LED_red
|
0
|
261 ostc_debug 'I' ; Sends debug-information to screen if debugmode active
|
|
262
|
|
263 movff last_surfpressure+0,int_I_pres_surface+0 ; copy surface air pressure to deco routine
|
|
264 movff last_surfpressure+1,int_I_pres_surface+1
|
|
265 clrf wait_temp ; Use as buffer
|
|
266 movff wait_temp,char_I_He_ratio ; No He at the Surface
|
|
267 movlw d'79' ; 79% N2
|
|
268 movwf wait_temp ; Use as buffer
|
|
269 movff wait_temp,char_I_N2_ratio ; No He at the Surface
|
|
270
|
|
271 movff amb_pressure+0,int_I_pres_respiration+0 ; copy surface air pressure to deco routine
|
|
272 movff amb_pressure+1,int_I_pres_respiration+1
|
|
273 GETCUSTOM8 d'11' ; Saturation multiplier %
|
|
274 movwf wait_temp
|
|
275 movff wait_temp,char_I_saturation_multiplier
|
|
276 GETCUSTOM8 d'12' ; Desaturation multiplier %
|
|
277 movwf wait_temp
|
|
278 movff wait_temp,char_I_desaturation_multiplier
|
|
279
|
|
280 call deco_main_calc_wo_deco_step_1_m ; calculate deco in surface mode
|
|
281 movlb b'00000001' ; select ram bank 1
|
|
282 ostc_debug 'J' ; Sends debug-information to screen if debugmode active
|
21
|
283 bcf LED_red
|
0
|
284 return
|
|
285
|
|
286
|
|
287 test_charger:
|
|
288 bcf TRISC,1 ; CHRG_OUT output
|
|
289 bsf CHRG_OUT
|
|
290
|
|
291 bcf cc_active ; Constant Current mode active?
|
|
292 btfss CHRG_IN ; If CHRG_IN=0 -> CC active
|
|
293 bsf cc_active ; Constant Current mode Active!
|
|
294
|
|
295 bcf CHRG_OUT
|
|
296 bsf TRISC,1 ; CHRG_OUT high impedance
|
|
297
|
|
298 WAIT10US d'10'
|
|
299
|
|
300 bcf cv_active ; Constant Voltage mode Active?
|
|
301 btfss CHRG_IN ; If CHRG_IN=0 -> CV active
|
|
302 bsf cv_active ; Constant Voltage mode active!
|
|
303
|
|
304 bcf TRISC,1 ; CHRG_OUT output
|
|
305 bcf CHRG_OUT
|
|
306
|
|
307 btfsc cc_active
|
|
308 bra show_cc_active
|
|
309 btfsc cv_active
|
|
310 bra show_cv_active
|
|
311
|
|
312 bsf TRISC,1 ; CHRG_OUT high impedance
|
|
313
|
|
314 ; Charger inactive or ready
|
|
315 btfss charge_done ; charge done?
|
|
316 bra test_charger2 ; No, add incomplete cycle!
|
|
317
|
|
318 ; Yes, store all data for complete cycle
|
|
319 bcf charge_started ; Clear flag
|
|
320 bcf charge_done ; Clear flag
|
|
321 ; Store incomplete/total cycles
|
|
322 read_int_eeprom d'50' ; Read byte (stored in EEDATA)
|
|
323 movff EEDATA,temp1 ; Low byte
|
|
324 read_int_eeprom d'51' ; Read byte (stored in EEDATA)
|
|
325 movff EEDATA,temp2 ; high byte
|
|
326 bcf STATUS,C
|
|
327 movlw d'1'
|
|
328 addwf temp1
|
|
329 movlw d'0'
|
|
330 addwfc temp2
|
|
331 movff temp1,EEDATA
|
|
332 write_int_eeprom d'50' ; write byte stored in EEDATA
|
|
333 movff temp2,EEDATA
|
|
334 write_int_eeprom d'51' ; write byte stored in EEDATA
|
|
335
|
|
336 ; Store complete cycles
|
|
337 read_int_eeprom d'52' ; Read byte (stored in EEDATA)
|
|
338 movff EEDATA,temp1 ; Low byte
|
|
339 read_int_eeprom d'53' ; Read byte (stored in EEDATA)
|
|
340 movff EEDATA,temp2 ; high byte
|
|
341 bcf STATUS,C
|
|
342 movlw d'1'
|
|
343 addwf temp1
|
|
344 movlw d'0'
|
|
345 addwfc temp2
|
|
346 movff temp1,EEDATA
|
|
347 write_int_eeprom d'52' ; write byte stored in EEDATA
|
|
348 movff temp2,EEDATA
|
|
349 write_int_eeprom d'53' ; write byte stored in EEDATA
|
|
350 ; Store date of complete cycle
|
|
351 movff month,EEDATA
|
|
352 write_int_eeprom d'47'
|
|
353 movff day,EEDATA
|
|
354 write_int_eeprom d'48'
|
|
355 movff year,EEDATA
|
|
356 write_int_eeprom d'49'
|
|
357
|
|
358 return
|
|
359
|
|
360 test_charger2:
|
|
361 btfss charge_started ; Did the charger ever start?
|
|
362 return ; No, quit!
|
|
363
|
|
364 bcf charge_started ; Clear flag
|
|
365 ; Store incomplete/total cycles
|
|
366 read_int_eeprom d'50' ; Read byte (stored in EEDATA)
|
|
367 movff EEDATA,temp1 ; Low byte
|
|
368 read_int_eeprom d'51' ; Read byte (stored in EEDATA)
|
|
369 movff EEDATA,temp2 ; high byte
|
|
370 bcf STATUS,C
|
|
371 movlw d'1'
|
|
372 addwf temp1
|
|
373 movlw d'0'
|
|
374 addwfc temp2
|
|
375 movff temp1,EEDATA
|
|
376 write_int_eeprom d'50' ; write byte stored in EEDATA
|
|
377 movff temp2,EEDATA
|
|
378 write_int_eeprom d'51' ; write byte stored in EEDATA
|
|
379 return
|
|
380
|
|
381 show_cv_active: ; CV mode
|
21
|
382 bsf LED_red
|
0
|
383 WAITMS d'100'
|
21
|
384 bcf LED_red
|
0
|
385 WAITMS d'100'
|
21
|
386 bsf LED_red
|
0
|
387 bsf charge_done ; Charge cycle finished
|
|
388 return
|
|
389
|
|
390 show_cc_active: ; CC mode
|
21
|
391 bsf LED_red
|
0
|
392 bsf charge_started ; Charger started in CC mode
|
|
393 bcf charge_done ; Charge cycle not finished
|
|
394 return
|
|
395
|
|
396
|
|
397 timeout_premenu:
|
|
398 btfss premenu ; is "Menu?" displayed?
|
|
399 return ; No
|
|
400 incf timeout_counter3,F ; Yes...
|
|
401 GETCUSTOM8 d'4' ; loads premenu_timeout into WREG
|
|
402 cpfsgt timeout_counter3 ; ... longer then premenu_timeout
|
|
403 return ; No!
|
|
404 bcf premenu ; Yes, so clear "Menu?" and clear pre_menu bit
|
|
405
|
|
406 call PLED_topline_box_clear ; Clears Bar at the top
|
|
407
|
|
408 btfsc gauge_mode
|
|
409 bra timeout_premenu2 ; Skip in Gauge mode
|
|
410 btfsc FLAG_apnoe_mode
|
|
411 bra timeout_premenu2 ; Skip in Apnoe mode
|
13
|
412
|
|
413 btfss pre_dive_screen ; Show predive screen
|
|
414 call PLED_tissue_saturation_graph ; no, display saturation graph
|
|
415 btfsc pre_dive_screen ; Show predive screen
|
|
416 call PLED_pre_dive_screen ; yes, display Pre-Dive Screen
|
|
417
|
0
|
418 timeout_premenu2:
|
|
419 call update_surf_press ; rewrite serial number
|
|
420 call PLED_serial ; rewrite serial number
|
|
421 clrf timeout_counter3 ; Also clear timeout
|
|
422 bcf switch_left ; and debounce switches
|
|
423 bcf switch_right
|
|
424 return
|
|
425
|
|
426 test_switches_surfmode: ; checks switches in surfacemode
|
|
427 btfsc switch_left
|
|
428 bra test_switches_surfmode2
|
|
429 btfsc switch_right
|
|
430 bra test_switches_surfmode3
|
|
431
|
|
432 ; No button press, reset timer0
|
|
433 bcf T0CON,TMR0ON ; Stop Timer 0
|
|
434 bcf INTCON,TMR0IF ; Clear flag
|
|
435 clrf TMR0H
|
|
436 clrf TMR0L
|
|
437 bcf INTCON,INT0IF ; Clear flag
|
|
438 bcf INTCON3,INT1IF ; Clear flag
|
|
439 return
|
|
440
|
|
441 test_switches_surfmode3:
|
|
442 bcf switch_right
|
|
443 call PLED_topline_box ; Write a filled bar at the top
|
|
444 WIN_INVERT .1 ; Init new Wordprocessor
|
|
445 DISPLAYTEXT .4 ;Menu?
|
|
446 WIN_INVERT .0 ; Init new Wordprocessor
|
|
447 bsf premenu
|
|
448 clrf timeout_counter2
|
|
449 return
|
|
450
|
|
451 test_switches_surfmode2:
|
|
452 bcf switch_left
|
|
453 btfss premenu
|
13
|
454 bra test_switches_surfmode4
|
0
|
455 bsf menubit ; Enter Menu!
|
|
456 return
|
|
457
|
13
|
458 test_switches_surfmode4:
|
|
459 btg pre_dive_screen
|
0
|
460
|
13
|
461 btfss pre_dive_screen ; Show predive screen
|
|
462 call PLED_tissue_saturation_graph ; no, display saturation graph
|
|
463 btfsc pre_dive_screen ; Show predive screen
|
|
464 call PLED_pre_dive_screen ; yes, display Pre-Dive Screen
|
|
465
|
|
466 return
|
0
|
467
|
|
468 timeout_surfmode:
|
|
469 incf timeout_counter2,F ; increase timeout counter
|
|
470 GETCUSTOM8 d'3' ; loads surfloop_timeout into WREG
|
|
471 addlw d'5' ; adds five seconds in case timout=zero!
|
|
472 btfsc STATUS,C ; > 255?
|
|
473 movlw d'255' ; Set to 255...
|
|
474 decf WREG,F ; Limit to 254
|
|
475 cpfsgt timeout_counter2 ; Compare with timeout_counter2
|
|
476 return ; return, no timeout
|
|
477 bsf sleepmode ; Set Flag
|
|
478 return ; Return
|