config_leon3_drvmgr.c 2.9 KB
Newer Older
yoogx's avatar
yoogx committed
1
2
3
4
/* Note, this file is from RCC1.3rc4 sample directory.
 *
 * Any modification there should be carefully weighted.
 */
5
6
7
8
9
10
11
12
13

#include <drvmgr/ambapp_bus_grlib.h>
#include <drvmgr/ambapp_bus.h>
#include <ambapp_ids.h>

/* B1553RT driver configuration (optional) */
struct drvmgr_key grlib_drv_res_b1553rt0[] =
{
#ifdef SET_B1553RT_FREQ
yoogx's avatar
yoogx committed
14
        {"coreFreq", DRVMGR_KT_INT, {(unsigned int)SET_B1553RT_FREQ}},
15
#endif
yoogx's avatar
yoogx committed
16
        DRVMGR_KEY_EMPTY
17
18
19
20
21
};

/* GRPCI driver configuration (optional) */
struct drvmgr_key grlib_drv_res_grpci0[] =
{
yoogx's avatar
yoogx committed
22
23
        {"byteTwisting", DRVMGR_KT_INT, {(unsigned int)1}},
        DRVMGR_KEY_EMPTY
24
25
26
27
28
29
};

/* GRPCI2 driver configuration (optional) */
struct drvmgr_key grlib_drv_res_grpci2_0[] =
{
#if 0
yoogx's avatar
yoogx committed
30
31
32
33
        {"INTA#", DRVMGR_KT_INT, {(unsigned int)3}},
        {"INTB#", DRVMGR_KT_INT, {(unsigned int)3}},
        {"INTC#", DRVMGR_KT_INT, {(unsigned int)3}},
        {"INTD#", DRVMGR_KT_INT, {(unsigned int)3}},
34
#endif
yoogx's avatar
yoogx committed
35
        DRVMGR_KEY_EMPTY
36
37
38
39
40
41
};

/* GRGPIO0 driver configuration (optional) */
struct drvmgr_key grlib_drv_res_grgpio0[] =
{
#if 0
yoogx's avatar
yoogx committed
42
        {"nBits", DRVMGR_KT_INT, {(unsigned int)24}},
43
#endif
yoogx's avatar
yoogx committed
44
45
46
47
        {"int1", DRVMGR_KT_INT,  {(unsigned int)1}},
        {"ptr2", DRVMGR_KT_POINTER,  {(unsigned int)0x23334445}},
        {"str3", DRVMGR_KT_STRING,  {(unsigned int)"STRING_ValUe"}},
        DRVMGR_KEY_EMPTY
48
49
50
51
52
};

/* GRGPIO1 driver configuration (optional) */
struct drvmgr_key grlib_drv_res_grgpio1[] =
{
yoogx's avatar
yoogx committed
53
54
        {"nBits", DRVMGR_KT_INT, {(unsigned int)8}},
        DRVMGR_KEY_EMPTY
55
56
57
58
59
60
};

/* GRGPIO1 driver configuration (optional) */
struct drvmgr_key grlib_drv_res_spictrl0[] =
{
#ifdef SPICTRL_SLV_SEL_FUNC
yoogx's avatar
yoogx committed
61
        {"slvSelFunc", DRVMGR_KT_POINTER, {(unsigned int)SPICTRL_SLV_SEL_FUNC}},
62
#endif
yoogx's avatar
yoogx committed
63
        DRVMGR_KEY_EMPTY
64
65
66
67
68
69
70
};

/* If RTEMS_DRVMGR_STARTUP is defined we override the "weak defaults" that
 * is defined by the LEON3 BSP.
 */
struct drvmgr_bus_res grlib_drv_resources =
{
yoogx's avatar
yoogx committed
71
72
73
        .next = NULL,
        .resource = {
        {DRIVER_AMBAPP_GAISLER_GRPCI2_ID, 0, &grlib_drv_res_grpci2_0[0]},
74
#ifdef LITTLE_ENDIAN_PCI_SYSTEM
yoogx's avatar
yoogx committed
75
76
77
78
79
        /* this configuration option enables PCI byte-twisting which is
         * required for little-endian PCI systems such as for UT699 and
         * the GR-LEON4-ITX board.
         */
        {DRIVER_AMBAPP_GAISLER_GRPCI_ID, 0, &grlib_drv_res_grpci0[0]},
80
81
#endif
/*
yoogx's avatar
yoogx committed
82
83
        {DRIVER_AMBAPP_GAISLER_B1553RT_ID, 0, &grlib_drv_res_b1553rt0[0]},
        {DRIVER_AMBAPP_GAISLER_SPICTRL_ID, 0, &grlib_drv_res_spictrl0[0]},
84
*/
yoogx's avatar
yoogx committed
85
86
87
        {DRIVER_AMBAPP_GAISLER_GRGPIO_ID, 0, &grlib_drv_res_grgpio0[0]},
        DRVMGR_RES_EMPTY
        }
88
89
90
};

#ifndef RTEMS_DRVMGR_STARTUP
yoogx's avatar
yoogx committed
91
struct grlib_config grlib_bus_config =
92
{
yoogx's avatar
yoogx committed
93
94
        &ambapp_plb,		/* AMBAPP bus setup */
        &grlib_drv_resources,	/* Driver configuration */
95
96
97
98
99
100
101
};
#endif

/* LEON3 specific system init */
void system_init2(void)
{
#ifndef RTEMS_DRVMGR_STARTUP
yoogx's avatar
yoogx committed
102
103
        /* Register GRLIB root bus */
        ambapp_grlib_root_register(&grlib_bus_config);
104
105
#endif
}