| 
									
										
										
										
											2018-06-30 23:06:50 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "esp32-hal.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if CONFIG_SPIRAM_SUPPORT
 | 
					
						
							|  |  |  | #include "esp_spiram.h"
 | 
					
						
							|  |  |  | #include "soc/efuse_reg.h"
 | 
					
						
							|  |  |  | #include "esp_heap_caps.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static volatile bool spiramDetected = false; | 
					
						
							|  |  |  | static volatile bool spiramFailed = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool psramInit(){ | 
					
						
							|  |  |  |     if (spiramDetected) { | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #ifndef CONFIG_SPIRAM_BOOT_INIT
 | 
					
						
							|  |  |  |     if (spiramFailed) { | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     uint32_t chip_ver = REG_GET_FIELD(EFUSE_BLK0_RDATA3_REG, EFUSE_RD_CHIP_VER_PKG); | 
					
						
							|  |  |  |     uint32_t pkg_ver = chip_ver & 0x7; | 
					
						
							| 
									
										
										
										
											2019-02-14 16:49:30 +01:00
										 |  |  |     if (pkg_ver == EFUSE_RD_CHIP_VER_PKG_ESP32D2WDQ5 || pkg_ver == EFUSE_RD_CHIP_VER_PKG_ESP32PICOD2) { | 
					
						
							| 
									
										
										
										
											2018-06-30 23:06:50 +02:00
										 |  |  |         spiramFailed = true; | 
					
						
							|  |  |  |         log_w("PSRAM not supported!"); | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     esp_spiram_init_cache(); | 
					
						
							|  |  |  |     if (esp_spiram_init() != ESP_OK) { | 
					
						
							|  |  |  |         spiramFailed = true; | 
					
						
							|  |  |  |         log_w("PSRAM init failed!"); | 
					
						
							|  |  |  |         pinMatrixOutDetach(16, false, false); | 
					
						
							|  |  |  |         pinMatrixOutDetach(17, false, false); | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!esp_spiram_test()) { | 
					
						
							|  |  |  |         spiramFailed = true; | 
					
						
							|  |  |  |         log_e("PSRAM test failed!"); | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (esp_spiram_add_to_heapalloc() != ESP_OK) { | 
					
						
							|  |  |  |         spiramFailed = true; | 
					
						
							|  |  |  |         log_e("PSRAM could not be added to the heap!"); | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |     spiramDetected = true; | 
					
						
							|  |  |  |     log_d("PSRAM enabled"); | 
					
						
							|  |  |  |     return true; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool IRAM_ATTR psramFound(){ | 
					
						
							|  |  |  |     return spiramDetected; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IRAM_ATTR *ps_malloc(size_t size){ | 
					
						
							|  |  |  |     if(!spiramDetected){ | 
					
						
							|  |  |  |         return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return heap_caps_malloc(size, MALLOC_CAP_SPIRAM | MALLOC_CAP_8BIT); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IRAM_ATTR *ps_calloc(size_t n, size_t size){ | 
					
						
							|  |  |  |     if(!spiramDetected){ | 
					
						
							|  |  |  |         return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return heap_caps_calloc(n, size, MALLOC_CAP_SPIRAM | MALLOC_CAP_8BIT); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IRAM_ATTR *ps_realloc(void *ptr, size_t size){ | 
					
						
							|  |  |  |     if(!spiramDetected){ | 
					
						
							|  |  |  |         return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return heap_caps_realloc(ptr, size, MALLOC_CAP_SPIRAM | MALLOC_CAP_8BIT); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool psramInit(){ | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool IRAM_ATTR psramFound(){ | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IRAM_ATTR *ps_malloc(size_t size){ | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IRAM_ATTR *ps_calloc(size_t n, size_t size){ | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void IRAM_ATTR *ps_realloc(void *ptr, size_t size){ | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |