 8f9b2513ff
			
		
	
	
		8f9b2513ff
		
			
		
	
	
	
	
		
			
			* SYSTEM: tickless mode with deep sleep. * Move FreeRTOS ticks to lptim2 * API: move all sumbodules init routines to one place. Timebase: working lptim2 at tick source. * API Timebase: lp-timer routines, timer access safe zones prediction and synchronization. FreeRTOS: adjust configuration for tickless mode. * NFC: support for tickless mode. * API Timebase: improve tick error handling in IRQ. Apploader: use insomnia mode to run applications. * BLE: prevent sleep while core2 starting * HAL: nap while in insomnia mode * init records work * try to implement record delete * tests and flapp * flapp subsystem * new core functions to get app stat, simplify core code * fix thread termination * add strdup to core * fix tests * Refactoring: remove all unusued parts, update API usage, aggreagate API sources and headers, new record storage * Refactoring: update furi record api usage, cleanup code * Fix broken merge for freertos apps * Core, Target: fix compilation warnings * Drop firmware target local * HAL Timebase, Power, Clock: semaphore guarded access to clock and power modes, better sleep mode. * SD-Filesystem: wait for all deps to arrive before adding widget. Core, BLE: disable debug dump to serial. * delete old app example-ipc * delete old app fatfs list * fix strobe app, add input header * delete old display driver * comment old app qr-code * fix sd-card test, add forced widget update * remove unused new core test * increase heap to 128k * comment and assert old core tests * fix syntax Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
		
			
				
	
	
		
			123 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "u8g2/u8g2.h"
 | |
| #include <furi.h>
 | |
| #include <main.h>
 | |
| 
 | |
| extern SPI_HandleTypeDef SPI_D;
 | |
| 
 | |
| // TODO: fix log
 | |
| #ifdef DEBUG
 | |
| #undef DEBUG
 | |
| #endif
 | |
| 
 | |
| uint8_t u8g2_gpio_and_delay_stm32(u8x8_t* u8x8, uint8_t msg, uint8_t arg_int, void* arg_ptr) {
 | |
|     switch(msg) {
 | |
|     //Initialize SPI peripheral
 | |
|     case U8X8_MSG_GPIO_AND_DELAY_INIT:
 | |
|         /* HAL initialization contains all what we need so we can skip this part. */
 | |
|         break;
 | |
| 
 | |
|     //Function which implements a delay, arg_int contains the amount of ms
 | |
|     case U8X8_MSG_DELAY_MILLI:
 | |
|         osDelay(arg_int);
 | |
|         break;
 | |
| 
 | |
|     //Function which delays 10us
 | |
|     case U8X8_MSG_DELAY_10MICRO:
 | |
|         delay_us(10);
 | |
|         break;
 | |
| 
 | |
|     //Function which delays 100ns
 | |
|     case U8X8_MSG_DELAY_100NANO:
 | |
|         asm("nop");
 | |
|         break;
 | |
| 
 | |
|     // Function to define the logic level of the RESET line
 | |
|     case U8X8_MSG_GPIO_RESET:
 | |
| #ifdef DEBUG
 | |
|         printf("[u8g2] rst %d\n", arg_int);
 | |
| #endif
 | |
| 
 | |
|         // TODO change it to FuriRecord pin
 | |
|         HAL_GPIO_WritePin(
 | |
|             DISPLAY_RST_GPIO_Port, DISPLAY_RST_Pin, arg_int ? GPIO_PIN_SET : GPIO_PIN_RESET);
 | |
|         break;
 | |
| 
 | |
|     default:
 | |
| #ifdef DEBUG
 | |
|         printf("[u8g2] unknown io %d\n", msg);
 | |
| #endif
 | |
| 
 | |
|         return 0; //A message was received which is not implemented, return 0 to indicate an error
 | |
|     }
 | |
| 
 | |
|     return 1; // command processed successfully.
 | |
| }
 | |
| 
 | |
| uint8_t u8x8_hw_spi_stm32(u8x8_t* u8x8, uint8_t msg, uint8_t arg_int, void* arg_ptr) {
 | |
|     switch(msg) {
 | |
|     case U8X8_MSG_BYTE_SEND:
 | |
| #ifdef DEBUG
 | |
|         printf("[u8g2] send %d bytes %02X\n", arg_int, ((uint8_t*)arg_ptr)[0]);
 | |
| #endif
 | |
| 
 | |
|         // TODO change it to FuriRecord SPI
 | |
|         HAL_SPI_Transmit(&SPI_D, (uint8_t*)arg_ptr, arg_int, 10000);
 | |
|         break;
 | |
| 
 | |
|     case U8X8_MSG_BYTE_SET_DC:
 | |
| #ifdef DEBUG
 | |
|         printf("[u8g2] dc %d\n", arg_int);
 | |
| #endif
 | |
| 
 | |
|         // TODO change it to FuriRecord pin
 | |
|         HAL_GPIO_WritePin(
 | |
|             DISPLAY_DI_GPIO_Port, DISPLAY_DI_Pin, arg_int ? GPIO_PIN_SET : GPIO_PIN_RESET);
 | |
|         break;
 | |
| 
 | |
|     case U8X8_MSG_BYTE_INIT:
 | |
| #ifdef DEBUG
 | |
|         printf("[u8g2] init\n");
 | |
| #endif
 | |
| 
 | |
|         // TODO change it to FuriRecord pin
 | |
|         HAL_GPIO_WritePin(DISPLAY_CS_GPIO_Port, DISPLAY_CS_Pin, GPIO_PIN_RESET);
 | |
|         break;
 | |
| 
 | |
|     case U8X8_MSG_BYTE_START_TRANSFER:
 | |
| #ifdef DEBUG
 | |
|         printf("[u8g2] start\n");
 | |
| #endif
 | |
| 
 | |
|         // TODO: SPI manager
 | |
|         api_hal_spi_lock_device(&display_spi);
 | |
| 
 | |
|         // TODO change it to FuriRecord pin
 | |
|         HAL_GPIO_WritePin(DISPLAY_CS_GPIO_Port, DISPLAY_CS_Pin, GPIO_PIN_RESET);
 | |
|         asm("nop");
 | |
|         break;
 | |
| 
 | |
|     case U8X8_MSG_BYTE_END_TRANSFER:
 | |
| #ifdef DEBUG
 | |
|         printf("[u8g2] end\n");
 | |
| #endif
 | |
| 
 | |
|         asm("nop");
 | |
|         // TODO change it to FuriRecord pin
 | |
|         HAL_GPIO_WritePin(DISPLAY_CS_GPIO_Port, DISPLAY_CS_Pin, GPIO_PIN_SET);
 | |
| 
 | |
|         // TODO: SPI manager
 | |
|         api_hal_spi_unlock_device(&display_spi);
 | |
| 
 | |
|         break;
 | |
| 
 | |
|     default:
 | |
| #ifdef DEBUG
 | |
|         printf("[u8g2] unknown xfer %d\n", msg);
 | |
| #endif
 | |
| 
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
|     return 1;
 | |
| }
 |