Browse Source

Test DMA reset value

Matthias Vogelgesang 6 years ago
parent
commit
1d158032d0
1 changed files with 12 additions and 3 deletions
  1. 12 3
      ddrio.c

+ 12 - 3
ddrio.c

@@ -7,6 +7,7 @@
 #include <unistd.h>
 #include <getopt.h>
 #include <time.h>
+#include <assert.h>
 #include <pcilib.h>
 #include <pcilib/bar.h>
 #include <pcilib/kmem.h>
@@ -148,13 +149,21 @@ elapsed_seconds (struct timespec *start, struct timespec *end)
     return (end->tv_sec + end->tv_nsec / 1000000000.0) - (start->tv_sec + start->tv_nsec / 1000000000.0);
 }
 
-
 static void
-reset_ddr_data (pcilib_t *pci, volatile void *bar, Options *opts)
+reset_dma (pcilib_t *pci, volatile void *bar)
 {
-    /* reset DMA */
+    uint32_t value;
+
     WR32_sleep (HF_REG_BASE, HF_BASE_RESET);
     WR32_sleep (HF_REG_BASE, 0);
+    value = RD32 (HF_REG_BASE);
+    assert (value == 0x14021700 || value == 0x14031700);
+}
+
+static void
+reset_ddr_data (pcilib_t *pci, volatile void *bar, Options *opts)
+{
+    reset_dma (pci, bar);
 
     /* reset DDR and FIFOs */
     WR32_sleep (HF_REG_CONTROL,