stc_rpncalc/src/main.c

129 lines
2.7 KiB
C
Raw Normal View History

2019-03-20 05:34:51 +01:00
//
// STC15 RPN calculator
//
#include "stc15.h"
#include <stdint.h>
#include "lcd.h"
2019-03-20 08:21:11 +01:00
#include "key.h"
2019-03-20 05:34:51 +01:00
#include "utils.h"
#define FOSC 11059200
2019-03-22 02:01:17 +01:00
static const char KEY_MAP[20] = {
'c', '<', 'r', 'm',
'/', '9', '8', '7',
'*', '6', '5', '4',
'-', '3', '2', '1',
'+', '=', '.', '0'
};
uint32_t NewKeyBuf[4];
volatile uint8_t new_key_write_i;
volatile uint8_t new_key_read_i;
volatile uint8_t new_key_empty;
#define INCR_NEW_KEY_I(i) i = (i + 1) & 3
volatile uint8_t SecCount;
2019-03-20 05:34:51 +01:00
void timer0_isr() __interrupt 1 __using 1
{
2019-03-22 02:01:17 +01:00
static uint8_t count = 0;
static uint8_t min_count = 0, hour_count = 0;
uint32_t new_keys;
//scan keyboard
KeyScan();
new_keys = GetNewKeys();
if (new_keys != 0){
if (!new_key_empty && (new_key_write_i == new_key_read_i)){
//do not overwrite keymap currently being processed
INCR_NEW_KEY_I(new_key_write_i);
}
NewKeyBuf[new_key_write_i] = new_keys;
INCR_NEW_KEY_I(new_key_write_i);
new_key_empty = 0;
}
2019-03-20 05:34:51 +01:00
}
// Call timer0_isr() 10000/sec: 0.0001 sec
// Initialize the timer count so that it overflows after 0.0001 sec
// THTL = 0x10000 - FOSC / 12 / 10000 = 0x10000 - 92.16 = 65444 = 0xFFA4
void Timer0Init(void) //100us @ 11.0592MHz
{
// TMOD = 0; // default: 16-bit auto-reload
// AUXR = 0; // default: traditional 8051 timer frequency of FOSC / 12
// Initial values of TL0 and TH0 are stored in hidden reload registers: RL_TL0 and RL_TH0
TL0 = 0xA4; // Initial timer value
TH0 = 0xFF; // Initial timer value
TF0 = 0; // Clear overflow flag
TR0 = 1; // Timer0 start run
ET0 = 1; // Enable timer0 interrupt
EA = 1; // Enable global interrupt
}
char buf[17];
/*********************************************/
int main()
{
uint32_t i;
2019-03-22 02:01:17 +01:00
uint8_t j;
const uint8_t* keys;
2019-03-20 08:21:11 +01:00
uint8_t key_i;
2019-03-20 05:34:51 +01:00
Timer0Init(); // display refresh & switch read
LCD_Open();
2019-03-20 08:21:11 +01:00
KeyInit();
2019-03-20 05:34:51 +01:00
P3_4 = 0; //turn on led backlight
i = 0;
2019-03-22 02:01:17 +01:00
j = 0;
2019-03-20 05:34:51 +01:00
// LOOP
while (1)
{
2019-03-20 08:21:11 +01:00
LCD_GoTo(0,0);
2019-03-22 02:01:17 +01:00
//keyboard debug
keys = DebugGetKeys();
2019-03-20 08:21:11 +01:00
for (key_i = 0; key_i < 5; key_i++){
LCD_OutNibble(keys[key_i]);
}
2019-03-22 02:01:17 +01:00
TERMIO_PutChar(',');
2019-03-20 08:21:11 +01:00
//counter
2019-03-22 02:01:17 +01:00
if (SecCount == 0){
LCD_OutString(" ");
} else if (SecCount < 10){
TERMIO_PutChar(' ');
LCD_OutString(u32str(SecCount, buf, 10));
} else {
LCD_OutString(u32str(SecCount, buf, 10));
}
2019-03-20 05:34:51 +01:00
2019-03-22 02:01:17 +01:00
///new keys
if (!new_key_empty){
uint8_t i_key;
uint32_t new_keys = NewKeyBuf[new_key_read_i];
INCR_NEW_KEY_I(new_key_read_i);
if (new_key_read_i == new_key_write_i){
new_key_empty = 1;
}
LCD_GoTo(1,j);
for (i_key = 0; i_key < 20; i_key++){
if (new_keys & ((uint32_t) 1 << i_key)){
TERMIO_PutChar(KEY_MAP[i_key]);
j++;
j &= 0x0f;
break;
}
}
}
2019-03-20 05:34:51 +01:00
}
}
/* ------------------------------------------------------------------------- */