You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

152 lines
4.3 KiB

// Plays a RAW (16-bit signed) PCM audio file at slower or faster rate
// this example plays a sample stored in an array
#include <Arduino.h>
#include <Audio.h>
#include "../../../src/playarrayresmp.h"
#include "output_soundio.h"
#include <soundio/soundio.h>
#include <SD.h>
#include <iostream>
#include <execinfo.h>
#include <signal.h>
#include <stdlib.h>
#include <unistd.h>
#include <string>
#include <cassert>
// GUItool: begin automatically generated code
AudioPlayArrayResmp rraw_a1; //xy=306,225
AudioRecordQueue queue1; //xy=609,267
AudioOutputSoundIO sio_out1; //xy=612,224
AudioConnection patchCord1(rraw_a1, 0, sio_out1, 0);
AudioConnection patchCord2(rraw_a1, 0, sio_out1, 1);
AudioConnection patchCord3(rraw_a1, 0, queue1, 0);
// GUItool: end automatically generated code
extern unsigned int mono_souljah_wav_len;
extern unsigned char mono_souljah_wav[];
int16_t buffer[512] = {0};
File frec;
unsigned long lastSamplePlayed = 0;
void my_handler(sig_atomic_t i);
static char stack_body[64*1024];
static stack_t sigseg_stack;
static struct sigaction sigseg_handler;
void crash_handler(sig_atomic_t i);
void setup() {
Serial.begin(9600);
rraw_a1.setPlaybackRate(1.0f);
rraw_a1.enableInterpolation(true);
//rraw_a1.play((int16_t*)kick_raw, kick_raw_len/2);
Serial.println("setup done");
if (SD.exists("RECORD.RAW")) {
// The SD library writes new data to the end of the
// file, so to start a new recording, the old file
// must be deleted before new data is written.
SD.remove("RECORD.RAW");
}
frec = SD.open("RECORD.RAW", O_WRITE);
AudioMemory(120);
if (frec) {
queue1.begin();
Serial.println("startRecording");
} else {
Serial.println("recording failed...");
}
}
void loop() {
unsigned currentMillis = millis();
if (currentMillis > lastSamplePlayed + 1000) {
if (!rraw_a1.isPlaying()) {
rraw_a1.playWav((int16_t *)mono_souljah_wav, mono_souljah_wav_len/2);
lastSamplePlayed = currentMillis;
Serial.print("Memory: ");
Serial.print(AudioMemoryUsage());
Serial.print(",");
Serial.print(AudioMemoryUsageMax());
Serial.println();
}
}
if (queue1.available() >= 1) {
int16_t* incomming = queue1.readBuffer();
if (incomming != NULL) {
memcpy(buffer, incomming, 256);
queue1.freeBuffer();
frec.write((unsigned char *)buffer, 256);
frec.flush();
}
}
delay(1);
}
int main() {
signal (SIGINT,my_handler);
signal (SIGSEGV,crash_handler);
sigseg_stack.ss_sp = stack_body;
sigseg_stack.ss_flags = SS_ONSTACK;
sigseg_stack.ss_size = sizeof(stack_body);
// assert(!sigaltstack(&sigseg_stack, nullptr));
sigseg_handler.sa_flags = SA_ONSTACK;
sigseg_handler.sa_handler = &crash_handler;
// assert(!sigaction(SIGSEGV, &sigseg_handler, nullptr));
initialize_mock_arduino();
SD.setSDCardFolderPath(".");
setup();
while(!arduino_should_exit){
loop();
}
delay(1000);
frec.close();
}
void my_handler(sig_atomic_t i){
if ( i== SIGINT) {
arduino_should_exit = true;
printf("Caught signal %d\n",i);
} else
{
cerr << "sig seg fault handler" << endl;
const int asize = 10;
void *array[asize];
size_t size;
// get void*'s for all entries on the stack
size = backtrace(array, asize);
// print out all the frames to stderr
cerr << "stack trace: " << endl;
backtrace_symbols_fd(array, size, STDERR_FILENO);
cerr << "resend SIGSEGV to get core dump" << endl;
signal(i, SIG_DFL);
kill(getpid(), i);
}
}
void crash_handler(sig_atomic_t i){
cerr << "sig seg fault handler" << endl;
const int asize = 10;
void *array[asize];
size_t size;
// get void*'s for all entries on the stack
size = backtrace(array, asize);
// print out all the frames to stderr
cerr << "stack trace: " << endl;
backtrace_symbols_fd(array, size, STDERR_FILENO);
cerr << "resend SIGSEGV to get core dump" << endl;
signal(i, SIG_DFL);
kill(getpid(), i);
}