summaryrefslogtreecommitdiff
path: root/sim/testsuite/bfin/mdma-skel.h
blob: 920eff27116365f4c49544d9c15fb90ba40daeae (plain)
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
80
#include <stdlib.h>
#include <string.h>

void _mdma_memcpy (bu32 dst, bu32 src, bu32 size, bs16 mod)
{
  bu32 count = size >> (abs (mod) / 2);
  bu16 wdsize;
  switch (abs (mod))
    {
    case 4: wdsize = WDSIZE_32; break;
    case 2: wdsize = WDSIZE_16; break;
    default: wdsize = WDSIZE_8; break;
    }

  s->config = d->config = 0;

  d->irq_status = DMA_DONE | DMA_ERR;

  /* Destination */
  d->start_addr = dst;
  d->x_count = count;
  d->x_modify = mod;
  d->irq_status = DMA_DONE | DMA_ERR;

  /* Source */
  s->start_addr = src;
  s->x_count = count;
  s->x_modify = mod;
  s->irq_status = DMA_DONE | DMA_ERR;

  /* Enable */
  s->config = DMAEN | wdsize;
  d->config = WNR | DI_EN | DMAEN | wdsize;

  while (!(d->irq_status & DMA_DONE))
    continue;
}

void mdma_memcpy (bu32 dst, bu32 src, bu32 size);

#ifndef MAX_LEN
#define MAX_LEN 0x40000
#endif
bu32 _data[(MAX_LEN / 4) * 2 + 3];
char *data = (char *)(_data + 1);

int _start (void)
{
  char *src, *dst;
  bu32 len, canary, *canaries[3];

  canary = 0x12345678;

  len = 4;
  while (len < MAX_LEN)
    {
      src = data;
      dst = data + len + 4;
      /* Set up the canaries.  */
      canaries[0] = (void *)&src[-4];
      canaries[1] = (void *)&dst[-4];
      canaries[2] = (void *)&dst[len];
      *canaries[0] = *canaries[1] = *canaries[2] = canary;

      memset (src, 0xad, len);
      memset (dst, 0x00, len);

      mdma_memcpy ((bu32)dst, (bu32)src, len);
      if (memcmp (src, dst, len))
	DBG_FAIL;

      if (*canaries[0] != canary ||
	  *canaries[1] != canary ||
	  *canaries[2] != canary)
	DBG_FAIL;

      len <<= 4;
    }
  DBG_PASS;
}