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);
}
|