diff options
author | Florian Didron <fdidron@users.noreply.github.com> | 2019-05-28 19:40:25 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-05-28 19:40:25 +0900 |
commit | 877b962dccba2df19988ef824848955c6c793f53 (patch) | |
tree | 262efbbfbe22baab71d20e213f403f80317c7587 | |
parent | 9e86204fd46d22915f81d2a21071e4167c2e7278 (diff) | |
parent | 4b6c1b8c2c58d117090c7f1dce20effdf61a5c13 (diff) |
Merge pull request #61 from zsa/a5_luis_rocks
A5 luis rocks
-rw-r--r-- | quantum/audio/audio_arm.c | 51 |
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); } } |