Mercurial > public > mk2
annotate code_part1/OSTC_code_asm_part1/start.asm @ 145:8bda2452a532
FIX bad mix icon when active gas in not G1.
author | JeanDo |
---|---|
date | Sun, 09 Jan 2011 11:45:20 +0100 |
parents | 8b75ba28d641 |
children | 17de42ab02b6 |
rev | line source |
---|---|
0 | 1 ; OSTC - diving computer code |
2 ; Copyright (C) 2008 HeinrichsWeikamp GbR | |
3 | |
4 ; This program is free software: you can redistribute it and/or modify | |
5 ; it under the terms of the GNU General Public License as published by | |
6 ; the Free Software Foundation, either version 3 of the License, or | |
7 ; (at your option) any later version. | |
8 | |
9 ; This program is distributed in the hope that it will be useful, | |
10 ; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 ; GNU General Public License for more details. | |
13 | |
14 ; You should have received a copy of the GNU General Public License | |
15 ; along with this program. If not, see <http://www.gnu.org/licenses/>. | |
16 | |
17 | |
18 ; Start and init | |
19 ; written by: Matthias Heinrichs, info@heinrichsweikamp.com | |
20 ; written: 10/13/04 | |
21 ; last updated: 06/24/08 | |
22 ; known bugs: | |
23 ; ToDo: | |
24 | |
25 start: | |
26 movlb b'00000001' ; ram bank 1 selected | |
119 | 27 movff STKPTR,temp10 |
0 | 28 call init |
29 btfsc divemode ; Reset from Divemode? | |
30 call PLED_resetdebugger ; Yes! Something went wrong, show reset informations | |
31 | |
32 clrf STKPTR ; Clear Stackpointer | |
98
6f8e3a08011e
1.73beta rc1 (Added new customview for divemode)
heinrichsweikamp
parents:
97
diff
changeset
|
33 lfsr FSR0, 10Bh ; Clear rambank 1-9, do not delete RTC registers |
0 | 34 clear_rambank: |
35 clrf POSTINC0 | |
36 movlw 0x0A | |
37 cpfseq FSR0H ; Bank 9 done? | |
38 bra clear_rambank ; clear... | |
39 | |
40 ; Defaults for RTC | |
41 call disable_rs232 ; disable UART module | |
42 call RTCinit ; reset RTC | |
43 | |
97 | 44 ; Extra power-up reset jDG jDG jDG jDG |
83
3e351e25f5d1
adding anti-aliased fonts frame and merging some patches from Jeando
heinrichsweikamp
parents:
62
diff
changeset
|
45 ifdef TESTING |
97 | 46 call do_menu_reset_all2 |
83
3e351e25f5d1
adding anti-aliased fonts frame and merging some patches from Jeando
heinrichsweikamp
parents:
62
diff
changeset
|
47 endif |
3e351e25f5d1
adding anti-aliased fonts frame and merging some patches from Jeando
heinrichsweikamp
parents:
62
diff
changeset
|
48 ; DONE jDG jDG jDG jDG |
3e351e25f5d1
adding anti-aliased fonts frame and merging some patches from Jeando
heinrichsweikamp
parents:
62
diff
changeset
|
49 |
0 | 50 ; Air pressure compensation after reset |
51 call get_calibration_data ; Get calibration data from pressure sensor | |
52 | |
53 bcf pressure_refresh | |
54 wait_start_pressure: | |
55 btfss pressure_refresh ; Air pressure compensation | |
56 bra wait_start_pressure | |
57 | |
58 clrf rel_pressure+0 | |
59 clrf rel_pressure+1 | |
60 clrf surface_interval+0 | |
61 clrf surface_interval+1 | |
62 | |
63 bsf sleepmode ; Routine only works in sleepmode... | |
64 call pressuretest_sleep_fast ; Gets pressure without averaging (faster!) | |
65 bcf sleepmode ; Normal mode again | |
66 | |
67 movff amb_pressure+0,last_surfpressure+0 | |
68 movff amb_pressure+1,last_surfpressure+1 | |
69 movff amb_pressure+0,last_surfpressure_15min+0 | |
70 movff amb_pressure+1,last_surfpressure_15min+1 | |
71 movff amb_pressure+0,last_surfpressure_30min+0 | |
72 movff amb_pressure+1,last_surfpressure_30min+1 ; Rests all airpressure registers | |
73 | |
74 ; reset deco data | |
75 incf nofly_time+0,F ; =1 | |
76 clrf wait_temp ; Use as buffer | |
77 movff wait_temp,char_I_He_ratio ; No He at the Surface | |
78 movlw d'79' ; 79% N2 | |
79 movwf wait_temp ; Use as buffer | |
80 movff wait_temp,char_I_N2_ratio ; No He at the Surface | |
81 movff amb_pressure+0,int_I_pres_respiration+0 ; copy surface air pressure to deco routine | |
82 movff amb_pressure+1,int_I_pres_respiration+1 | |
83 | |
31 | 84 movlw d'0' |
85 movff WREG,char_I_step_is_1min ; 2 second deco mode | |
116 | 86 call deco_clear_tissue ; |
87 call deco_calc_desaturation_time ; calculate desaturation time | |
88 call deco_clear_CNS_fraction ; clear CNS | |
0 | 89 call calc_deko_surfmode ; calculate desaturation every minute |
116 | 90 call deco_calc_wo_deco_step_1_min ; calculate deco in surface mode |
0 | 91 movlb b'00000001' ; select ram bank 1 |
92 | |
93 ; check firmware and reset Custom Functions after an update | |
94 movlw LOW 0x101 | |
95 movwf EEADR | |
96 movlw HIGH 0x101 | |
97 movwf EEADRH | |
98 call read_eeprom ; read current version x | |
99 movff EEDATA,temp1 | |
100 incf EEADR,F ; set to 0x102 | |
101 call read_eeprom ; read current version y | |
102 movff EEDATA,temp2 | |
103 clrf EEADRH ; Reset EEADRH | |
104 | |
105 movlw softwareversion_x | |
106 cpfseq temp1 ; compare version x | |
107 bra check_firmware_new ; is not equal -> reset CF and store new version in EEPROM | |
108 | |
109 movlw softwareversion_y | |
110 cpfseq temp2 ; compare version y | |
111 bra check_firmware_new ; is not equal -> reset CF and store new version in EEPROM | |
112 bra restart ; x and y are equal -> do not reset cf | |
113 | |
114 check_firmware_new: | |
115 movlw LOW 0x101 ; store current version in EEPROM | |
116 movwf EEADR | |
117 movlw HIGH 0x101 | |
118 movwf EEADRH | |
119 movlw softwareversion_x | |
120 movwf EEDATA | |
121 call write_eeprom ; write version x | |
122 incf EEADR,F ; set to 0x102 | |
123 movlw softwareversion_y | |
124 movwf EEDATA | |
125 call write_eeprom ; write version y | |
126 clrf EEADRH ; Reset EEADRH | |
62 | 127 ; goto reset_all_cf ; resets all custom functions bank0 and bank1 and jumps to "restart" |
52 | 128 ; goto reset_all_cf_bank1 ; resets all custom functions bank1 and jumps to "restart" |
0 | 129 |
130 restart: | |
21 | 131 bcf LED_red |
132 bcf LED_blue ; all LEDs off | |
43 | 133 GETCUSTOM8 d'48' ; time correction value |
134 movff WREG, time_correction_value ; store in Bank0 register | |
15 | 135 |
142 | 136 GETCUSTOM8 d'63' ; OLED flip_screen flag(s). |
137 movff WREG,win_flags ; store in Bank0 register | |
138 | |
15 | 139 clrf flag1 ; clear all flags |
140 clrf flag2 | |
141 clrf flag3 | |
142 clrf flag4 | |
143 clrf flag5 | |
144 clrf flag6 | |
145 clrf flag7 | |
146 clrf flag8 | |
147 clrf flag9 | |
148 clrf flag10 | |
149 clrf flag11 | |
150 clrf flag12 | |
151 clrf flag13 | |
152 clrf flag14 | |
153 clrf flag15 | |
142 | 154 call gassetup_sort_gaslist ; Sorts Gaslist according to change depth |
155 call PLED_boot ; PLED boot (Incl. Clear Screen!) | |
0 | 156 WIN_TOP .0 |
157 WIN_LEFT .0 | |
158 WIN_FONT FT_SMALL | |
159 WIN_INVERT .0 ; Init new Wordprocessor | |
83
3e351e25f5d1
adding anti-aliased fonts frame and merging some patches from Jeando
heinrichsweikamp
parents:
62
diff
changeset
|
160 setf WREG |
3e351e25f5d1
adding anti-aliased fonts frame and merging some patches from Jeando
heinrichsweikamp
parents:
62
diff
changeset
|
161 movff WREG,win_color1 ; Beware: win_color1 is bank0, and we are bank1 currently |
3e351e25f5d1
adding anti-aliased fonts frame and merging some patches from Jeando
heinrichsweikamp
parents:
62
diff
changeset
|
162 movff WREG,win_color2 |
0 | 163 call I2CReset ; Just in Case any I2C device blocks the Bus |
164 movff last_surfpressure_30min+0,last_surfpressure+0 ; Use 30min old airpressure | |
165 movff last_surfpressure_30min+1,last_surfpressure+1 ; Use 30min old airpressure | |
166 | |
167 ; Check if new CF were added in the last firmware version | |
168 clrf EEADRH | |
169 read_int_eeprom d'92' ; Read number of CF used in this firmware | |
170 movlw max_custom_number ; Defined in definitions.asm | |
171 cpfseq EEDATA ; Compare with last version | |
172 bra restart_01 ; New CF, show warning and store new number | |
173 bra restart_1 ; No new CF, continue with boot | |
174 restart_01: | |
175 ; Save new number of current CF count | |
176 rcall display_new_cf_installed; Show warning | |
177 movlw max_custom_number ; Defined in definitions.asm | |
178 movwf EEDATA | |
179 write_int_eeprom d'92' ; Store number of CF used in this firmware | |
180 | |
181 restart_1: | |
182 | |
183 ; Set Debug mode? | |
184 read_int_eeprom d'39' | |
185 bsf debug_mode | |
186 movlw d'1' | |
187 cpfseq EEDATA | |
188 bcf debug_mode ; clear flag if <> 1 | |
189 | |
190 goto surfloop ; Jump to Surfaceloop! | |
191 | |
192 | |
193 display_new_cf_installed: | |
194 call PLED_new_cf_warning ; Display new CF warning screen | |
195 movlw d'20' ; timeout for warning screen | |
196 bra startup_screen3a ; Will RETURN after timeout or button press | |
197 | |
198 restart_set_modes_and_flags: ; "Call"ed from divemode, as well! | |
199 bcf gauge_mode | |
200 bcf FLAG_const_ppO2_mode | |
201 bcf FLAG_apnoe_mode | |
45 | 202 |
203 ; Pre-load modes for OC, GF 90/90 and no Aponoe or Gauge. | |
137 | 204 bcf no_deco_customviews ; Clear no-deco-mode-flag |
45 | 205 movlw d'0' |
206 movwf wait_temp | |
207 movff wait_temp,char_I_deco_model ; Clear Flagbyte | |
208 ; Load GF values into RAM | |
209 movlw d'90' | |
210 movwf wait_temp | |
211 movff wait_temp,char_I_GF_Lo_percentage | |
212 movff wait_temp,char_I_GF_Hi_percentage ; Set to 90/90... | |
0 | 213 clrf EEADRH |
214 read_int_eeprom d'34' ; Read deco data | |
215 movlw d'1' ; Gauge mode | |
216 cpfseq EEDATA | |
217 bra restart_3_test_ppO2_mode; check for ppO2 mode | |
218 bsf gauge_mode ; Set flag for gauge mode | |
137 | 219 bsf no_deco_customviews ; Set no-deco-mode-flag |
0 | 220 return ; start in Surfacemode |
221 restart_3_test_ppO2_mode: | |
222 movlw d'2' ; const ppO2 mode | |
223 cpfseq EEDATA | |
224 bra restart_3_test_apnoe_mode; check for apnoe mode | |
225 bsf FLAG_const_ppO2_mode ; Set flag for ppO2 mode | |
226 return ; start in Surfacemode | |
227 restart_3_test_apnoe_mode: | |
228 movlw d'3' ; Apnoe mode | |
229 cpfseq EEDATA | |
230 bra restart_4_test_gf_mode ; check for GF OC mode | |
231 bsf FLAG_apnoe_mode ; Set flag for Apnoe Mode | |
137 | 232 bsf no_deco_customviews ; Set no-deco-mode-flag |
0 | 233 return ; start in Surfacemode |
234 restart_4_test_gf_mode: | |
235 movlw d'4' ; GF OC mode | |
236 cpfseq EEDATA | |
237 bra restart_5_test_gfO2_mode; check for GF CC mode | |
238 movlw d'1' | |
239 movwf wait_temp | |
240 movff wait_temp,char_I_deco_model ; Set Flagbyte for GF method | |
45 | 241 ; Load GF values into RAM |
242 GETCUSTOM8 d'32' ; GF low | |
243 movff EEDATA,char_I_GF_Lo_percentage | |
244 GETCUSTOM8 d'33' ; GF high | |
245 movff EEDATA,char_I_GF_Hi_percentage | |
0 | 246 return ; start in Surfacemode |
247 restart_5_test_gfO2_mode: | |
248 movlw d'5' ; GF CC mode | |
249 cpfseq EEDATA | |
250 return ; Start in Surfacemode | |
251 bsf FLAG_const_ppO2_mode ; Set flag for ppO2 mode | |
252 movlw d'1' | |
253 movwf wait_temp | |
254 movff wait_temp,char_I_deco_model ; Set Flagbyte for GF method | |
137 | 255 ; Load GF values into RAM |
45 | 256 GETCUSTOM8 d'32' ; GF low |
257 movff EEDATA,char_I_GF_Lo_percentage | |
258 GETCUSTOM8 d'33' ; GF high | |
259 movff EEDATA,char_I_GF_Hi_percentage | |
0 | 260 return ; start in Surfacemode |
261 | |
262 startup_screen1: | |
263 call PLED_ClearScreen | |
264 call PLED_startupscreen1 ; show startup sreen | |
265 startup_screen1_2: | |
266 movlw d'10' ; timeout for startup screen | |
267 movwf temp1 | |
268 WAITMS d'200' | |
269 bcf switch_left | |
270 bcf switch_right | |
271 screen1_loop: | |
272 btfsc onesecupdate ; do every second tasks? | |
273 call set_dive_modes ; tests if depth>threshold | |
274 btfsc onesecupdate ; do every second tasks? | |
275 decf temp1,F | |
276 bcf onesecupdate ; every second tasks done | |
277 | |
278 tstfsz temp1 ; timout occured? | |
279 bra screen1_loop2 ; no | |
280 return | |
281 | |
282 screen1_loop2: | |
283 btfsc divemode ; Divemode active? | |
284 return | |
285 btfsc switch_left ; Ack? | |
286 return | |
287 btfsc switch_right ; Ack? | |
288 return | |
289 bra screen1_loop ; loop screen | |
290 | |
291 startup_screen2: | |
292 call PLED_ClearScreen ; Page 1 | |
293 call PLED_startupscreen2 ; show startup sreen | |
294 bra startup_screen1_2 | |
295 | |
296 startup_screen3a:; WARNING: Also used for decodescriptions and CF Warning screen! | |
297 movwf temp1 | |
298 WAITMS d'200' | |
299 bcf switch_left | |
300 bcf switch_right | |
301 screen3_loop: | |
302 btfsc onesecupdate ; do every second tasks? | |
303 call set_dive_modes ; tests if depth>threshold | |
304 | |
305 btfsc onesecupdate ; do every second tasks? | |
306 decf temp1,F | |
307 bcf onesecupdate ; every second tasks done | |
308 | |
309 tstfsz temp1 ; timout occured? | |
310 bra screen3_loop2 ; no | |
311 return | |
312 screen3_loop2: | |
313 btfsc switch_left ; Ack? | |
314 return | |
315 btfsc switch_right ; Ack? | |
316 return | |
317 bra screen3_loop ; loop screen | |
318 | |
319 init: | |
320 movlw b'01101100' ; 4MHz (x4 PLL) | |
321 movwf OSCCON | |
322 | |
323 movlw b'00010001' ; I/O Ports | |
324 movwf TRISA | |
325 clrf PORTA | |
326 movlw b'00000011' | |
327 movwf TRISB | |
328 clrf PORTB | |
329 movlw b'11011101' ; UART | |
330 movwf TRISC | |
331 clrf PORTC | |
332 movlw b'00000000' | |
333 movwf TRISE | |
334 clrf PORTE | |
335 movlw b'00000000' | |
336 movwf TRISD | |
337 clrf PORTD | |
338 | |
339 movlw b'01000000' ; Bit6: PPL enable | |
340 movwf OSCTUNE | |
341 | |
342 movlw b'00011111' ; Timer0 | |
343 movwf T0CON | |
344 | |
345 movlw b'00000111' ; Timer1 | |
346 movwf T1CON | |
347 | |
348 movlw b'11010000' ; Interrups | |
349 movwf INTCON | |
350 movlw b'00000101' | |
351 movwf INTCON2 | |
352 movlw b'00001000' | |
353 movwf INTCON3 | |
354 movlw b'00100001' | |
355 movwf PIE1 | |
356 movlw b'00000000' | |
357 movwf PIE2 | |
358 clrf RCON | |
359 | |
360 movlw b'00000000' ; A/D Converter | |
361 movwf ADCON0 | |
362 movlw b'00001110' | |
363 movwf ADCON1 | |
364 movlw b'10001010' ; Right justified | |
365 movwf ADCON2 | |
366 | |
367 clrf SSPCON1 ; Set I²C Mode | |
368 movlw b'00000000' | |
369 movwf SSPSTAT | |
370 movlw b'00101000' | |
371 movwf SSPCON1 | |
372 movlw b'00000000' | |
373 movwf SSPCON2 | |
374 movlw d'8' ; 400kHz I2C clock @ 16MHz Fcy | |
375 movwf SSPADD | |
376 | |
377 clrf CCP1CON ; PWM Module off | |
378 clrf ECCP1CON ; PWM Module off | |
379 | |
380 movlw b'00000111' ; Comperator Module off | |
381 movwf CMCON | |
382 | |
383 movlw b'00100000' | |
384 movwf CANCON ; ECAN Module OFF | |
385 | |
386 movlw b'00100100' ; UART | |
387 movwf TXSTA | |
388 movlw b'10010000' | |
389 movwf RCSTA | |
390 movlw b'00001000' | |
391 movwf BAUDCON | |
392 clrf SPBRGH | |
393 movlw d'34' | |
394 movwf SPBRG | |
395 clrf RCREG | |
396 clrf PIR1 | |
397 return |