blob: c9de62b516841ca9903f8c8cd650fc4e3927fd7a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
// SPDX-License-Identifier: GPL-2.0-only
/*
* Copyright (C) 2012 Samsung Electronics, R. Chandrasekar <rcsekar@samsung.com>
* Copyright (C) 2021 Ahmad Fatoum
*/
#include <common.h>
#include <linux/fixp-arith.h>
#include <linux/math64.h>
#include <sound.h>
void __synth_sin(unsigned freq, s16 amplitude, s16 *stream,
unsigned sample_rate, unsigned nsamples)
{
int64_t v = 0;
int i = 0;
for (i = 0; i < nsamples; i++) {
/* Assume RHS sign extension, true for GCC */
stream[i] = (fixp_sin32(div_s64(v * 360, sample_rate)) * (int64_t)amplitude) >> 31;
v += freq;
}
}
void __synth_square(unsigned freq, s16 amplitude, s16 *stream,
unsigned sample_rate, unsigned nsamples)
{
unsigned period = freq ? sample_rate / freq : 0;
int half = period / 2;
while (nsamples) {
int i;
for (i = 0; nsamples && i < half; i++) {
nsamples--;
*stream++ = amplitude;
}
for (i = 0; nsamples && i < period - half; i++) {
nsamples--;
*stream++ = -amplitude;
}
}
}
|