Commit bf1916f1 authored by Grzegorz Daniluk's avatar Grzegorz Daniluk Committed by Adam Wujek

wrc simulation: fix indentation to make checkpatch happy

parent 6d6018d7
......@@ -12,7 +12,7 @@
* This file provides the main() function that replaces the main function of
* wrc_main.c file when WRPC is compiled for testbench. This is done by
* configuring WRPC using make menuconfig:
* a) by using the default wrpc_sim_defconfig, i.e. "make wrpc_sim_defconfig", or
* a) by using the default wrpc_sim_defconfig, i.e. "make wrpc_sim_defconfig",or
* b) by chosing in make menuconfig the following opton:
* "Build simple software for test of WR PTP Core in simulatin"
*
......@@ -32,21 +32,23 @@
#include "softpll_ng.h"
#include <wrpc.h> /*needed for htons()*/
void wrc_run_task(struct wrc_task *t);
int wrpc_test_1(void);
/*
* This is a variable that is meant to be set by testbench through memory-manipulation.
* This is a variable that is meant to be set by testbench through
* memory-manipulation.
*
* To allow this, there are still some elements missing:
* - the test_number variable needs to be at a known address, this is already done
* for other variables (for VLANs?), so the same needs to be done for this
* - the test_number variable needs to be at a known address, this is already
* done for other variables (for VLANs?), so the same needs to be done for
* this
* - testbench needs to be modified appropriately
*
* The idea behind is that different tests for different testbenches are compiled in
* this file, and the proper test is loaded based on this variable. Each testbench
* sets the proper testbench number at th startup
* The idea behind is that different tests for different testbenches are
* compiled in this file, and the proper test is loaded based on this variable.
* Each testbench sets the proper testbench number at th startup
*/
static int test_number = 0;
static int test_number;
/*
* Basic initialization required for simulation
......@@ -58,7 +60,7 @@ static void wrc_sim_initialize(void)
sdb_find_devices();
timer_init(1);
//Source MAC used by WRPC's Endpoint
/* Source MAC used by WRPC's Endpoint */
mac_addr[0] = 0xDE;
mac_addr[1] = 0xAD;
mac_addr[2] = 0xBE;
......@@ -75,17 +77,17 @@ static void wrc_sim_initialize(void)
}
/*
* This is a test used by:
* - WRPC testbench located in "testbench/wrc_core" folder of the wr-cores repository
* (git://ohwr.org/hdl-core-lib/wr-cores.git)
* - WRPC testbench located in "testbench/wrc_core" folder of the wr-cores
* repository (git://ohwr.org/hdl-core-lib/wr-cores.git)
*
* This test:
* - sends min-size frames of PTP EtherType (0x88f7) and Dst MAC (01:1B:19:00:00:00)
* with embedded sequence number and flags providing information about the previously
* received frame
* - checkes whether the transmitted frames are successfully received back in a proper
* sequence (it is supposed that the testbench loops back the frames)
* - embeds in the next frame flag and return value regarding the previously received
* frames, i.e.:
* - sends min-size frames of PTP EtherType (0x88f7) and Dst MAC
* (01:1B:19:00:00:00) with embedded sequence number and flags providing
* information about the previously received frame
* - checkes whether the transmitted frames are successfully received back in a
* proper sequence (it is supposed that the testbench loops back the frames)
* - embeds in the next frame flag and return value regarding the previously
* received frames, i.e.:
* # the flags say:
* 0xAA: this is the first frame (no previous frames)
* 0xBB: previous frame was successfully received
......@@ -98,69 +100,67 @@ int wrpc_test_1(void)
struct hw_timestamp hwts;
struct wr_ethhdr_vlan tx_hdr;
struct wr_ethhdr rx_hdr;
int recvd, i, q_required;
int j;
uint8_t tx_payload[NET_MAX_SKBUF_SIZE - 32];
uint8_t rx_payload[NET_MAX_SKBUF_SIZE - 32];
int ret;
int tx_cnt=0, rx_cnt=0, pl_cnt;
// error code:
// 0xAA - first
// 0xBB - normal
// 0xE* - error code:
// 0 - Error: returned zero value
// 1 - Error: wrong seqID
// 2 - Error: error of rx
int code=0xAA;
/// prepare dummy frame
//payload
for(j=0; j<80; ++j) {
tx_payload[j] = 0xC7;//j;
}
//MAC address and EtherType of PTP
int ret = 0;
int tx_cnt = 0, rx_cnt = 0, pl_cnt;
/* error code:
* 0xAA - first
* 0xBB - normal
* 0xE* - error code:
* 0 - Error: returned zero value
* 1 - Error: wrong seqID
* 2 - Error: error of rx */
int code = 0xAA;
/** prepare dummy frame */
/* payload */
for (j = 0; j < 80; ++j)
tx_payload[j] = 0xC7;/* j; */
/* MAC address and EtherType of PTP */
memcpy(tx_hdr.dstmac, "\x01\x1B\x19\x00\x00\x00", 6);
tx_hdr.ethtype = htons(0x88f7);
/// main loop, send test frames
for (;;)
{
// seqID
/** main loop, send test frames */
for (;;) {
/* seqID */
tx_payload[0] = 0xFF & (tx_cnt >> 8);
tx_payload[1] = 0xFF & tx_cnt;
tx_payload[2] = 0xFF & (code >> 8);
tx_payload[3] = 0xFF & code;
// rx return value
/* rx return value */
tx_payload[4] = 0xFF & (ret >> 8);
tx_payload[5] = 0xFF & ret;
/* A frame is sent out with sequenceID (firt octet) and awaited reception. */
/* A frame is sent out with sequenceID (firt octet) and awaited
* reception. */
minic_tx_frame(&tx_hdr, tx_payload, 62, &hwts);
tx_cnt++;
ret=minic_rx_frame(&rx_hdr, rx_payload, NET_MAX_SKBUF_SIZE, &hwts);
/// check whether the received value is OK
if(ret == 0)
code = 0xE0; // Error: returned zero value
else if(ret > 0 ) {
if(pl_cnt == rx_cnt)
{
ret = minic_rx_frame(&rx_hdr, rx_payload, NET_MAX_SKBUF_SIZE,
&hwts);
/** check whether the received value is OK */
if (ret == 0)
code = 0xE0; /* Error: returned zero value */
else if (ret > 0) {
if (pl_cnt == rx_cnt) {
rx_cnt++;
code = 0xBB; // OK
}
else {
code = 0xBB; /* OK */
} else {
rx_cnt = pl_cnt+1;
code = 0xE1; // Error: wrong seqID
code = 0xE1; /* Error: wrong seqID */
}
}
else
code = 0xE2; // Error: error of rx
} else
code = 0xE2; /* Error: error of rx */
}
}
int main(void)
void main(void)
{
wrc_sim_initialize();
......@@ -169,6 +169,7 @@ int main(void)
wrpc_test_1();
break;
default:
while(1);
while (1)
;
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment