mirror of
https://github.com/sle118/squeezelite-esp32.git
synced 2025-12-08 12:37:01 +03:00
BT ring buffering
This commit is contained in:
@@ -30,6 +30,47 @@
|
||||
#include "nvs_flash.h"
|
||||
#include "sys/socket.h"
|
||||
#include "string.h"
|
||||
thread_cond_type wifi_connect_suspend_cond;
|
||||
mutex_type wifi_connect_suspend_mutex;
|
||||
char * art_wifi[]={
|
||||
"\n",
|
||||
"o `O ooOoOOo OOooOoO ooOoOOo\n",
|
||||
"O o O o O \n",
|
||||
"o O o O o \n",
|
||||
"O O O oOooO O \n",
|
||||
"o o o o O o \n",
|
||||
"O O O O o O \n",
|
||||
"`o O o O' O o O \n",
|
||||
" `OoO' `OoO' ooOOoOo O' ooOOoOo\n",
|
||||
"\n",
|
||||
""
|
||||
};
|
||||
char * art_wifi_connecting[]={
|
||||
" .oOOOo.",
|
||||
".O o o \n",
|
||||
"o O \n",
|
||||
"o oOo \n",
|
||||
"o .oOo. 'OoOo. 'OoOo. .oOo. .oOo o O 'OoOo. .oOoO \n",
|
||||
"O O o o O o O OooO' O O o o O o O \n",
|
||||
"`o .o o O O o O o O o o O O o O o \n",
|
||||
" `OoooO' `OoO' o O o O `OoO' `OoO' `oO o' o O `OoOo \n",
|
||||
" O \n",
|
||||
" OoO' \n",
|
||||
"\n",
|
||||
""
|
||||
};
|
||||
char * art_wifi_connected[]={
|
||||
" .oOOOo. o oO\n",
|
||||
".O o O OO\n",
|
||||
"o O o oO\n",
|
||||
"o oOo o Oo\n",
|
||||
"o .oOo. 'OoOo. 'OoOo. .oOo. .oOo o .oOo. .oOoO oO\n",
|
||||
"O O o o O o O OooO' O O OooO' o O \n",
|
||||
"`o .o o O O o O o O o o O O o Oo\n",
|
||||
" `OoooO' `OoO' o O o O `OoO' `OoO' `oO `OoO' `OoO'o oO\n",
|
||||
"\n",
|
||||
""
|
||||
};
|
||||
|
||||
/*Set the SSID and Password via "make menuconfig"*/
|
||||
#define DEFAULT_SSID CONFIG_WIFI_SSID
|
||||
@@ -80,7 +121,13 @@ static void event_handler(void* arg, esp_event_base_t event_base,
|
||||
esp_wifi_connect();
|
||||
} else if (event_base == IP_EVENT && event_id == IP_EVENT_STA_GOT_IP) {
|
||||
ip_event_got_ip_t* event = (ip_event_got_ip_t*) event_data;
|
||||
ESP_LOGI(TAG, "got ip: %s", ip4addr_ntoa(&event->ip_info.ip));
|
||||
ESP_LOGI(TAG, "got ip: %s.", ip4addr_ntoa(&event->ip_info.ip));
|
||||
logprint("Signaling wifi connected. Locking.\n");
|
||||
mutex_lock(wifi_connect_suspend_mutex);
|
||||
logprint("Signaling wifi connected. Broadcasting.\n");
|
||||
mutex_broadcast_cond(wifi_connect_suspend_cond);
|
||||
logprint("Signaling wifi connected. Unlocking.\n");
|
||||
mutex_unlock(wifi_connect_suspend_mutex);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -88,6 +135,12 @@ static void event_handler(void* arg, esp_event_base_t event_base,
|
||||
/* Initialize Wi-Fi as sta and set scan method */
|
||||
static void wifi_scan(void)
|
||||
{
|
||||
for(uint8_t l=0;art_wifi[l][0]!='\0';l++){
|
||||
logprint("%s",art_wifi[l]);
|
||||
}
|
||||
for(uint8_t l=0;art_wifi_connecting[l][0]!='\0';l++){
|
||||
logprint("%s",art_wifi_connecting[l]);
|
||||
}
|
||||
tcpip_adapter_init();
|
||||
ESP_ERROR_CHECK(esp_event_loop_create_default());
|
||||
|
||||
@@ -143,18 +196,13 @@ void app_main()
|
||||
|
||||
};
|
||||
|
||||
|
||||
// can't do strtok on FLASH strings
|
||||
argv = malloc(sizeof(_argv));
|
||||
for (i = 0; i < sizeof(_argv)/sizeof(char*); i++) {
|
||||
argv[i] = strdup(_argv[i]);
|
||||
}
|
||||
|
||||
logprint("%s %s:%d Calling main with parameters: " , logtime(), __FUNCTION__, __LINE__);
|
||||
|
||||
for (i = 0; i < sizeof(_argv)/sizeof(char*); i++) {
|
||||
logprint("%s " , _argv[i]);
|
||||
}
|
||||
logprint("\n");
|
||||
|
||||
// Initialize NVS
|
||||
esp_err_t ret = nvs_flash_init();
|
||||
@@ -163,8 +211,30 @@ void app_main()
|
||||
ret = nvs_flash_init();
|
||||
}
|
||||
ESP_ERROR_CHECK( ret );
|
||||
|
||||
|
||||
mutex_create_p(wifi_connect_suspend_mutex);
|
||||
mutex_cond_init(wifi_connect_suspend_cond);
|
||||
|
||||
logprint("Starting WiFi.\n");
|
||||
wifi_scan();
|
||||
|
||||
logprint("Waiting for WiFi to connect. Locking Mutex.\n");
|
||||
mutex_lock(wifi_connect_suspend_mutex);
|
||||
logprint("Waiting for WiFi to connect. cond_wait.\n");
|
||||
pthread_cond_wait(&wifi_connect_suspend_cond,&wifi_connect_suspend_mutex);
|
||||
logprint("Waiting for WiFi to connect. Unlocking Mutex.\n");
|
||||
mutex_unlock(wifi_connect_suspend_mutex);
|
||||
for(uint8_t l=0;art_wifi[l][0]!='\0';l++){
|
||||
logprint("%s",art_wifi[l]);
|
||||
}
|
||||
for(uint8_t l=0;art_wifi_connected[l][0]!='\0';l++){
|
||||
logprint("%s",art_wifi_connected[l]);
|
||||
}
|
||||
logprint("%s %s:%d Calling main with parameters: " , logtime(), __FUNCTION__, __LINE__);
|
||||
|
||||
for (i = 0; i < sizeof(_argv)/sizeof(char*); i++) {
|
||||
logprint("%s " , _argv[i]);
|
||||
}
|
||||
logprint("\n");
|
||||
|
||||
main(sizeof(_argv)/sizeof(char*), argv);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user