File: sinusgen.c

package info (click to toggle)
faumachine 20180503-4
  • links: PTS
  • area: main
  • in suites: buster
  • size: 61,272 kB
  • sloc: ansic: 272,290; makefile: 6,199; asm: 4,251; sh: 3,022; perl: 886; xml: 563; pascal: 311; lex: 214; vhdl: 204
file content (93 lines) | stat: -rw-r--r-- 1,845 bytes parent folder | download
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/*
 * Copyright (C) 2016 FAUmachine Team <info@faumachine.org>.
 * This program is free software. You can redistribute it and/or modify it
 * under the terms of the GNU General Public License, either version 2 of
 * the License, or (at your option) any later version. See COPYING.
 */

#include <assert.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>

#include "glue.h"

#include "sinusgen.h"

struct cpssp{
	struct sig_std_logic *port_output;

	unsigned int state;
};

static void
sinusgen_tick(void *_cpssp)
{
	struct cpssp *cpssp = _cpssp;
	unsigned int mV;
	unsigned int mA;

	mV = (unsigned int) (2500.0 + 2000.0 * sin(2.0 * M_PI * (double) cpssp->state / 100.0));
	mA = mV * 0.5;

	sig_std_logic_set(cpssp->port_output, cpssp, SIG_COMB(mV, mA));

	cpssp->state = (cpssp->state + 1) % 100;

	/* In */
	time_call_at(time_virt() + TIME_HZ / 1000000, sinusgen_tick, cpssp);
	/*time_call_after(TIME_HZ / 10000, sinusgen_tick, cpssp);*/

}

void *
sinusgen_create(
	const char *name,
	struct sig_manage *port_manage,
	struct sig_std_logic *port_gnd,
	struct sig_std_logic *port_vcc,
	struct sig_std_logic *port_output
)
{

	struct cpssp *cpssp;

	cpssp = malloc(sizeof(*cpssp));
	assert(cpssp);

	cpssp->state = 0;

	/* Out */
	cpssp->port_output = port_output;
	sig_std_logic_connect_out(cpssp->port_output, cpssp, SIG_STD_LOGIC_0);

	/* In */
	time_call_at(time_virt() + TIME_HZ / 1000000, sinusgen_tick, cpssp);
	/*time_call_after(TIME_HZ / 100, sinusgen_tick, cpssp);*/

	return cpssp;
}


void
sinusgen_destroy(void *_cpssp)
{
	struct cpssp *cpssp = _cpssp;
	free(cpssp);
}

void
sinusgen_suspend(void *_cpssp, FILE *fp)
{
	struct cpssp *cpssp = _cpssp;

	generic_suspend(cpssp, sizeof(*cpssp), fp);
}

void
sinusgen_resume(void *_cpssp, FILE *fp)
{
	struct cpssp *cpssp = _cpssp;

	generic_resume(cpssp, sizeof(*cpssp), fp);
}