summaryrefslogtreecommitdiffstats
path: root/ipedma_test.c
diff options
context:
space:
mode:
Diffstat (limited to 'ipedma_test.c')
-rw-r--r--ipedma_test.c28
1 files changed, 25 insertions, 3 deletions
diff --git a/ipedma_test.c b/ipedma_test.c
index a99a40b..d072a5c 100644
--- a/ipedma_test.c
+++ b/ipedma_test.c
@@ -15,6 +15,7 @@
#include <pcilib.h>
#include <pcilib/kmem.h>
+#include <pcilib/bar.h>
//#include <sys/ipc.h>
//#include <sys/shm.h>
@@ -29,14 +30,16 @@
#define BUFFERS 128
#define ITERATIONS 1000
-#define DESC_THRESHOLD BUFFERS/8 // Lorenzo: after how many desc the FPGA must update the "written descriptor counter" in PC mem
+#define DESC_THRESHOLD 1//BUFFERS/8 // Lorenzo: after how many desc the FPGA must update the "written descriptor counter" in PC mem
// if set to 0, the update only happens when INT is received
#define HUGE_PAGE 1 // number of pages per huge page
-#define TLP_SIZE 32 // TLP SIZE = 64 for 256B payload, 32 for 128B payload
+#define TLP_SIZE 64 // TLP SIZE = 64 for 256B payload, 32 for 128B payload
#define PAGE_SIZE 4096 // other values are not supported in the kernel
#define USE_64 // Lorenzo: use 64bit addressing
+#define USE_STREAMING // Use alternative implementation with streaming sequence of memory pages
+#define ENABLE_COUNTER 0x9000 // If set wee need to write 1 to the specified register to enable counter
//#define DUAL_CORE // Lorenzo: DUAL Core
@@ -405,8 +408,16 @@ int main() {
printf("* DMA: Start \n");
WR(0x04, 0x1);
+
+#ifdef ENABLE_COUNTER
+ printf("* Enable counter\n");
+ WR(ENABLE_COUNTER, 0x1);
+#endif /* ENABLE_COUNTER */
+
gettimeofday(&start, NULL);
+
+
// ******************************************************************
// **** Handshaking DMA *****
// ******************************************************************
@@ -438,7 +449,7 @@ int main() {
hwptr = desc[4];
#endif
j++;
- //printf("\rcurptr: %lx \t \t hwptr: %lx", curptr, hwptr);
+ //printf("curptr: %lx \t \t hwptr: %lx\n", curptr, hwptr);
} while (hwptr == curptr);
do {
@@ -446,6 +457,12 @@ int main() {
#ifdef MEM_COPY
memcpy(temp_data[i][curbuf], (void*)ptr[curbuf], 4096);
#endif
+
+#ifdef USE_STREAMING
+ WR(0x50, bus_addr[curbuf]);
+ // Now, we can check error in the register 0x68 (non-zero if there is an error)
+#endif /* USE_STREAMING */
+
#ifdef CHECK_RESULTS
for (k = 0; k < 1024 ; k++)
{
@@ -501,7 +518,12 @@ for (k = 0; k < 1024 ; k++)
}
#endif
+#ifndef USE_STREAMING
+ // Generally it is safe to write register in any case, it is just unsed in streaming mode
+ // Therefore, in the driver we can use it instead of software register so far
WR(0x58, curbuf + 1);
+#endif /* ! USE_STREAMING */
+
//printf("WR %d\n", curbuf + 1);
//printf("%u (%lu)\n", curbuf, j);
curptr = hwptr;