3 * Config & Main routine.
4 * Copyright (C) 2013-06-10 K.Ohta <whatisthis.sowhat ai gmail.com>
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2,
10 * or (at your option) any later version.
11 * This library / program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
14 * See the GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this library; see the file COPYING. If not, write to the
18 * Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston,
21 * As a special exception, if you link this(includeed from sdcc) library
22 * with other files, some of which are compiled with SDCC,
23 * to produce an executable, this library does not by itself cause
24 * the resulting executable to be covered by the GNU General Public License.
25 * This exception does not however invalidate any other reasons why
26 * the executable file might be covered by the GNU General Public License.
36 #include <pic18fregs.h> /* ONLY FOR PIC18x */
48 #include "lcd_acm1602.h"
55 #include "i2c_eeprom.h"
56 #include "backlight.h"
62 #if defined(pic18f23k22) || defined(pic18f24k22) || defined(pic18f25k22) || defined(pic18f26k22)
63 //#pragma stack 0x200 256 // Set stack size to 256bytes.
64 #pragma config FOSC=INTIO67,BORV=190,BOREN=ON,PWRTEN=ON
65 #pragma config WDTEN=ON,WDTPS=32768
66 #pragma config PBADEN=OFF,MCLRE=EXTMCLR,STVREN=ON,LVP=OFF,DEBUG=ON,XINST=ON
67 //#pragma config PBADEN=OFF,MCLRE=EXTMCLR,STVREN=ON,LVP=OFF//,XINST=ON
68 #pragma config CP0=OFF,CP1=OFF,CPB=OFF,CPD=OFF
69 #pragma config WRT0=OFF,WRT1=OFF,WRTB=OFF,WRTC=OFF,WRTD=OFF
70 #pragma config EBTR0=OFF,EBTR1=OFF,EBTRB=OFF
72 // For 4xK20 or 2xK20 Series
73 #if defined(pic18f43k20) || defined(pic18f44k20) || defined(pic18f45k20) || defined(pic18f46k20) || \
74 defined(pic18f23k20) || defined(pic18f24k20) || defined(pic18f25k20) || defined(pic18f26k20) || \
75 defined(_18F43K20) || defined(_18F44K20) || defined(_18F45K20) || defined(_18F46K20) || \
76 defined(_18F23K20) || defined(_18F24K20) || defined(_18F25K20) || defined(_18F26K20)
79 #pragma stack 0x200 256
82 #pragma config FOSC=HS,FCMEN=ON,PWRT=ON,BOREN=NOSLP,BORV=27, \
83 WDTEN=ON,WDTPS=32768,PBADEN=OFF,HFOFST=OFF,LPT1OSC=OFF, \
84 MCLRE=ON,STVREN=ON,DEBUG=ON,LVP=OFF, \
93 unsigned char stereoflag;
94 unsigned char tuneflag;
95 unsigned char cnrlevel;
97 unsigned int batlevel_6955;
98 unsigned int battlevel;
99 unsigned char ui_idlekey;
100 unsigned char ui_idlepad;
103 unsigned char pollkeybuf[33];
105 //#define _LCD_DEBUG 1
107 void TMR0_handler(void)
109 SIGHANDLER(TMR0_handler)
114 T0CONbits.TMR0ON = 0;
116 // Clear interrupt flag
117 // INTCONbits.TMR0IF = 0;
118 INTCONbits.TMR0IE = 0;;
123 * Interrupt wake up every 1ms.
126 void TMR1_Handler(void)
128 SIGHANDLER(TMR1_Handler)
138 void TMR3_Handler(void)
140 SIGHANDLER(TMR3_Handler)
149 void EXINT_Handler(void)
151 SIGHANDLER(EXINT_Handler)
154 INTCONbits.INT0IE = 0;
155 INTCONbits.INT0IF = 0;
156 INTCON3bits.INT1IF = 0;
157 INTCON3bits.INT2IF = 0;
158 INTCON3bits.INT1IE = 0;
159 INTCON3bits.INT2IE = 0;
163 void RBIF_handler(void)
165 SIGHANDLER(RBIF_handler)
169 // if(chk_powerbutton(0, 0) != 0) { // If pressed on
174 void EEPROM_handler(void)
176 SIGHANDLER(EEPROM_handler)
181 // if(chk_powerbutton(0, 0) != 0) { // If pressed on
187 void INADC_handler(void)
189 SIGHANDLER(INADC_handler)
195 // battlevel = adc_rawtobatt(a);
200 void I2C_handler(void)
202 SIGHANDLER(I2C_handler)
208 void I2CBus_handler(void)
210 SIGHANDLER(I2CBus_handler)
219 DEF_INTLOW(intlow_handler)
220 DEF_HANDLER(SIG_TMR0, TMR0_handler)
221 DEF_HANDLER(SIG_INT0, EXINT_Handler)
222 // DEF_HANDLER(SIG_TMR3, TMR3_Handler)
225 DEF_INTHIGH(inthigh_handler)
226 DEF_HANDLER(SIG_RBIF, RBIF_handler)
227 // DEF_HANDLER(SIG_EEIF, EEPROM_handler)
228 // DEF_HANDLER(SIG_TMR1, TMR1_Handler)
229 // DEF_HANDLER(SIG_INT1, EXINT_Handler)
230 DEF_HANDLER(SIG_INT2, EXINT_Handler)
231 DEF_HANDLER(SIG_AD, INADC_handler)
232 //DEF_HANDLER(SIG_SSP, I2C_handler)
233 //DEF_HANDLER(SIG_BCOL, I2CBus_handler)
236 void interrupt low_priority intlow_handler(void)
238 if(INTCONbits.TMR0IF) TMR0_handler();
239 if(INTCONbits.INT0IF) EXINT_Handler();
240 // if(PIR1bits.TMR1IF) TMR1_Handler();
243 void interrupt high_priority inthigh_handler(void)
245 if(INTCONbits.RBIF) RBIF_handler();
246 // if(PIR2bits.EEIF) EEPROM_handler();
247 if(PIR1bits.TMR1IF) TMR1_Handler();
248 // if(PIR2bits.TMR3IF) TMR3_Handler();
249 // if(INTCON3bits.INT1IF) EXINT_Handler();
250 // if(INTCON3bits.INT2IF) EXINT_Handler();
251 if(PIR1bits.ADIF) INADC_handler();
253 // if(PIR1bits.SSPIF) I2C_handler();
266 // idle_time_ms(100);
267 printhelp_2lines("Low battery X)", "Press key to suspend");
274 unsigned char pbutton;
275 unsigned char reset_status;
277 unsigned char lvcount = 0;
278 unsigned char dispf = 0xff;
282 OSCCON = (0x80 & 0b11111100) | 0b00111000;
283 // OSCCON = (0x80 & 0b11111100) | 0b00110010; // 8MHz
288 reset_status = chk_reset();
289 idle_time_ms(300); // Wait for setup.
290 WDTCONbits.SWDTEN = 0; // WDT OFF.
291 switch(reset_status){
294 shutdown(0); // Save and halt on BOR.
296 case RESET_SOFTWARE: //
298 pbutton = chk_powerbutton();
299 if(pbutton == 0) shutdown(0); // Not-Pressed power-button -> shutdown( not save).
302 case RESET_WDT: // Workaround random reset.
308 WDTCONbits.SWDTEN = 1; // WDT ON.
313 acm1602_init(LCD_I2CADDR, 1); //Init LCD
314 lcd_setbacklight(0xff, 255);
317 /* Push default parameters to AKC6955*/
325 ui_idlekey = setup.ui_idlecount / 92;
326 ui_idlepad = setup.ui_idlecount % 23;
334 if(battlevel < 340) { // 3.4V
338 acm1602_resume(LCD_I2CADDR);
341 lowbatt(); //Zap 4Times on LowVoltage.
350 for(i = 0; i < 4; i++) {
351 c = pollkey_single_timeout(ui_idlekey, 1); // 23*41 = 943ms
353 if(c != charcode_null) {
356 acm1602_resume(LCD_I2CADDR);
367 if((setup.fm == 0) && (setup.amband == AKC6955_BAND_MW2)) {
368 step = renc_count * 3;
374 if(renc_dir == RENC_LEFT) {
375 akc6955_down_freq(step);
377 } else if(renc_dir == RENC_RIGHT) {
378 akc6955_up_freq(step);
386 dispf = backlight_dec(dispf);
387 if(dispf != 0) update_display();
388 if(ui_idlepad != 0) idle_time_ms(ui_idlepad);