forked from sonakbi/block-demo-sifive
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpwm.json5
115 lines (115 loc) · 2.92 KB
/
pwm.json5
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
{
/////////////////////////////////////////////////////////////////////
definitions: {
ports: {
PCLK: 1,
PRESETn: 1,
PENABLE: 1,
PSELPTC: 1,
PADDR: 7,
PWRITE: 1,
PWDATA: 32,
PRDATA: -32,
INTptc0: -1,
INTptc1: -1,
INTptc2: -1,
INTptc3: -1,
INTptc4: -1,
INTptc5: -1,
capt0_event: 1,
capt1_event: 1,
capt2_event: 1,
capt3_event: 1,
capt4_event: 1,
capt5_event: 1,
PWM_OUT0: -1,
PWM_OUT1: -1,
PWM_OUT2: -1,
PWM_OUT3: -1,
PWM_OUT4: -1,
PWM_OUT5: -1,
},
ctrlPortMap: {
"PCLK": "PCLK",
"PSEL": "PSELPTC",
"PWRITE": "PWRITE",
// "__UMAP__": [
// [
// "PWM_OUT0",
// "PWM_OUT1",
// "PWM_OUT2",
// "PWM_OUT3",
// "PWM_OUT4",
// "PWM_OUT5"
// ],
// [
// "capt0_event",
// "capt1_event",
// "capt2_event",
// "capt3_event",
// "capt4_event",
// "capt5_event"
// ],
// [
// "INTptc0",
// "INTptc1",
// "INTptc2",
// "INTptc3",
// "INTptc4",
// "INTptc5"
// ]
// ],
"PADDR": "PADDR",
"PRDATA": "PRDATA",
"PENABLE": "PENABLE",
"PWDATA": "PWDATA",
"PRESETn": "PRESETn"
},
pg_cnt :1
},
/////////////////////////////////////////////////////////////////////
component: {
vendor: 'sifive',
library: 'blocks',
name: 'PWM',
version: '0.1.0',
busInterfaces: [
{
name: 'ctrl',
interfaceMode: 'slave',
busType: {vendor: 'amba.com', library: 'AMBA4', name: 'APB4', version: 'r0p0_0'},
abstractionTypes: [{ viewRef: 'RTLview', portMaps: {$ref: '#/definitions/ctrlPortMap'} }],
},
{
name: 'irq',
interfaceMode: 'master',
busType: {vendor: 'sifive.com', library: 'free', name: 'interrupts', version: '0.1.0'},
abstractionTypes: [{ viewRef: 'RTLview', portMaps: ['INTptc0','INTptc1','INTptc2','INTptc3','INTptc4','INTptc5'] }]
}
],
addressSpaces: [{
name : 'pwmAddressSpace',
range: 1024,
width: 32
}],
memoryMaps: [],
model: {
views: [{
name: 'RTLview',
displayName: 'RTL View',
description: 'Simple RTL view of a component.',
envIdentifier: '*Synthesis:',
componentInstantiationRef: 'VerilogModel'
}],
instantiations: [],
ports: {
$ref: '#/definitions/ports',
},
},
componentGenerators: [],
fileSets: {
VerilogFiles: ['PWM.v', 'PTC.v']
},
pSchema: {},
}
}