-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathclock.c
102 lines (88 loc) · 2.58 KB
/
clock.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
//
// clock.c
// cxg-60ewt
//
// Created by Leonid Mesentsev on 26/11/2019.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
//
#include <clock.h>
#include <main.h>
#define BEEP_DURATION 100
extern struct EEPROM_DATA _eepromData;
// internal clock counter, will overflow every 49 days ;)
volatile uint32_t _currentMsecs = 0;
volatile uint8_t _beep1 = 0;
volatile uint8_t _beep2 = 0;
volatile uint8_t _duration = 0;
void TIM4_overflow_handler() __interrupt(TIM4_UPD_OVF)
{
static uint8_t localCnt = 0;
if (localCnt++ % 2) // 1kHz clock, 1mS
_currentMsecs++;
TIM4_SR &= ~1;
if (_beep1 < BEEP_DURATION)
{
if (localCnt % 2) // 500Hz
PA_ODR ^= (1 << 3);
_beep1++;
}
else if (_beep2 < BEEP_DURATION) // 1kHz
{
PA_ODR ^= (1 << 3);
_beep2++;
}
else if (_duration) // repeat
{
_beep1 = _beep2 = 0;
_duration--;
}
}
void TIM4_init()
{
PA_DDR |= (1 << 3); // configure PA3 as output
PA_CR1 |= (1 << 3); // push-pull mode
PA_CR2 |= (1 << 3); // push-pull mode
// F = F_CPU / ( 2 ^ Prescaler * ( 1 + ARR ) )
// F = 16 MHz / ( 64 * ( 1 + 124 ) ) = 2kHz
TIM4_PSCR = 6;
TIM4_ARR = 0x7c;
TIM4_IER = (1 << TIM4_IER_UIE);
TIM4_CR1 = (1 << TIM4_CR1_CEN);
}
void beep()
{
if (!_eepromData.enableSound)
return;
_beep1 = 0;
_beep2 = 0;
_duration = 0;
}
void beepAlarm()
{
if (!_eepromData.enableSound)
return;
_beep1 = 0;
_beep2 = 0;
_duration = 3;
}
uint32_t currentMillis()
{
return _currentMsecs;
}