File: dio24_loopback.c

package info (click to toggle)
faumachine 20100527-2
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 53,836 kB
  • ctags: 20,552
  • sloc: ansic: 179,550; asm: 3,645; makefile: 3,611; perl: 2,103; sh: 1,529; python: 600; xml: 563; lex: 210; vhdl: 204
file content (79 lines) | stat: -rw-r--r-- 2,380 bytes parent folder | download | duplicates (2)
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
/*
 * $Id: dio24_loopback.c,v 1.12 2009-06-03 11:34:06 vrsieh Exp $ 
 *
 * Copyright (C) 2007-2009 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 <stdio.h>
#include <stdlib.h>

#include "dio24_loopback.h"

struct cpssp {
	struct sig_std_logic_merge *forward_a0_b0;
	struct sig_std_logic_merge *forward_a1_b1;
	struct sig_std_logic_merge *forward_a2_b2;
	struct sig_std_logic_merge *forward_a3_b3;
	struct sig_std_logic_merge *forward_a4_b4;
	struct sig_std_logic_merge *forward_a5_b5;
	struct sig_std_logic_merge *forward_a6_b6;
	struct sig_std_logic_merge *forward_a7_b7;

	struct sig_std_logic_merge *forward_c0_c4;
	struct sig_std_logic_merge *forward_c1_c5;
	struct sig_std_logic_merge *forward_c2_c6;
	struct sig_std_logic_merge *forward_c3_c7;
};

void *
dio24_loopback_create(
	const char *name,
	struct sig_manage *port_manage,
	struct sig_dio24 *port_dio24
)
{
	struct cpssp *cpssp;

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

	cpssp->forward_a0_b0 = sig_std_logic_merge(
			port_dio24->sig[0], port_dio24->sig[8]);
	cpssp->forward_a1_b1 = sig_std_logic_merge(
			port_dio24->sig[1], port_dio24->sig[9]);
	cpssp->forward_a2_b2 = sig_std_logic_merge(
			port_dio24->sig[2], port_dio24->sig[10]);
	cpssp->forward_a3_b3 = sig_std_logic_merge(
			port_dio24->sig[3], port_dio24->sig[11]);
	cpssp->forward_a4_b4 = sig_std_logic_merge(
			port_dio24->sig[4], port_dio24->sig[12]);
	cpssp->forward_a5_b5 = sig_std_logic_merge(
			port_dio24->sig[5], port_dio24->sig[13]);
	cpssp->forward_a6_b6 = sig_std_logic_merge(
			port_dio24->sig[6], port_dio24->sig[14]);
	cpssp->forward_a7_b7 = sig_std_logic_merge(
			port_dio24->sig[7], port_dio24->sig[15]);

	cpssp->forward_c0_c4 = sig_std_logic_merge(
			port_dio24->sig[16], port_dio24->sig[20]);
	cpssp->forward_c1_c5 = sig_std_logic_merge(
			port_dio24->sig[17], port_dio24->sig[21]);
	cpssp->forward_c2_c6 = sig_std_logic_merge(
			port_dio24->sig[18], port_dio24->sig[22]);
	cpssp->forward_c3_c7 = sig_std_logic_merge(
			port_dio24->sig[19], port_dio24->sig[23]);

	return cpssp;
}

void
dio24_loopback_destroy(void *_cpssp)
{
	struct cpssp *cpssp = _cpssp;

	free(cpssp);
}