OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [branches/] [stable_0_2_x/] [or1ksim/] [testbench/] [acv_gpio.c] - Blame information for rev 478

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 478 erez
/* GPIO test */
2
 
3
#include "support.h"
4
 
5
/* Relative Register Addresses */
6
#define RGPIO_IN        (4 * 0x00)
7
#define RGPIO_OUT       (4 * 0x01)
8
#define RGPIO_OE        (4 * 0x02)
9
#define RGPIO_INTE      (4 * 0x03)
10
#define RGPIO_PTRIG     (4 * 0x04)
11
#define RGPIO_AUX       (4 * 0x05)
12
#define RGPIO_CTRL      (4 * 0x06)
13
 
14
/* Fields inside RGPIO_CTRL */
15
#define RGPIO_CTRL_ECLK      0x00000001
16
#define RGPIO_CTRL_NEC       0x00000002
17
#define RGPIO_CTRL_INTE      0x00000004
18
#define RGPIO_CTRL_INT       0x00000008
19
 
20
#define GPIO_BASE 0xB0000000LU
21
 
22
typedef volatile unsigned long *GPIO_REG;
23
 
24
GPIO_REG rgpio_in = (unsigned long *)(GPIO_BASE + RGPIO_IN),
25
  rgpio_out = (unsigned long *)(GPIO_BASE + RGPIO_OUT),
26
  rgpio_oe = (unsigned long *)(GPIO_BASE + RGPIO_OE),
27
  rgpio_inte = (unsigned long *)(GPIO_BASE + RGPIO_INTE),
28
  rgpio_ptrig = (unsigned long *)(GPIO_BASE + RGPIO_PTRIG),
29
  rgpio_aux = (unsigned long *)(GPIO_BASE + RGPIO_AUX),
30
  rgpio_ctrl = (unsigned long *)(GPIO_BASE + RGPIO_CTRL);
31
 
32
int main()
33
{
34
  printf( "Starting GPIO test\n" );
35
 
36
  while ( *rgpio_in != 0x01234567 )
37
    ;
38
  *rgpio_oe = 0xffffffff;
39
  *rgpio_out = 0x89abcdef;
40
 
41
  printf( "Ending GPIO test\n" );
42
 
43
  report (0xdeaddead);
44
  return 0;
45
}
46
 
47
 

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.