Compare commits

...

7 Commits

Author SHA1 Message Date
David Hoelscher
276d379d59
Merge f664d766e4 into 9c86583981 2024-11-19 18:24:14 -08:00
David Hoelscher
f664d766e4 lint 2024-10-22 01:14:05 -05:00
David Hoelscher
d29cc98240 fixed tone playing after a rest, optimized tone stopping algorithm 2024-10-22 00:38:56 -05:00
David Hoelscher
9948b05410 lint correction 2024-10-20 18:09:16 -05:00
David Hoelscher
0179f979e5 updated return-to-zero method to use pwm width of 0 2024-10-20 17:57:50 -05:00
David Hoelscher
9b8d4803dc switch to timer_read for limiting audio pin wait times 2024-10-19 02:49:07 -05:00
David Hoelscher
fb8351b325 always return audio pin to 0 on ARM 2024-10-18 21:35:13 -05:00
2 changed files with 13 additions and 10 deletions

View File

@ -41,18 +41,19 @@ static float channel_1_frequency = 0.0f;
void channel_1_set_frequency(float freq) {
channel_1_frequency = freq;
pwmcnt_t period;
pwmcnt_t width;
if (freq <= 0.0) {
// a pause/rest has freq=0
return;
period = 2;
width = 0;
} else {
period = (pwmCFG.frequency / freq);
width = (pwmcnt_t)(((period) * (pwmcnt_t)((100 - note_timbre) * 100)) / (pwmcnt_t)(10000));
}
pwmcnt_t period = (pwmCFG.frequency / freq);
chSysLockFromISR();
pwmChangePeriodI(&AUDIO_PWM_DRIVER, period);
pwmEnableChannelI(&AUDIO_PWM_DRIVER, AUDIO_PWM_CHANNEL - 1,
// adjust the duty-cycle so that the output is for 'note_timbre' duration HIGH
PWM_PERCENTAGE_TO_WIDTH(&AUDIO_PWM_DRIVER, (100 - note_timbre) * 100));
pwmEnableChannelI(&AUDIO_PWM_DRIVER, AUDIO_PWM_CHANNEL - 1, width);
chSysUnlockFromISR();
}
@ -67,6 +68,9 @@ void channel_1_start(void) {
void channel_1_stop(void) {
pwmStop(&AUDIO_PWM_DRIVER);
pwmStart(&AUDIO_PWM_DRIVER, &pwmCFG);
pwmEnableChannel(&AUDIO_PWM_DRIVER, AUDIO_PWM_CHANNEL - 1, 0);
pwmStop(&AUDIO_PWM_DRIVER);
}
static virtual_timer_t audio_vt;

View File

@ -258,11 +258,10 @@ void audio_stop_tone(float pitch) {
for (int i = AUDIO_TONE_STACKSIZE - 1; i >= 0; i--) {
found = (tones[i].pitch == pitch);
if (found) {
tones[i] = (musical_tone_t){.time_started = 0, .pitch = -1.0f, .duration = 0};
for (int j = i; (j < AUDIO_TONE_STACKSIZE - 1); j++) {
tones[j] = tones[j + 1];
tones[j + 1] = (musical_tone_t){.time_started = 0, .pitch = -1.0f, .duration = 0};
tones[j] = tones[j + 1];
}
tones[AUDIO_TONE_STACKSIZE - 1] = (musical_tone_t){.time_started = 0, .pitch = -1.0f, .duration = 0};
break;
}
}