summaryrefslogtreecommitdiffstats
path: root/drivers/sound/synth.c
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;
		}
	}
}