Unverified Commit b5ffed41 authored by Wolle's avatar Wolle Committed by GitHub

Add files via upload

parent 8b1b4a98
...@@ -7,62 +7,81 @@ ...@@ -7,62 +7,81 @@
#define I2S_BCLK 27 #define I2S_BCLK 27
#define I2S_LRC 26 #define I2S_LRC 26
/* We create 10 structures and 10 memory areas for the queues. Audio audio;
* Only the pointer to a structure is transferred to the queue.
* The queue therefore only takes up a small amount of memory. String ssid = "******";
* Since the command is executed with a time delay, the structure cannot be overwritten prematurely. String password = "******";
* However, you can work cyclically. Then a check for a full queue is not necessary. */
//****************************************************************************************
// A U D I O _ T A S K *
//****************************************************************************************
struct audioMessage{ struct audioMessage{
uint8_t cmd; uint8_t cmd;
char* txt; const char* txt;
uint32_t value; uint32_t value;
} audioTxMessage[10], audioRxMessage; uint32_t ret;
} audioTxMessage, audioRxMessage;
enum : uint8_t { SET_VOLUME, GET_VOLUME, CONNECTTOHOST, CONNECTTOFS };
enum : uint8_t { SET_VOLUME, GET_VOLUME, CONNECTTOHOST, CONNECTTOSD };
QueueHandle_t audioSetQueue = NULL; QueueHandle_t audioSetQueue = NULL;
QueueHandle_t audioGetQueue = NULL; QueueHandle_t audioGetQueue = NULL;
void CreateQueues(){
audioSetQueue = xQueueCreate(10, sizeof(struct audioMessage));
audioGetQueue = xQueueCreate(10, sizeof(struct audioMessage));
}
Audio audio; void audioTask(void *parameter) {
CreateQueues();
String ssid = "*****"; if(!audioSetQueue || !audioGetQueue){
String password = "*****"; log_e("queues are not initialized");
while(true){;} // endless loop
}
void AudioPlayer_Task(void *parameter) {
struct audioMessage audioRxTaskMessage; struct audioMessage audioRxTaskMessage;
struct audioMessage audioTxTaskMessage[10]; struct audioMessage audioTxTaskMessage;
audio.setPinout(I2S_BCLK, I2S_LRC, I2S_DOUT);
audio.setVolume(15); // 0...21
while(true){ while(true){
if(audioSetQueue != NULL ){ if(xQueueReceive(audioSetQueue, &audioRxTaskMessage, 1) == pdPASS) {
if(xQueueReceive(audioSetQueue, &audioRxTaskMessage, 0) == pdPASS) {
if(audioRxTaskMessage.cmd == SET_VOLUME){ if(audioRxTaskMessage.cmd == SET_VOLUME){
log_i("set volume to %d", audioRxTaskMessage.value); audioTxTaskMessage.cmd = SET_VOLUME;
audio.setVolume(audioRxTaskMessage.value); audio.setVolume(audioRxTaskMessage.value);
audioTxTaskMessage.ret = 1;
xQueueSend(audioGetQueue, &audioTxTaskMessage, portMAX_DELAY);
} }
if(audioRxTaskMessage.cmd == CONNECTTOHOST){ else if(audioRxTaskMessage.cmd == CONNECTTOHOST){
log_i("new url is %s", audioRxTaskMessage.txt); audioTxTaskMessage.cmd = CONNECTTOHOST;
audio.connecttohost(audioRxTaskMessage.txt); audioTxTaskMessage.ret = audio.connecttohost(audioRxTaskMessage.txt);
xQueueSend(audioGetQueue, &audioTxTaskMessage, portMAX_DELAY);
} }
if(audioRxTaskMessage.cmd == GET_VOLUME){ else if(audioRxTaskMessage.cmd == CONNECTTOSD){
audioTxTaskMessage[0].cmd = GET_VOLUME; audioTxTaskMessage.cmd = CONNECTTOSD;
audioTxTaskMessage[0].value = audio.getVolume(); audioTxTaskMessage.ret = audio.connecttoSD(audioRxTaskMessage.txt);
xQueueSend(audioGetQueue, &audioTxTaskMessage[0], 0); xQueueSend(audioGetQueue, &audioTxTaskMessage, portMAX_DELAY);
} }
else if(audioRxTaskMessage.cmd == GET_VOLUME){
audioTxTaskMessage.cmd = GET_VOLUME;
audioTxTaskMessage.ret = audio.getVolume();
xQueueSend(audioGetQueue, &audioTxTaskMessage, portMAX_DELAY);
}
else{
log_i("error");
} }
} }
audio.loop(); audio.loop();
if(!audio.isRunning()) vTaskDelay(10); // yield
} }
} }
void AudioPlayer_Init(void) { void audioInit() {
CreateQueues();
xTaskCreatePinnedToCore( xTaskCreatePinnedToCore(
AudioPlayer_Task, /* Function to implement the task */ audioTask, /* Function to implement the task */
"audioplay", /* Name of the task */ "vs1053play", /* Name of the task */
5000, /* Stack size in words */ 5000, /* Stack size in words */
NULL, /* Task input parameter */ NULL, /* Task input parameter */
2 | portPRIVILEGE_BIT, /* Priority of the task */ 2 | portPRIVILEGE_BIT, /* Priority of the task */
...@@ -71,51 +90,70 @@ void AudioPlayer_Init(void) { ...@@ -71,51 +90,70 @@ void AudioPlayer_Init(void) {
); );
} }
void CreateQueues(){ audioMessage transmitReceive(audioMessage msg){
audioSetQueue = xQueueCreate(10, sizeof(struct audioMessage)); xQueueSend(audioSetQueue, &msg, portMAX_DELAY);
audioGetQueue = xQueueCreate(10, sizeof(struct audioMessage)); if(xQueueReceive(audioGetQueue, &audioRxMessage, portMAX_DELAY) == pdPASS){
if(msg.cmd != audioRxMessage.cmd){
log_e("wrong reply from message queue");
}
}
return audioRxMessage;
}
void audioSetVolume(uint8_t vol){
audioTxMessage.cmd = SET_VOLUME;
audioTxMessage.value = vol;
audioMessage RX = transmitReceive(audioTxMessage);
}
uint8_t audioGetVolume(){
audioTxMessage.cmd = GET_VOLUME;
audioMessage RX = transmitReceive(audioTxMessage);
return RX.ret;
}
bool audioConnecttohost(const char* host){
audioTxMessage.cmd = CONNECTTOHOST;
audioTxMessage.txt = host;
audioMessage RX = transmitReceive(audioTxMessage);
return RX.ret;
}
bool audioConnecttoSD(const char* filename){
audioTxMessage.cmd = CONNECTTOSD;
audioTxMessage.txt = filename;
audioMessage RX = transmitReceive(audioTxMessage);
return RX.ret;
} }
//****************************************************************************************
// S E T U P *
//****************************************************************************************
void setup() { void setup() {
Serial.begin(115200); Serial.begin(115200);
WiFi.begin(ssid.c_str(), password.c_str()); WiFi.begin(ssid.c_str(), password.c_str());
while (WiFi.status() != WL_CONNECTED) delay(1500); while (WiFi.status() != WL_CONNECTED) delay(1500);
audio.setPinout(I2S_BCLK, I2S_LRC, I2S_DOUT); audioInit();
CreateQueues();
AudioPlayer_Init(); audioConnecttohost("http://mp3.ffh.de/radioffh/hqlivestream.mp3");
audioSetVolume(15);
int i = 0; log_i("current volume is: %d", audioGetVolume());
audioTxMessage[i].cmd = CONNECTTOHOST;
audioTxMessage[i].txt = "http://mp3.ffh.de/radioffh/hqlivestream.mp3";
audioTxMessage[i].value = 0;
xQueueSend(audioSetQueue, &audioTxMessage[i], 0);
i++;
audioTxMessage[i].cmd = SET_VOLUME;
audioTxMessage[i].txt = NULL;
audioTxMessage[i].value = 10;
xQueueSend(audioSetQueue, &audioTxMessage[i], 0);
i++;
audioTxMessage[i].cmd = GET_VOLUME;
audioTxMessage[i].txt = NULL;
audioTxMessage[i].value = 0;
xQueueSend(audioSetQueue, &audioTxMessage[i], 0);
} }
void loop(){ //****************************************************************************************
if(audioGetQueue != NULL ){ // L O O P *
if(xQueueReceive(audioGetQueue, &audioRxMessage, (TickType_t)0) == pdPASS) { //****************************************************************************************
if(audioRxMessage.cmd == GET_VOLUME){
log_i("current volume is %d", audioRxMessage.value);
}
}
}
void loop(){
// your own code here // your own code here
} }
//*****************************************************************************************
// E V E N T S *
//*****************************************************************************************
void audio_info(const char *info){ void audio_info(const char *info){
Serial.print("info "); Serial.println(info); Serial.print("info "); Serial.println(info);
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment