summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFlorian Didron <fdidron@users.noreply.github.com>2019-05-28 19:40:25 +0900
committerGitHub <noreply@github.com>2019-05-28 19:40:25 +0900
commit877b962dccba2df19988ef824848955c6c793f53 (patch)
tree262efbbfbe22baab71d20e213f403f80317c7587
parent9e86204fd46d22915f81d2a21071e4167c2e7278 (diff)
parent4b6c1b8c2c58d117090c7f1dce20effdf61a5c13 (diff)
Merge pull request #61 from zsa/a5_luis_rocks
A5 luis rocks
-rw-r--r--quantum/audio/audio_arm.c51
1 files changed, 44 insertions, 7 deletions
diff --git a/quantum/audio/audio_arm.c b/quantum/audio/audio_arm.c
index e5164f2abb..5a9d03686a 100644
--- a/quantum/audio/audio_arm.c
+++ b/quantum/audio/audio_arm.c
@@ -32,10 +32,13 @@ float frequency = 0;
float frequency_alt = 0;
int volume = 0;
long position = 0;
+systime_t last_note_played_at;
+virtual_timer_t play_note_timer;
float frequencies[8] = {0, 0, 0, 0, 0, 0, 0, 0};
int volumes[8] = {0, 0, 0, 0, 0, 0, 0, 0};
bool sliding = false;
+bool dac_on = true;
float place = 0;
@@ -78,20 +81,27 @@ bool glissando = true;
float startup_song[][2] = STARTUP_SONG;
static void gpt_cb8(GPTDriver *gptp);
+static bool should_shutoff_dac(void);
+static void shutoff_dac(void);
+static void shutoff_dac_callback(void *arg);
+#define PLAY_NOTE_TIMEOUT MS2ST(5)
#define DAC_BUFFER_SIZE 100
#ifndef DAC_SAMPLE_MAX
#define DAC_SAMPLE_MAX 65535U
#endif
-#define START_CHANNEL_1() gptStart(&GPTD6, &gpt6cfg1); \
- gptStartContinuous(&GPTD6, 2U); \
- palSetPadMode(GPIOA, 5, PAL_MODE_INPUT_ANALOG);
+#define START_CHANNEL_1() dacStart(&DACD1, &dac1cfg1); \
+ dacStart(&DACD2, &dac1cfg2); \
+ dacStartConversion(&DACD1, &dacgrpcfg1, (dacsample_t *)dac_buffer, DAC_BUFFER_SIZE); \
+ dacStartConversion(&DACD2, &dacgrpcfg2, (dacsample_t *)dac_buffer_2, DAC_BUFFER_SIZE); \
+ dac_on = true; \
+ gptStart(&GPTD6, &gpt6cfg1); \
+ gptStartContinuous(&GPTD6, 2U); \
+ palSetPadMode(GPIOA, 5, PAL_MODE_INPUT_ANALOG);
#define START_CHANNEL_2() gptStart(&GPTD7, &gpt7cfg1); \
gptStartContinuous(&GPTD7, 2U)
-#define STOP_CHANNEL_1() gptStopTimer(&GPTD6); \
- palSetPadMode(GPIOA, 5, PAL_MODE_OUTPUT_PUSHPULL); \
- palSetPad(GPIOA, 5);
+#define STOP_CHANNEL_1() gptStopTimer(&GPTD6)
#define STOP_CHANNEL_2() gptStopTimer(&GPTD7)
#define RESTART_CHANNEL_1() STOP_CHANNEL_1(); \
START_CHANNEL_1()
@@ -410,11 +420,13 @@ float vibrato(float average_freq) {
}
#endif
-
static void gpt_cb8(GPTDriver *gptp) {
float freq;
if (playing_note) {
+ last_note_played_at = chVTGetSystemTime();
+ chVTReset(&play_note_timer);
+ chVTSet(&play_note_timer, PLAY_NOTE_TIMEOUT, shutoff_dac_callback, NULL);
if (voices > 0) {
float freq_alt = 0;
@@ -524,6 +536,7 @@ static void gpt_cb8(GPTDriver *gptp) {
}
if (playing_notes) {
+ last_note_played_at = chVTGetSystemTime();
if (note_frequency > 0) {
#ifdef VIBRATO_ENABLE
if (vibrato_strength > 0) {
@@ -600,6 +613,28 @@ static void gpt_cb8(GPTDriver *gptp) {
playing_notes = false;
playing_note = false;
}
+
+ if(should_shutoff_dac()) {
+ shutoff_dac();
+ }
+}
+
+bool should_shutoff_dac() {
+ return ST2MS(chVTTimeElapsedSinceX(last_note_played_at)) > 5 && dac_on;
+}
+
+void shutoff_dac() {
+ dacStopConversion(&DACD2);
+ dacStop(&DACD2);
+ palSetPadMode(GPIOA, 5, PAL_MODE_OUTPUT_PUSHPULL );
+ palSetPad(GPIOA, 5);
+ dac_on = false;
+}
+
+void shutoff_dac_callback(void *args) {
+ if(!playing_note) {
+ shutoff_dac();
+ }
}
void play_note(float freq, int vol) {
@@ -631,6 +666,8 @@ void play_note(float freq, int vol) {
gptStartContinuous(&GPTD8, 2U);
RESTART_CHANNEL_1();
RESTART_CHANNEL_2();
+ chVTReset(&play_note_timer);
+ chVTSet(&play_note_timer, PLAY_NOTE_TIMEOUT, shutoff_dac_callback, NULL);
}
}