preparation for display off action

This commit is contained in:
olikraus 2017-05-12 17:27:54 +02:00
parent 093742ca3d
commit c9b1bdd74b
4 changed files with 112 additions and 36 deletions

View File

@ -14,6 +14,8 @@ void do_reset(void)
/* clear the display first, to provide some visual feedback to the user */ /* clear the display first, to provide some visual feedback to the user */
u8g2_ClearDisplay(gui_menu.u8g2); u8g2_ClearDisplay(gui_menu.u8g2);
__disable_irq();
/* Deactivate tamper so that the uC can be programmed via UART */ /* Deactivate tamper so that the uC can be programmed via UART */
/* This is required, because RX pin is shared with Tamp2 */ /* This is required, because RX pin is shared with Tamp2 */
@ -156,6 +158,7 @@ void set_time(uint8_t ht, uint8_t ho, uint8_t mt, uint8_t mo, uint8_t st, uint8_
v <<= 4; v <<= 4;
v |= so; v |= so;
__disable_irq();
RTC->WPR = 0x0ca; /* disable RTC write protection */ RTC->WPR = 0x0ca; /* disable RTC write protection */
RTC->WPR = 0x053; RTC->WPR = 0x053;
@ -168,6 +171,7 @@ void set_time(uint8_t ht, uint8_t ho, uint8_t mt, uint8_t mo, uint8_t st, uint8_
RTC->WPR = 0; /* enable RTC write protection */ RTC->WPR = 0; /* enable RTC write protection */
RTC->WPR = 0; RTC->WPR = 0;
__enable_irq();
} }
@ -197,6 +201,7 @@ void set_date(uint8_t yt, uint8_t yo, uint8_t mt, uint8_t mo, uint8_t dayt, uint
v <<= 4; v <<= 4;
v |= dayo; v |= dayo;
__disable_irq();
RTC->WPR = 0x0ca; /* disable RTC write protection */ RTC->WPR = 0x0ca; /* disable RTC write protection */
RTC->WPR = 0x053; RTC->WPR = 0x053;
@ -209,5 +214,6 @@ void set_date(uint8_t yt, uint8_t yo, uint8_t mt, uint8_t mo, uint8_t dayt, uint
RTC->WPR = 0; /* enable RTC write protection */ RTC->WPR = 0; /* enable RTC write protection */
RTC->WPR = 0; RTC->WPR = 0;
__enable_irq();
} }

View File

@ -1,15 +1,18 @@
/* /*
RTC for the STM32L031 Clock for the STM32L031
EXTI line EXTI line
17 RTC alarm 17 RTC alarm
19 RTC tamper & timestamp & CSS_LSE 19 RTC tamper & timestamp & CSS_LSE
20 RTC wakeup timer 20 RTC wakeup timer
PA0 TAMP2 Button
PA2 TAMP3 Button
__enable_irq()
__disable_irq() __enable_irq();
__disable_irq();
*/ */
@ -26,7 +29,7 @@
/* delay until other another button press is accepted */ /* delay until other another button press is accepted */
/* time is in systicks (50ms) */ /* time is in systicks (50ms) */
#define TAMPER_SYSTICK_DELAY 6 #define TAMPER_SYSTICK_DELAY 20
/* delay until the menu goes back time display and standby mode */ /* delay until the menu goes back time display and standby mode */
/* delay in systicks (50ms) */ /* delay in systicks (50ms) */
@ -36,7 +39,7 @@
#define MENU_IDLE_SYSTICK_TIMEOUT (20*18) #define MENU_IDLE_SYSTICK_TIMEOUT (20*18)
/* wakeup period: The uC will wake up after the specified number of seconds */ /* wakeup period: The uC will wake up after the specified number of seconds */
/* the value is one less the intended number of seconds: /* the value is one less the intended number of seconds: */
/* 0: wakeup every 1 second */ /* 0: wakeup every 1 second */
/* 14: wakeup every 15 seconds */ /* 14: wakeup every 15 seconds */
/* 29: wakeup every 30 seconds */ /* 29: wakeup every 30 seconds */
@ -62,12 +65,14 @@ uint8_t u8x8_gpio_and_delay_stm32l0(u8x8_t *u8x8, uint8_t msg, uint8_t arg_int,
volatile unsigned long SysTickCount = 0; volatile unsigned long SysTickCount = 0;
volatile unsigned long RTCWUCount = 0; volatile unsigned long RTCWUCount = 0;
volatile unsigned long RTCIRQCount = 0; volatile unsigned long RTCIRQCount = 0;
volatile unsigned long isIgnoreNextKey = 0;
volatile unsigned long Tamper2Count = 0; volatile unsigned long Tamper2Count = 0;
volatile unsigned long Tamper3Count = 0; volatile unsigned long Tamper3Count = 0;
volatile unsigned long MenuIdleTimer = 0; volatile unsigned long MenuIdleTimer = 0;
volatile unsigned long PWR_CSR_Backup; volatile unsigned long PWR_CSR_Backup;
volatile unsigned long ResetReason = RESET_REASON_POR; volatile unsigned long ResetReason = RESET_REASON_POR;
rtc_t rtc; rtc_t rtc;
u8g2_t u8g2; u8g2_t u8g2;
@ -76,17 +81,45 @@ u8g2_t u8g2;
void __attribute__ ((interrupt, used)) SysTick_Handler(void) void __attribute__ ((interrupt, used)) SysTick_Handler(void)
{ {
int is_t2 = 0;
int is_t3 = 0;
SysTickCount++; SysTickCount++;
/* read the tamper/button state */
/* this is more complicated, because there are no external pull ups for the buttons */
/* pull ups can be activated via GPIO, but are disabled if the pin is configured as tamper input */
/* As a consequence, we have to disable tamper (so that the internal pullups are active), then */
/* after some delay, get the GPIO value of the tamper input and restore tamper status */
if ( Tamper2Count > 0 || Tamper3Count > 0 )
{
RTC->WPR = 0x0ca; /* disable RTC write protection */
RTC->WPR = 0x053;
RTC->TAMPCR &= ~RTC_TAMPCR_TAMP2E; /* disable tamper so that we can do normal GPIO access */
RTC->TAMPCR &= ~RTC_TAMPCR_TAMP3E; /* disable tamper so that we can do normal GPIO access */
__NOP(); /* add delay after disable tamper so that GPIO can read the value */
__NOP();
is_t2 = (GPIOA->IDR & GPIO_IDR_ID0) != 0 ? 1 : 0;
is_t3 = (GPIOA->IDR & GPIO_IDR_ID2) != 0 ? 1 : 0;
RTC->TAMPCR |= RTC_TAMPCR_TAMP2E; /* enable tamper */
RTC->TAMPCR |= RTC_TAMPCR_TAMP3E; /* enable tamper */
RTC->WPR = 0; /* enable RTC write protection */
RTC->WPR = 0;
}
if ( Tamper3Count > 0 ) if ( Tamper3Count > 0 )
{ {
MenuIdleTimer = 0;
Tamper3Count--; Tamper3Count--;
if ( Tamper3Count == 0 ) /* check for timeout or whether the user has released the button */
if ( Tamper3Count == 0 || is_t3 )
{ {
//enableRCCRTCWrite(); Tamper3Count = 0;
RTC->ISR &= ~RTC_ISR_TAMP3F; /* clear tamper flag, allow new tamper event */ RTC->ISR &= ~RTC_ISR_TAMP3F; /* clear tamper flag, allow new tamper event */
//disableRCCRTCWrite();
} }
} }
else else
@ -96,13 +129,12 @@ void __attribute__ ((interrupt, used)) SysTick_Handler(void)
if ( Tamper2Count > 0 ) if ( Tamper2Count > 0 )
{ {
MenuIdleTimer = 0;
Tamper2Count--; Tamper2Count--;
if ( Tamper2Count == 0 ) /* check for timeout or whether the user has released the button */
if ( Tamper2Count == 0 || is_t2)
{ {
//enableRCCRTCWrite(); Tamper2Count = 0;
RTC->ISR &= ~RTC_ISR_TAMP2F; /* clear tamper flag, allow new tamper event */ RTC->ISR &= ~RTC_ISR_TAMP2F; /* clear tamper flag, allow new tamper event */
//disableRCCRTCWrite();
} }
} }
else else
@ -140,14 +172,22 @@ void __attribute__ ((interrupt, used)) RTC_IRQHandler(void)
//RTC->ISR &= ~RTC_ISR_TAMP2F; //RTC->ISR &= ~RTC_ISR_TAMP2F;
if ( RTC->ISR & RTC_ISR_TAMP3F ) if ( RTC->ISR & RTC_ISR_TAMP3F )
{
if ( isIgnoreNextKey == 0 )
{ {
key_add(KEY_NEXT); key_add(KEY_NEXT);
}
isIgnoreNextKey = 0;
MenuIdleTimer = 0; MenuIdleTimer = 0;
Tamper3Count = TAMPER_SYSTICK_DELAY; Tamper3Count = TAMPER_SYSTICK_DELAY;
} }
if ( RTC->ISR & RTC_ISR_TAMP2F ) if ( RTC->ISR & RTC_ISR_TAMP2F )
{
if ( isIgnoreNextKey == 0 )
{ {
key_add(KEY_SELECT); key_add(KEY_SELECT);
}
isIgnoreNextKey = 0;
MenuIdleTimer = 0; MenuIdleTimer = 0;
Tamper2Count = TAMPER_SYSTICK_DELAY; Tamper2Count = TAMPER_SYSTICK_DELAY;
} }
@ -166,6 +206,7 @@ void __attribute__ ((interrupt, used)) RTC_IRQHandler(void)
*/ */
void startUp(void) void startUp(void)
{ {
RCC->IOPENR |= RCC_IOPENR_IOPAEN; /* Enable clock for GPIO Port A */ RCC->IOPENR |= RCC_IOPENR_IOPAEN; /* Enable clock for GPIO Port A */
RCC->APB1ENR |= RCC_APB1ENR_PWREN; /* enable power interface */ RCC->APB1ENR |= RCC_APB1ENR_PWREN; /* enable power interface */
PWR->CR |= PWR_CR_DBP; /* activate write access to RCC->CSR and RTC */ PWR->CR |= PWR_CR_DBP; /* activate write access to RCC->CSR and RTC */
@ -173,6 +214,18 @@ void startUp(void)
PWR_CSR_Backup = PWR->CSR; /* create a backup of the original PWR_CSR register for later analysis */ PWR_CSR_Backup = PWR->CSR; /* create a backup of the original PWR_CSR register for later analysis */
PWR->CR |= PWR_CR_CSBF; /* clear the standby flag in the PWR_CSR register, but luckily we have a copy */ PWR->CR |= PWR_CR_CSBF; /* clear the standby flag in the PWR_CSR register, but luckily we have a copy */
PWR->CR |= PWR_CR_CWUF; /* also clear the WUF flag in PWR_CSR */ PWR->CR |= PWR_CR_CWUF; /* also clear the WUF flag in PWR_CSR */
/* PA0, TAMP2, button input */
GPIOA->MODER &= ~GPIO_MODER_MODE0; /* clear mode for PA0 */
GPIOA->PUPDR &= ~GPIO_PUPDR_PUPD0; /* no pullup/pulldown for PA0 */
GPIOA->PUPDR |= GPIO_PUPDR_PUPD0_0; /* pullup for PA0 */
/* PA2, TAMP3, button input */
GPIOA->MODER &= ~GPIO_MODER_MODE2; /* clear mode for PA2 */
GPIOA->PUPDR &= ~GPIO_PUPDR_PUPD2; /* no pullup/pulldown for PA2 */
GPIOA->PUPDR |= GPIO_PUPDR_PUPD2_0; /* pullup for PA2 */
} }
/*=======================================================================*/ /*=======================================================================*/
@ -276,6 +329,8 @@ void initRTC(void)
/* real time clock enable */ /* real time clock enable */
//enableRCCRTCWrite(); //enableRCCRTCWrite();
__disable_irq();
RTC->WPR = 0x0ca; /* disable RTC write protection */ RTC->WPR = 0x0ca; /* disable RTC write protection */
RTC->WPR = 0x053; RTC->WPR = 0x053;
@ -308,6 +363,7 @@ void initRTC(void)
RTC->WPR = 0; /* enable RTC write protection */ RTC->WPR = 0; /* enable RTC write protection */
RTC->WPR = 0; RTC->WPR = 0;
__enable_irq();
} }
/*=======================================================================*/ /*=======================================================================*/
@ -320,6 +376,7 @@ void startRTCWakeUp(void)
{ {
/* wake up time setup & start */ /* wake up time setup & start */
__disable_irq();
RTC->WPR = 0x0ca; /* disable RTC write protection */ RTC->WPR = 0x0ca; /* disable RTC write protection */
RTC->WPR = 0x053; RTC->WPR = 0x053;
@ -356,6 +413,7 @@ void startRTCWakeUp(void)
RTC->WPR = 0; /* disable RTC write protection */ RTC->WPR = 0; /* disable RTC write protection */
RTC->WPR = 0; RTC->WPR = 0;
__enable_irq();
} }
/* read values from RTC and store the values into the gui_data struct */ /* read values from RTC and store the values into the gui_data struct */
@ -427,9 +485,6 @@ int main()
startUp(); /* basic system setup + make a backup of PWR_CSR (PWR_CSR_Backup), must be executed after each reset */ startUp(); /* basic system setup + make a backup of PWR_CSR (PWR_CSR_Backup), must be executed after each reset */
startSysTick(); /* start the sys tick interrupt, must be executed after each reset */ startSysTick(); /* start the sys tick interrupt, must be executed after each reset */
RCC->IOPENR |= RCC_IOPENR_IOPAEN; /* Enable clock for GPIO Port A */
__NOP();
__NOP();
/* LED output line */ /* LED output line */
GPIOA->MODER &= ~GPIO_MODER_MODE13; /* clear mode for PA13 */ GPIOA->MODER &= ~GPIO_MODER_MODE13; /* clear mode for PA13 */
@ -440,16 +495,6 @@ int main()
GPIOA->BSRR = GPIO_BSRR_BR_13; /* atomic clr PA13 */ GPIOA->BSRR = GPIO_BSRR_BR_13; /* atomic clr PA13 */
GPIOA->BSRR = GPIO_BSRR_BS_13; /* atomic set PA13 */ GPIOA->BSRR = GPIO_BSRR_BS_13; /* atomic set PA13 */
/* PA0, button input */
GPIOA->MODER &= ~GPIO_MODER_MODE0; /* clear mode for PA0 */
GPIOA->PUPDR &= ~GPIO_PUPDR_PUPD0; /* no pullup/pulldown for PA0 */
GPIOA->PUPDR |= GPIO_PUPDR_PUPD0_0; /* pullup for PA0 */
/* PA2, button input */
GPIOA->MODER &= ~GPIO_MODER_MODE2; /* clear mode for PA2 */
GPIOA->PUPDR &= ~GPIO_PUPDR_PUPD2; /* no pullup/pulldown for PA2 */
GPIOA->PUPDR |= GPIO_PUPDR_PUPD2_0; /* pullup for PA2 */
/* the lowest two bits of the PWR_CSR reg indicate wake up from standby (bit 1) and WUF als source (bit 0) */ /* the lowest two bits of the PWR_CSR reg indicate wake up from standby (bit 1) and WUF als source (bit 0) */
/* both bits are 0 for POR and button reset, both bits are 1 for a wakeup reset */ /* both bits are 0 for POR and button reset, both bits are 1 for a wakeup reset */
@ -478,8 +523,6 @@ int main()
break; break;
} }
if ( ResetReason == RESET_REASON_POR || ResetReason == RESET_REASON_NVIC_RESET ) if ( ResetReason == RESET_REASON_POR || ResetReason == RESET_REASON_NVIC_RESET )
{ {
/* Power on reset */ /* Power on reset */
@ -494,14 +537,20 @@ int main()
/* we probably have to clear the RTC detection flags for WUF and TAMPER */ /* we probably have to clear the RTC detection flags for WUF and TAMPER */
/* this is done later in startRTCWakeUp() */ /* this is done later in startRTCWakeUp() */
readRTC(); readRTC();
/* do a warm start of the display, this means that the display reset is skipped and the init sequence is not sent */ /* do a warm start of the display, this means that the display reset is skipped and the init sequence is not sent */
initDisplay(0); /* init display assumes proper values in gui_data, additionally the alarm flag might be set here */ initDisplay(0); /* init display assumes proper values in gui_data, additionally the alarm flag might be set here */
} }
startRTCWakeUp(); /* setup wakeup and temper, probably required after each reset */
/* before the RTC is enabled via startRTCWakeUp(), avoid key detection if required */
/*
if ( ResetReason == RESET_REASON_TAMP2 || ResetReason == RESET_REASON_TAMP3 )
isIgnoreNextKey = 1;
*/
startRTCWakeUp(); /* setup wakeup and temper, enable RTC IRQ, probably required after each reset */
NVIC_SetPriority(RTC_IRQn, 0); NVIC_SetPriority(RTC_IRQn, 0);
NVIC_EnableIRQ(RTC_IRQn); NVIC_EnableIRQ(RTC_IRQn);

View File

@ -109,8 +109,14 @@ https://www.bengs-modellbau.de/zubehoerteile/flasche-und-fittings/
Auch nicht schlecht: Auch nicht schlecht:
https://knupfer.info/shop/index.php/deutsch/profile-rohre/kupferrohr.html https://knupfer.info/shop/index.php/deutsch/profile-rohre/kupferrohr.html
kupferrohrflöte kupferrohrflöte, obertonflöte
http://www.spiritsoundart.de/shop/obertonfloeten-aus-kupfer/ http://www.spiritsoundart.de/shop/obertonfloeten-aus-kupfer/
http://www.maxbrumbergflutes.eu/floeten/obertonfloeten/
englisch
https://en.wikipedia.org/wiki/Overtone_flute
Didgeridoo
=========== ===========

View File

@ -386,6 +386,15 @@ int main()
rtc_register_to_bcd(&rtc); rtc_register_to_bcd(&rtc);
rtc_bcd_to_ymd_hms(&rtc); rtc_bcd_to_ymd_hms(&rtc);
rtc_draw_time(&rtc, &u8g2); rtc_draw_time(&rtc, &u8g2);
RTC->WPR = 0x0ca; /* disable RTC write protection */
RTC->WPR = 0x053;
RTC->TAMPCR &= ~RTC_TAMPCR_TAMP3E;
RTC->TAMPCR &= ~RTC_TAMPCR_TAMP2E;
__NOP(); /* add delay after disable tamper so that GPO can read the value */
__NOP();
if ( GPIOA->IDR & GPIO_IDR_ID0 ) if ( GPIOA->IDR & GPIO_IDR_ID0 )
u8g2_DrawStr(&u8g2, 15, 45, "+"); u8g2_DrawStr(&u8g2, 15, 45, "+");
else else
@ -395,6 +404,12 @@ int main()
else else
u8g2_DrawStr(&u8g2, 0, 45, "-"); u8g2_DrawStr(&u8g2, 0, 45, "-");
RTC->TAMPCR |= RTC_TAMPCR_TAMP3E;
RTC->TAMPCR |= RTC_TAMPCR_TAMP2E;
RTC->WPR = 0; /* enable RTC write protection */
RTC->WPR = 0;
u8g2_DrawStr(&u8g2, 30,45, u8x8_u8toa(RTCIRQCount, 3)); u8g2_DrawStr(&u8g2, 30,45, u8x8_u8toa(RTCIRQCount, 3));
u8g2_DrawStr(&u8g2, 90,45, u8x8_u8toa(key_queue_start, 2)); u8g2_DrawStr(&u8g2, 90,45, u8x8_u8toa(key_queue_start, 2));