 9829145d8c
			
		
	
	
		9829145d8c
		
			
		
	
	
	
	
		
			
			* fbt: fixed include paths for generated version header * lib: STM32CubeWB: refactored & cleaned up WPAN include paths * hal: linter fixes for new headers * fbt: added version_json target * Added .pvsconfig; split common_defines.h into 2 files * Added PVS-Studio basic configuration files; updated .gitignore Co-authored-by: あく <alleteam@gmail.com>
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include "core_defines.h"
 | |
| #include <stdbool.h>
 | |
| #include <FreeRTOS.h>
 | |
| #include <task.h>
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| #include <cmsis_compiler.h>
 | |
| 
 | |
| #ifndef FURI_IS_IRQ_MASKED
 | |
| #define FURI_IS_IRQ_MASKED() (__get_PRIMASK() != 0U)
 | |
| #endif
 | |
| 
 | |
| #ifndef FURI_IS_IRQ_MODE
 | |
| #define FURI_IS_IRQ_MODE() (__get_IPSR() != 0U)
 | |
| #endif
 | |
| 
 | |
| #ifndef FURI_IS_ISR
 | |
| #define FURI_IS_ISR() (FURI_IS_IRQ_MODE() || FURI_IS_IRQ_MASKED())
 | |
| #endif
 | |
| 
 | |
| #ifndef FURI_CRITICAL_ENTER
 | |
| #define FURI_CRITICAL_ENTER()                                                    \
 | |
|     uint32_t __isrm = 0;                                                         \
 | |
|     bool __from_isr = FURI_IS_ISR();                                             \
 | |
|     bool __kernel_running = (xTaskGetSchedulerState() == taskSCHEDULER_RUNNING); \
 | |
|     if(__from_isr) {                                                             \
 | |
|         __isrm = taskENTER_CRITICAL_FROM_ISR();                                  \
 | |
|     } else if(__kernel_running) {                                                \
 | |
|         taskENTER_CRITICAL();                                                    \
 | |
|     } else {                                                                     \
 | |
|         __disable_irq();                                                         \
 | |
|     }
 | |
| #endif
 | |
| 
 | |
| #ifndef FURI_CRITICAL_EXIT
 | |
| #define FURI_CRITICAL_EXIT()                \
 | |
|     if(__from_isr) {                        \
 | |
|         taskEXIT_CRITICAL_FROM_ISR(__isrm); \
 | |
|     } else if(__kernel_running) {           \
 | |
|         taskEXIT_CRITICAL();                \
 | |
|     } else {                                \
 | |
|         __enable_irq();                     \
 | |
|     }
 | |
| #endif
 | |
| 
 | |
| static inline bool furi_is_irq_context() {
 | |
|     bool irq = false;
 | |
|     BaseType_t state;
 | |
| 
 | |
|     if(FURI_IS_IRQ_MODE()) {
 | |
|         /* Called from interrupt context */
 | |
|         irq = true;
 | |
|     } else {
 | |
|         /* Get FreeRTOS scheduler state */
 | |
|         state = xTaskGetSchedulerState();
 | |
| 
 | |
|         if(state != taskSCHEDULER_NOT_STARTED) {
 | |
|             /* Scheduler was started */
 | |
|             if(FURI_IS_IRQ_MASKED()) {
 | |
|                 /* Interrupts are masked */
 | |
|                 irq = true;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /* Return context, 0: thread context, 1: IRQ context */
 | |
|     return (irq);
 | |
| }
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 |