Skip to content

Commit

Permalink
dm: sound: Use the correct number of channels for sound
Browse files Browse the repository at this point in the history
At present the 'beep' sound generates a waveform for only one channel even
if two are being used. This means that the beep is twice the frequency it
should be. Correct this by making it a parameter.

The fix in a previous commit was correct for sandbox but not for other
boards.

Fixes: 03f11e8 ("sound: Correct data output in sound_create_square_wave()")
Signed-off-by: Simon Glass <[email protected]>
  • Loading branch information
sjg20 committed Dec 13, 2018
1 parent e221cdc commit f987177
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 10 deletions.
2 changes: 1 addition & 1 deletion drivers/sound/sound-uclass.c
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ int sound_beep(struct udevice *dev, int msecs, int frequency_hz)
}

sound_create_square_wave(i2s_uc_priv->samplingrate, data, data_size,
frequency_hz);
frequency_hz, i2s_uc_priv->channels);

while (msecs >= 1000) {
ret = sound_play(dev, data, data_size);
Expand Down
11 changes: 7 additions & 4 deletions drivers/sound/sound.c
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
#include <sound.h>

void sound_create_square_wave(uint sample_rate, unsigned short *data, int size,
uint freq)
uint freq, uint channels)
{
const unsigned short amplitude = 16000; /* between 1 and 32767 */
const int period = freq ? sample_rate / freq : 0;
Expand All @@ -21,14 +21,17 @@ void sound_create_square_wave(uint sample_rate, unsigned short *data, int size,
size--;

while (size) {
int i;
int i, j;

for (i = 0; size && i < half; i++) {
size -= 2;
*data++ = amplitude;
for (j = 0; j < channels; j++)
*data++ = amplitude;
}
for (i = 0; size && i < period - half; i++) {
size -= 2;
*data++ = -amplitude;
for (j = 0; j < channels; j++)
*data++ = -amplitude;
}
}
}
11 changes: 6 additions & 5 deletions include/sound.h
Original file line number Diff line number Diff line change
Expand Up @@ -37,13 +37,14 @@ struct sound_uc_priv {
/**
* Generates square wave sound data for 1 second
*
* @param sample_rate Sample rate in Hz
* @param data data buffer pointer
* @param size size of the buffer in bytes
* @param freq frequency of the wave
* @sample_rate: Sample rate in Hz
* @data: data buffer pointer
* @size: size of the buffer in bytes
* @freq: frequency of the wave
* @channels: Number of channels to use
*/
void sound_create_square_wave(uint sample_rate, unsigned short *data, int size,
uint freq);
uint freq, uint channels);

/*
* The sound uclass brings together a data transport (currently only I2C) and a
Expand Down

0 comments on commit f987177

Please sign in to comment.