source: trunk/softs/soft_transpose_giet/hard_config.h @ 975

Last change on this file since 975 was 810, checked in by cfuguet, 10 years ago

giet_tsar: updating giet_tsar to use new hard_config format

Other optimizations:

  • Using a memory lock instead of the hard lock for the TTY
  • Each tty channel data is aligned to a cacheline (lock and buffers).
  • The applications' ldscript is generated from a template which includes the hard_config.h file.
File size: 2.9 KB
Line 
1/* Generated by genmap for tsar_iob_2_2_4 */
2
3#ifndef HARD_CONFIG_H
4#define HARD_CONFIG_H
5
6/* General platform parameters */
7
8#define X_SIZE                 2
9#define Y_SIZE                 2
10#define X_WIDTH                4
11#define Y_WIDTH                4
12#define P_WIDTH                2
13#define X_IO                   0
14#define Y_IO                   0
15#define NB_PROCS_MAX           4
16#define IRQ_PER_PROCESSOR      4
17#define RESET_ADDRESS          0xbfc00000
18#define NB_TOTAL_PROCS         16
19
20/* Peripherals */
21
22#define NB_TTY_CHANNELS        1
23#define NB_IOC_CHANNELS        1
24#define NB_NIC_CHANNELS        2
25#define NB_CMA_CHANNELS        4
26#define NB_TIM_CHANNELS        0
27#define NB_DMA_CHANNELS        4
28
29#define USE_XCU                1
30#define USE_IOB                1
31#define USE_PIC                1
32#define USE_FBF                1
33
34#define USE_IOC_BDV            1
35#define USE_IOC_SPI            0
36#define USE_IOC_HBA            0
37#define USE_IOC_RDK            0
38
39#define FBUF_X_SIZE            128
40#define FBUF_Y_SIZE            128
41
42#define XCU_NB_INPUTS          16
43
44/* base addresses and sizes for physical segments */
45
46#define SEG_RAM_BASE           0x0
47#define SEG_RAM_SIZE           0x40000
48
49#define SEG_CMA_BASE           0xb6000000
50#define SEG_CMA_SIZE           0x4000
51
52#define SEG_DMA_BASE           0xb1000000
53#define SEG_DMA_SIZE           0x4000
54
55#define SEG_FBF_BASE           0xb7000000
56#define SEG_FBF_SIZE           0x4000
57
58#define SEG_ICU_BASE           0xffffffff
59#define SEG_ICU_SIZE           0x0
60
61#define SEG_IOB_BASE           0xbe000000
62#define SEG_IOB_SIZE           0x1000
63
64#define SEG_IOC_BASE           0xb3000000
65#define SEG_IOC_SIZE           0x1000
66
67#define SEG_MMC_BASE           0xb2000000
68#define SEG_MMC_SIZE           0x1000
69
70#define SEG_MWR_BASE           0xffffffff
71#define SEG_MWR_SIZE           0x0
72
73#define SEG_ROM_BASE           0xbfc00000
74#define SEG_ROM_SIZE           0x8000
75
76#define SEG_SIM_BASE           0xb9000000
77#define SEG_SIM_SIZE           0x1000
78
79#define SEG_NIC_BASE           0xb5000000
80#define SEG_NIC_SIZE           0x80000
81
82#define SEG_PIC_BASE           0xb8000000
83#define SEG_PIC_SIZE           0x1000
84
85#define SEG_TIM_BASE           0xffffffff
86#define SEG_TIM_SIZE           0x0
87
88#define SEG_TTY_BASE           0xb4000000
89#define SEG_TTY_SIZE           0x4000
90
91#define SEG_XCU_BASE           0xb0000000
92#define SEG_XCU_SIZE           0x1000
93
94#define SEG_RDK_BASE           0xffffffff
95#define SEG_RDK_SIZE           0x0
96
97#define PERI_CLUSTER_INCREMENT 0x10000
98
99/* physical base addresses for identity mapped vsegs */
100/* used by the GietVM OS                             */
101
102#define SEG_BOOT_MAPPING_BASE  0x0
103#define SEG_BOOT_MAPPING_SIZE  0x80000
104
105#define SEG_BOOT_CODE_BASE     0x80000
106#define SEG_BOOT_CODE_SIZE     0x40000
107
108#define SEG_BOOT_DATA_BASE     0xc0000
109#define SEG_BOOT_DATA_SIZE     0x80000
110
111#define SEG_BOOT_STACK_BASE    0x140000
112#define SEG_BOOT_STACK_SIZE    0x50000
113#endif
Note: See TracBrowser for help on using the repository browser.