/**************************************************************************** * Tu May 22 21:23:51 2020 * Copyright 2020 Dirk Brosswick * Email: dirk.brosswick@googlemail.com ****************************************************************************/ /* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include "config.h" #include #include #include "bma.h" #include "powermgm.h" #include "gui/statusbar.h" EventGroupHandle_t bma_event_handle = NULL; bma_config_t bma_config[ BMA_CONFIG_NUM ]; __NOINIT_ATTR uint32_t stepcounter_valid; __NOINIT_ATTR uint32_t stepcounter_before_reset; __NOINIT_ATTR uint32_t stepcounter; void IRAM_ATTR bma_irq( void ); /* * */ void bma_setup( TTGOClass *ttgo ) { bma_event_handle = xEventGroupCreate(); for ( int i = 0 ; i < BMA_CONFIG_NUM ; i++ ) { bma_config[ i ].enable = true; } if ( stepcounter_valid != 0xa5a5a5a5 ) { stepcounter = 0; stepcounter_before_reset = 0; stepcounter_valid = 0xa5a5a5a5; log_i("stepcounter not valid. reset"); } stepcounter = stepcounter + stepcounter_before_reset; bma_read_config(); ttgo->bma->begin(); ttgo->bma->attachInterrupt(); ttgo->bma->direction(); pinMode( BMA423_INT1, INPUT ); attachInterrupt( BMA423_INT1, bma_irq, RISING ); bma_reload_settings(); } void bma_standby( void ) { TTGOClass *ttgo = TTGOClass::getWatch(); log_i("go standby"); if ( bma_get_config( BMA_STEPCOUNTER ) ) ttgo->bma->enableStepCountInterrupt( false ); } void bma_wakeup( void ) { TTGOClass *ttgo = TTGOClass::getWatch(); log_i("go wakeup"); if ( bma_get_config( BMA_STEPCOUNTER ) ) ttgo->bma->enableStepCountInterrupt( true ); stepcounter_before_reset = ttgo->bma->getCounter(); statusbar_update_stepcounter( stepcounter + ttgo->bma->getCounter() ); } /* * */ void bma_reload_settings( void ) { TTGOClass *ttgo = TTGOClass::getWatch(); ttgo->bma->enableStepCountInterrupt( bma_config[ BMA_STEPCOUNTER ].enable ); ttgo->bma->enableWakeupInterrupt( bma_config[ BMA_DOUBLECLICK ].enable ); } /* * */ void IRAM_ATTR bma_irq( void ) { BaseType_t xHigherPriorityTaskWoken = pdFALSE; xEventGroupSetBitsFromISR( bma_event_handle, BMA_EVENT_INT, &xHigherPriorityTaskWoken ); if ( xHigherPriorityTaskWoken ) { portYIELD_FROM_ISR (); } } /* * loop routine for handling IRQ in main loop */ void bma_loop( TTGOClass *ttgo ) { /* * handle IRQ event */ if ( xEventGroupGetBitsFromISR( bma_event_handle ) & BMA_EVENT_INT ) { setCpuFrequencyMhz(240); while( !ttgo->bma->readInterrupt() ); if ( ttgo->bma->isDoubleClick() ) { powermgm_set_event( POWERMGM_BMA_WAKEUP ); xEventGroupClearBitsFromISR( bma_event_handle, BMA_EVENT_INT ); return; } } if ( !powermgm_get_event( POWERMGM_STANDBY ) && xEventGroupGetBitsFromISR( bma_event_handle ) & BMA_EVENT_INT ) { stepcounter_before_reset = ttgo->bma->getCounter(); statusbar_update_stepcounter( stepcounter + ttgo->bma->getCounter() ); xEventGroupClearBitsFromISR( bma_event_handle, BMA_EVENT_INT ); } } /* * */ void bma_save_config( void ) { fs::File file = SPIFFS.open( BMA_COFIG_FILE, FILE_WRITE ); if ( !file ) { log_e("Can't save file: %s", BMA_COFIG_FILE ); } else { file.write( (uint8_t *)bma_config, sizeof( bma_config ) ); file.close(); } } /* * */ void bma_read_config( void ) { fs::File file = SPIFFS.open( BMA_COFIG_FILE, FILE_READ ); if (!file) { log_e("Can't open file: %s!", BMA_COFIG_FILE ); } else { int filesize = file.size(); if ( filesize > sizeof( bma_config ) ) { log_e("Failed to read configfile. Wrong filesize!" ); } else { file.read( (uint8_t *)bma_config, filesize ); } file.close(); } } /* * */ bool bma_get_config( int config ) { if ( config < BMA_CONFIG_NUM ) { return( bma_config[ config ].enable ); } return false; } /* * */ void bma_set_config( int config, bool enable ) { if ( config < BMA_CONFIG_NUM ) { bma_config[ config ].enable = enable; bma_save_config(); bma_reload_settings(); } }