}
#endif //!CONFIG_FREERTOS_UNICORE
+static void intr_matrix_clear(void)
+{
+ //Clear all the interrupt matrix register
+ for (int i = ETS_WIFI_MAC_INTR_SOURCE; i <= ETS_CACHE_IA_INTR_SOURCE; i++) {
+ intr_matrix_set(0, i, ETS_INVALID_INUM);
+#if !CONFIG_FREERTOS_UNICORE
+ intr_matrix_set(1, i, ETS_INVALID_INUM);
+#endif
+ }
+}
+
void start_cpu0_default(void)
{
esp_setup_syscall_table();
trax_start_trace(TRAX_DOWNCOUNT_WORDS);
#endif
esp_clk_init();
+ intr_matrix_clear();
#ifndef CONFIG_CONSOLE_UART_NONE
uart_div_modify(CONFIG_CONSOLE_UART_NUM, (rtc_clk_apb_freq_get() << 4) / CONFIG_CONSOLE_UART_BAUDRATE);
#endif
{ 1, INTTP_LEVEL, {INTDESC_NORMAL, INTDESC_NORMAL} }, //2
{ 1, INTTP_LEVEL, {INTDESC_NORMAL, INTDESC_NORMAL} }, //3
{ 1, INTTP_LEVEL, {INTDESC_RESVD, INTDESC_NORMAL} }, //4
- { 1, INTTP_LEVEL, {INTDESC_RESVD, INTDESC_NORMAL} }, //5
+ { 1, INTTP_LEVEL, {INTDESC_RESVD, INTDESC_RESVD } }, //5
{ 1, INTTP_NA, {INT6RES, INT6RES } }, //6
{ 1, INTTP_NA, {INTDESC_SPECIAL,INTDESC_SPECIAL}}, //7
{ 1, INTTP_LEVEL, {INTDESC_RESVD, INTDESC_RESVD } }, //8
#define ETS_UART1_INUM 5
//Other interrupt number should be managed by the user
+//Invalid interrupt for number interrupt matrix
+#define ETS_INVALID_INUM 6
#endif /* _ESP32_SOC_H_ */