compilation support for audioreactive
putting all parts that will not compile between #ifdef .... #endif Tested on S3, cannot say what will happen on other MCUs
This commit is contained in:
		| @@ -949,10 +949,20 @@ class AudioReactive : public Usermod { | ||||
|  | ||||
|       // Reset I2S peripheral for good measure | ||||
|       i2s_driver_uninstall(I2S_NUM_0); | ||||
|       periph_module_reset(PERIPH_I2S0_MODULE); | ||||
|  | ||||
|       #if !defined(CONFIG_IDF_TARGET_ESP32C3) | ||||
|         periph_module_reset(PERIPH_I2S0_MODULE);   // not possible on -C3 | ||||
|       #endif | ||||
|       delay(100);         // Give that poor microphone some time to setup. | ||||
|       switch (dmType) { | ||||
|       #if defined(CONFIG_IDF_TARGET_ESP32S2) || defined(CONFIG_IDF_TARGET_ESP32C3) || defined(CONFIG_IDF_TARGET_ESP32S3) | ||||
|         // stub cases for not-yet-supported I2S modes on other ESP32 chips | ||||
|         case 0:  //ADC analog | ||||
|         case 3:  //MCLK | ||||
|         case 4:  //SPH0645 | ||||
|         #if defined(CONFIG_IDF_TARGET_ESP32S2) || defined(CONFIG_IDF_TARGET_ESP32C3) | ||||
|         case 5:  //PDM Microphone | ||||
|         #endif | ||||
|       #endif | ||||
|         case 1: | ||||
|           DEBUGSR_PRINT(F("AR: Generic I2S Microphone - ")); DEBUGSR_PRINTLN(F(I2S_MIC_CHANNEL_TEXT)); | ||||
|           audioSource = new I2SSource(SAMPLE_RATE, BLOCK_SIZE); | ||||
| @@ -965,24 +975,34 @@ class AudioReactive : public Usermod { | ||||
|           delay(100); | ||||
|           if (audioSource) audioSource->initialize(sdaPin, sclPin, i2swsPin, i2ssdPin, i2sckPin, mclkPin); | ||||
|           break; | ||||
|         #if !defined(CONFIG_IDF_TARGET_ESP32S2) && !defined(CONFIG_IDF_TARGET_ESP32C3) && !defined(CONFIG_IDF_TARGET_ESP32S3) | ||||
|         // SPH0645 is currently only possible on "classic" ESP32 | ||||
|         case 3: | ||||
|           DEBUGSR_PRINT(F("AR: SPH0645 Microphone - ")); DEBUGSR_PRINTLN(F(I2S_MIC_CHANNEL_TEXT)); | ||||
|           audioSource = new SPH0654(SAMPLE_RATE, BLOCK_SIZE); | ||||
|           delay(100); | ||||
|           audioSource->initialize(i2swsPin, i2ssdPin, i2sckPin); | ||||
|           break; | ||||
|         #endif | ||||
|         #if  !defined(CONFIG_IDF_TARGET_ESP32S2) && !defined(CONFIG_IDF_TARGET_ESP32C3) && !defined(CONFIG_IDF_TARGET_ESP32S3) | ||||
|         // MCLK routing currently only works on "classic" ESP32 | ||||
|         case 4: | ||||
|           DEBUGSR_PRINT(F("AR: Generic I2S Microphone with Master Clock - ")); DEBUGSR_PRINTLN(F(I2S_MIC_CHANNEL_TEXT)); | ||||
|           audioSource = new I2SSource(SAMPLE_RATE, BLOCK_SIZE); | ||||
|           delay(100); | ||||
|           if (audioSource) audioSource->initialize(i2swsPin, i2ssdPin, i2sckPin, mclkPin); | ||||
|           break; | ||||
|         #endif | ||||
|         #if  !defined(CONFIG_IDF_TARGET_ESP32S2) && !defined(CONFIG_IDF_TARGET_ESP32C3) | ||||
|         case 5: | ||||
|           DEBUGSR_PRINT(F("AR: I2S PDM Microphone - ")); DEBUGSR_PRINTLN(F(I2S_MIC_CHANNEL_TEXT)); | ||||
|           audioSource = new I2SSource(SAMPLE_RATE, BLOCK_SIZE); | ||||
|           delay(100); | ||||
|           if (audioSource) audioSource->initialize(i2swsPin, i2ssdPin); | ||||
|           break; | ||||
|         #endif | ||||
|         #if  !defined(CONFIG_IDF_TARGET_ESP32S2) && !defined(CONFIG_IDF_TARGET_ESP32C3) && !defined(CONFIG_IDF_TARGET_ESP32S3) | ||||
|         // ADC over I2S is only possible on "classic" ESP32 | ||||
|         case 0: | ||||
|         default: | ||||
|           DEBUGSR_PRINTLN(F("AR: Analog Microphone (left channel only).")); | ||||
| @@ -990,6 +1010,7 @@ class AudioReactive : public Usermod { | ||||
|           delay(100); | ||||
|           if (audioSource) audioSource->initialize(audioPin); | ||||
|           break; | ||||
|         #endif | ||||
|       } | ||||
|       delay(250); // give microphone enough time to initialise | ||||
|  | ||||
| @@ -1529,12 +1550,18 @@ class AudioReactive : public Usermod { | ||||
|     void appendConfigData() | ||||
|     { | ||||
|       oappend(SET_F("dd=addDropdown('AudioReactive','digitalmic:type');")); | ||||
|     #if  !defined(CONFIG_IDF_TARGET_ESP32S2) && !defined(CONFIG_IDF_TARGET_ESP32C3) && !defined(CONFIG_IDF_TARGET_ESP32S3) | ||||
|       oappend(SET_F("addOption(dd,'Generic Analog',0);")); | ||||
|     #endif | ||||
|       oappend(SET_F("addOption(dd,'Generic I2S',1);")); | ||||
|       oappend(SET_F("addOption(dd,'ES7243',2);")); | ||||
|     #if  !defined(CONFIG_IDF_TARGET_ESP32S2) && !defined(CONFIG_IDF_TARGET_ESP32C3) && !defined(CONFIG_IDF_TARGET_ESP32S3) | ||||
|       oappend(SET_F("addOption(dd,'SPH0654',3);")); | ||||
|       oappend(SET_F("addOption(dd,'Generic I2S with Mclk',4);")); | ||||
|     #endif | ||||
|     #if  !defined(CONFIG_IDF_TARGET_ESP32S2) && !defined(CONFIG_IDF_TARGET_ESP32C3) | ||||
|       oappend(SET_F("addOption(dd,'Generic I2S PDM',5);")); | ||||
|     #endif | ||||
|       oappend(SET_F("dd=addDropdown('AudioReactive','cfg:AGC');")); | ||||
|       oappend(SET_F("addOption(dd,'Off',0);")); | ||||
|       oappend(SET_F("addOption(dd,'Normal',1);")); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Frank
					Frank