URL
https://opencores.org/ocsvn/xge_mac/xge_mac/trunk
[/] [xge_mac/] [trunk/] [tbench/] [systemc/] [sc_xgmii_if.cpp] - Diff between revs 15 and 29
Go to most recent revision |
Show entire file |
Details |
Blame |
View Log
Rev 15 |
Rev 29 |
Line 53... |
Line 53... |
}
|
}
|
|
|
void xgmii_if::init(void) {
|
void xgmii_if::init(void) {
|
allow_idle_errors = false;
|
allow_idle_errors = false;
|
disable_padding = false;
|
disable_padding = false;
|
|
inject_noise = false;
|
}
|
}
|
|
|
void xgmii_if::connect_scoreboard(scoreboard *sbptr, scoreboard::sbSourceId sid) {
|
void xgmii_if::connect_scoreboard(scoreboard *sbptr, scoreboard::sbSourceId sid) {
|
sb = sbptr;
|
sb = sbptr;
|
sb_id = sid;
|
sb_id = sid;
|
Line 67... |
Line 68... |
packet_t* pkt;
|
packet_t* pkt;
|
|
|
sc_uint<64> txd = 0;
|
sc_uint<64> txd = 0;
|
sc_uint<8> txc = 0;
|
sc_uint<8> txc = 0;
|
|
|
|
int64_t noise [] = {0x1, 0xd5555555555555fb,
|
|
0x1, 0xd5555555555555fb,
|
|
0x1, 0xd5555555555555fc,
|
|
0x0, 0xd5555555555555fb,
|
|
0x1, 0xd5555555555555fb,
|
|
0x0, 0xd5555555555555fb,
|
|
0x1, 0x1111111111111111,
|
|
};
|
|
|
int lane = 0;
|
int lane = 0;
|
int bytecnt = 0;
|
int bytecnt = 0;
|
int length = 0;
|
int length = 0;
|
int preamblecnt = 0;
|
int preamblecnt = 0;
|
int ifg = 0;
|
int ifg = 0;
|
Line 78... |
Line 88... |
int coding_offset = 0;
|
int coding_offset = 0;
|
int fault_cnt = 0;
|
int fault_cnt = 0;
|
int fault_byte = 0;
|
int fault_byte = 0;
|
int fault_spacing;
|
int fault_spacing;
|
int fault_spacing_cnt = 0;
|
int fault_spacing_cnt = 0;
|
|
int count = 0;
|
|
int i = 0;
|
|
|
while (true) {
|
while (true) {
|
|
|
if (length == 0 && tx_fifo.nb_read(pkt)) {
|
if (length == 0 && tx_fifo.nb_read(pkt)) {
|
|
|
Line 262... |
Line 274... |
}
|
}
|
else {
|
else {
|
txd |= ((sc_uint<64>)0x07) << (8 * lane);
|
txd |= ((sc_uint<64>)0x07) << (8 * lane);
|
txc |= 0x01 << lane;
|
txc |= 0x01 << lane;
|
}
|
}
|
if (lane == 7) {
|
if (inject_noise) {
|
|
for (count = 0; count < 10000; count += 2) {
|
|
i = 2 * (random() % (sizeof(noise)/16));
|
|
cout << "NOISE: " << hex << noise[i] << " " << noise[i+1] << dec << endl;
|
|
xgmii_rxd = noise[i+1];
|
|
xgmii_rxc = noise[i];
|
|
txd = 0;
|
|
txc = 0;
|
|
wait();
|
|
}
|
|
inject_noise = false;
|
|
}
|
|
else if (lane == 7) {
|
xgmii_rxd = txd;
|
xgmii_rxd = txd;
|
xgmii_rxc = txc;
|
xgmii_rxc = txc;
|
txd = 0;
|
txd = 0;
|
txc = 0;
|
txc = 0;
|
wait();
|
wait();
|
© copyright 1999-2025
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.