Mercurial > public > hwos_code
comparison src/ostc3.asm @ 0:11d4fc797f74
init
author | heinrichsweikamp |
---|---|
date | Wed, 24 Apr 2013 19:22:45 +0200 |
parents | |
children | e4e662746c02 |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:11d4fc797f74 |
---|---|
1 ;============================================================================= | |
2 ; | |
3 ; File ostc3.asm | |
4 ; | |
5 ; Definition of the ostc3 dive computer platform. | |
6 ; | |
7 ; Copyright (c) 2011, JD Gascuel, HeinrichsWeikamp, all right reserved. | |
8 ;============================================================================= | |
9 ; HISTORY | |
10 ; 2011-05-24 : [jDG] Cleanups from initial Matthias code. | |
11 ; 2011-06-24 : [MH] Added clock speeds. | |
12 #include "ostc3.inc" | |
13 | |
14 ;============================================================================= | |
15 ; | |
16 ;----------------------------- CONFIG --------------------------------- | |
17 ; CONFIG RETEN = OFF ;Disabled - Controlled by SRETEN bit | |
18 ; CONFIG SOSCSEL = HIGH ;High Power SOSC circuit selected | |
19 ; CONFIG XINST = OFF ;Code won't excute in extended mode... | |
20 ; CONFIG FOSC = INTIO2 ;Internal RC oscillator, no clock-out | |
21 ; CONFIG PLLCFG = OFF | |
22 ; CONFIG IESO = OFF ;Disabled | |
23 ; CONFIG PWRTEN = OFF ;Disabled, because incompatible with ICD3 (Ri-400) | |
24 ; CONFIG BOREN = ON ;Controlled with SBOREN bit | |
25 ; CONFIG BORV = 2 ;2.0V | |
26 ; CONFIG BORPWR = MEDIUM ;BORMV set to medium power level | |
27 ; CONFIG WDTEN = ON ;WDT controlled by SWDTEN bit setting | |
28 ; CONFIG WDTPS = 128 ;1:128 | |
29 ; CONFIG RTCOSC = SOSCREF ;RTCC uses SOSC | |
30 ; CONFIG MCLRE = ON ;MCLR Enabled, RG5 Disabled | |
31 ; CONFIG CCP2MX = PORTBE ;RE7-Microcontroller Mode/RB3-All other modes | |
32 ;============================================================================= | |
33 boot CODE | |
34 global init_ostc3 | |
35 | |
36 init_ostc3: | |
37 banksel common ; Bank1 | |
38 ;init oscillator | |
39 movlw b'01110010' | |
40 movwf OSCCON ; 16MHz INTOSC | |
41 movlw b'00001000' | |
42 movwf OSCCON2 ; Secondary Oscillator running | |
43 movlw b'00000000' | |
44 movwf OSCTUNE ; 4x PLL Disable (Bit6) - only works with 8 or 16MHz (=32 or 64MHz) | |
45 bcf RCON,SBOREN ; Bown-Out off | |
46 bcf RCON,IPEN ; Priority Interrupts off | |
47 | |
48 ; I/O Ports | |
49 banksel 0xF16 ; Addresses, F16h through F5Fh, are also used by SFRs, but are not part of the Access RAM. | |
50 | |
51 clrf REFOCON ; No reference oscillator active on REFO pin | |
52 clrf ODCON1 ; Disable Open Drain capability | |
53 clrf ODCON2 ; Disable Open Drain capability | |
54 clrf ODCON3 ; Disable Open Drain capability | |
55 | |
56 movlw b'11000000' ; ANSEL, AN7 and AN6 -> Analog inputs, PORTA is digital. | |
57 movwf ANCON0 | |
58 movlw b'00000000' ; ANSEL | |
59 movwf ANCON1 | |
60 movlw b'00000010' ; ANSEL, AN17 -> Analog input | |
61 movwf ANCON2 | |
62 | |
63 banksel common | |
64 | |
65 movlw b'00000000' ; 1= Input -> Data TFT_high | |
66 movwf TRISA | |
67 movlw b'00000000' ; Init port | |
68 movwf PORTA | |
69 | |
70 movlw b'00001011' ; 1= Input, (RB0, RB1) -> Switches, RB2 -> Power_MCP, RB3 -> lf_data, RB4 -> LED_green, RB5 -> /TFT_POWER | |
71 movwf TRISB | |
72 movlw b'00100000' ; Init port | |
73 movwf PORTB | |
74 | |
75 movlw b'10011010' ; 1= Input, (RC0, RC1) -> SOSC, RC2 -> TFT_LED_PWM, (RC3,RC4) -> I²C, RC5 -> MOSI_MS5541, (RC6, RC7) -> UART1 | |
76 movwf TRISC | |
77 movlw b'00000000' ; Init port | |
78 movwf PORTC | |
79 | |
80 movlw b'00100000' ; 1= Input, RD0 -> TFT_NCS, RD1 -> TFT_RS, RD2 -> TFT_NWR, RD3 -> TFT_RD, RD4 -> MOSI_Flash, RD5 -> MISO_Flash, RD6 -> CLK_Flash, RD7 -> TFT_NRESET | |
81 movwf TRISD | |
82 movlw b'00000000' ; Init port | |
83 movwf PORTD | |
84 | |
85 movlw b'00000000' ; 1= Input, RE1 -> Power_IR, RE2 -> CS_MCP, RE3 -> LED_blue, RE4 -> power_sw1, | |
86 movwf TRISE | |
87 movlw b'00010000' ; Init port | |
88 movwf PORTE | |
89 | |
90 movlw b'00000110' ; 1= Input, (RF1, RF2) -> Analog | |
91 movwf TRISF | |
92 movlw b'00000000' ; Init port | |
93 movwf PORTF | |
94 | |
95 movlw b'00001111' ; 1= Input, <7:6> not implemented, RG0 -> SCLK_MCP, RG2 -> RX2, RG3 -> AN17_RSSI, RG4 -> SOSC_OUT, RG5 -> /RESET | |
96 movwf TRISG | |
97 movlw b'00000000' ; Init port | |
98 movwf PORTG | |
99 | |
100 movlw b'00000000' ; 1= Input -> Data TFT_low | |
101 movwf TRISH | |
102 movlw b'00000000' ; Init port | |
103 movwf PORTH | |
104 | |
105 movlw b'10010000' ; 1= Input, RJ4 -> vusb_in, RJ5 -> power_sw2, RJ6 -> CLK_MS5541, RJ7 -> MISO_MS5541 | |
106 movwf TRISJ | |
107 movlw b'00100000' ; Init port | |
108 movwf PORTJ | |
109 | |
110 | |
111 ; Timer 0 | |
112 ; movlw b'00000000' ; Timer0 with 1:2 prescaler | |
113 movlw b'00001000' ; Timer0 with 1:1 prescaler | |
114 movwf T0CON | |
115 | |
116 ; Timer 1 - Button hold-down timer | |
117 movlw b'10001100' ; 32768Hz clock source, 1:1 Prescaler -> ; 30,51757813µs/bit in TMR1L:TMR1H | |
118 movwf T1CON | |
119 | |
120 banksel 0xF16 ; Addresses, F16h through F5Fh, are also used by SFRs, but are not part of the Access RAM. | |
121 | |
122 ; RTCC | |
123 movlw 0x55 | |
124 movwf EECON2 | |
125 movlw 0xAA | |
126 movwf EECON2 | |
127 bsf RTCCFG,RTCWREN ; Unlock sequence for RTCWREN | |
128 bsf RTCCFG,RTCPTR1 | |
129 bsf RTCCFG,RTCPTR0 | |
130 bsf RTCCFG,RTCEN ; Module enable | |
131 bsf RTCCFG,RTCOE ; Output enable | |
132 movlw b'00000100' ; 32768Hz SOCS on RTCC pin (PORTG,4) Bit7-5: Pullups for Port D, E and J | |
133 movwf PADCFG1 | |
134 movlw b'11000100' | |
135 movwf ALRMCFG ; 1 second alarm | |
136 movlw d'1' | |
137 movwf ALRMRPT ; Alarm repeat counter | |
138 movlw 0x55 | |
139 movwf EECON2 | |
140 movlw 0xAA | |
141 movwf EECON2 | |
142 bcf RTCCFG,RTCWREN ; Lock sequence for RTCWREN | |
143 | |
144 banksel common | |
145 ; A/D Converter | |
146 movlw b'00011000' ; power off ADC, select AN6 | |
147 movwf ADCON0 | |
148 movlw b'00100000' ; 2.048V Vref+ | |
149 movwf ADCON1 | |
150 movlw b'10001101' ; Right justified | |
151 movwf ADCON2 | |
152 | |
153 | |
154 ;init serial port1 (TRISC6/7) | |
155 movlw b'00001000' ; BRG16=1 | |
156 movwf BAUDCON1 | |
157 movlw b'00100100' ; BRGH=1, SYNC=0 | |
158 movwf TXSTA1 | |
159 movlw .34 ; SPBRGH:SPBRG = .34 : 114285 BAUD @ 16MHz (+0,79% Error to 115200 BAUD) | |
160 movwf SPBRG1 ; SPBRGH:SPBRG = .207 : 19230 BAUD @ 16MHz (-0,16% Error to 19200 BAUD) | |
161 clrf SPBRGH1 ; | |
162 movlw b'10010000' | |
163 movwf RCSTA1 | |
164 | |
165 ;init serial port2 (TRISG2) | |
166 banksel BAUDCON2 | |
167 movlw b'00100000' ; BRG16=0 | |
168 movwf BAUDCON2 | |
169 movlw b'00100000' ; BRGH=0, SYNC=0 | |
170 movwf TXSTA2 | |
171 movlw .102 ; SPBRGH:SPBRG = .102 : 2403 BAUD @ 16MHz | |
172 movwf SPBRG2 | |
173 clrf SPBRGH2 | |
174 movlw b'10010000' | |
175 movwf RCSTA2 | |
176 banksel common | |
177 | |
178 ; Timer3 for IR-RX Timeout | |
179 clrf T3GCON ; Reset Timer3 Gate Control register | |
180 ; movlw b'10001101' ; 1:1 Prescaler -> 2seconds@32768Hz, not synced | |
181 movlw b'10001001' ; 1:1 Prescaler -> 2seconds@32768Hz, synced | |
182 ; 30,51757813µs/bit in TMR3L:TMR3H | |
183 movwf T3CON | |
184 | |
185 ; SPI Module(s) | |
186 ; SPI2: External Flash | |
187 movlw b'00110000' | |
188 movwf SSP2CON1 | |
189 movlw b'00000000' | |
190 movwf SSP2STAT | |
191 ; ->0,25MHz Bit clock @1MHz mode (Eco) | |
192 ; -> 4MHz Bit clock @16MHz mode (Normal) | |
193 ; -> 16MHz Bit clock @64MHz mode (Fastest) | |
194 | |
195 ; MSSP1 Module: I2C Master | |
196 movlw b'00101000' ; I2C Master Mode | |
197 movwf SSP1CON1 | |
198 movlw b'00000000' | |
199 movwf SSP1CON2 | |
200 movlw 0x27 | |
201 movwf SSP1ADD ; 100kHz @ 16MHz Fosc | |
202 | |
203 ; PWM Module(s) | |
204 ; PWM1 for LED dimming | |
205 movlw b'00001100' | |
206 movwf CCP1CON | |
207 movlw b'00000001' | |
208 movwf PSTR1CON ; Pulse steering disabled | |
209 movlw d'255' | |
210 movwf PR2 ; Period | |
211 ; 255 is max brightness (300mW) | |
212 clrf CCPR1L ; Duty cycle | |
213 clrf CCPR1H ; Duty cycle | |
214 movlw T2CON_NORMAL | |
215 movwf T2CON | |
216 | |
217 ; Timer5 for ISR-independent wait routines | |
218 clrf T5GCON ; Reset Timer5 Gate Control register | |
219 ; movlw b'10001101' ; 1:1 Prescaler -> 2seconds@32768Hz, not synced | |
220 movlw b'10001001' ; 1:1 Prescaler -> 2seconds@32768Hz, synced | |
221 ; 30,51757813µs/bit in TMR5L:TMR5H | |
222 movwf T5CON | |
223 | |
224 ; Timer7 for 62,5ms Interrupt (Sensor states) | |
225 banksel 0xF16 ; Addresses, F16h through F5Fh, are also used by SFRs, but are not part of the Access RAM. | |
226 clrf T7GCON ; Reset Timer7 Gate Control register | |
227 ; movlw b'10001101' ; 1:1 Prescaler -> 2seconds@32768Hz, not synced | |
228 movlw b'10001001' ; 1:1 Prescaler -> 2seconds@32768Hz, synced | |
229 movwf T7CON | |
230 clrf TMR7L | |
231 movlw .248 | |
232 movwf TMR7H ; -> Rollover after 2048 cycles -> 62,5ms | |
233 | |
234 banksel common | |
235 ; Interrupts | |
236 movlw b'11110000' | |
237 movwf INTCON | |
238 movlw b'10000000' ; BIT7=1: Pullup for PORTB disabled | |
239 movwf INTCON2 | |
240 movlw b'00001000' | |
241 movwf INTCON3 | |
242 movlw b'00000001' ; Bit0: TMR1 | |
243 movwf PIE1 | |
244 movlw b'00000010' ; Bit1: TMR3 | |
245 movwf PIE2 | |
246 movlw b'00000000' ; Bit1: TMR5 | |
247 movwf PIE5 | |
248 movlw b'00100001' ; Bit0: RTCC, Bit5: UART2 | |
249 movwf PIE3 | |
250 movlw b'00001000' ; Bit3: TMR7 | |
251 movwf PIE5 | |
252 | |
253 bsf power_sw1 | |
254 bsf power_sw2 | |
255 | |
256 return | |
257 | |
258 ;============================================================================= | |
259 global speed_eco | |
260 speed_eco: | |
261 movlw d'1' | |
262 movff WREG,speed_setting ; Bank-independent | |
263 ; Done in ISR | |
264 return | |
265 ;============================================================================= | |
266 global speed_normal | |
267 speed_normal: | |
268 movlw d'2' | |
269 movff WREG,speed_setting ; Bank-independent | |
270 ; Done in ISR | |
271 return | |
272 ;============================================================================= | |
273 global speed_fastest | |
274 speed_fastest: | |
275 movlw d'3' | |
276 movff WREG,speed_setting ; Bank-independent | |
277 ; Done in ISR | |
278 return | |
279 ;============================================================================= | |
280 | |
281 END |