Last modified by Alexander Schulz-Rosengarten on 2023/09/11 16:17

From version 12.1
edited by cmot
on 2014/02/10 20:48
Change comment: There is no comment for this version
To version 17.1
edited by cmot
on 2014/02/10 21:47
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -67,6 +67,7 @@
67 67  Now start modeling an SCChart. For example copy & paste the following sct code of abo, the hello world of SCCharts:
68 68  
69 69  {{code title="abo.sct"}}
70 +@VHLayout
70 70  scchart ABO {
71 71   input output bool A;
72 72   input output bool B;
... ... @@ -91,8 +91,80 @@
91 91  }
92 92  {{/code}}
93 93  
94 -
95 +As you save (Ctrl+S), KIELER will automatically draw the graphical SCChart diagram in a new KLigD view:
95 95  
97 +[[image:attach:kieler11.png]]
98 +
99 +You may want to re-arrange views. Just drag the KLighD view to the right side:
100 +
101 +[[image:attach:kieler12.png]]
102 +
103 +You will now see how to generate a C tick function.
104 +
96 96  = Generate C Code =
97 97  
98 -xxx
107 +You can do several transformations on SCCharts (*.sct files). Just right click the file you want to transform in the project explorer and select the Transform SCChart sub menu. As abo is already a Core SCCart you do not need the core transformations. Click the All Normalize Transformations, this will do the Split Trigger and Effects and the Surface and Depth transformations together (in this order).
108 +
109 +[[image:attach:kieler13.png]]
110 +
111 +After performing a transformation the transformed SCChart will open (together with it's KLighD diagram visualization):
112 +
113 +[[image:attach:kieler14.png]]
114 +
115 +Now generate the Sequentially Constructive Graph (SCG) from the normalized form. You do this also in the context menu of the Project Explorer by selecting the *.normalized.sct and choosing Generate SCG:
116 +
117 +[[image:attach:kieler15.png]]
118 +
119 +When selecting the abo.normalized.scg file the SCG diagram will be automatically synthesized (you may also want to re-arrange the KLigD view by dragging in to the right side again):
120 +
121 +[[image:attach:kieler16.png]]
122 +
123 +You can now populate the SCG automatically with dependency data. Choose Transform SCG -> SCG with Dependency Data from the context menu:
124 +
125 +[[image:attach:kieler17.png]]
126 +
127 +This will result in the following SCG:
128 +
129 +[[image:attach:kieler18.png]]
130 +
131 +Now populate the SCG with basic block information:
132 +
133 +[[image:attach:kieler19.png]]
134 +
135 +The SCG with calculated basic blocks will look like this:
136 +
137 +[[image:attach:kieler20.png]]
138 +
139 +The next step in compilation is the (more fine grained) calculate of scheduling blocks:
140 +
141 +[[image:attach:kieler21.png]]
142 +
143 +The populated SCG with scheduling information looks like this:
144 +
145 +[[image:attach:kieler22.png]]
146 +
147 +The SCG is now ready to be sequentialized. A primitive scheduler currently is included in KIELER but more elaborate ones are already in the pipe line:
148 +
149 +[[image:attach:kieler23.png]]
150 +
151 +The sequentialized SCG looks like this:
152 +
153 +[[image:attach:kieler24.png]]
154 +
155 +From here its only a short hop to C code. Transform the sequentialized SCG into an S Tick Function:
156 +
157 +[[image:attach:kieler25.png]]
158 +
159 +When opening the S file (abo.normalized.seq.s) this already is very c like code:
160 +
161 +[[image:attach:kieler26.png]]
162 +
163 +Selecting Generate SC will produce a C file:
164 +
165 +[[image:attach:kieler27.png]][[image:attach:kieler28.png]]
166 +
167 +
168 +
169 +
170 +
171 +
Confluence.Code.ConfluencePageClass[0]
Id
... ... @@ -1,1 +1,1 @@
1 -8651721
1 +8651731
URL
... ... @@ -1,1 +1,1 @@
1 -https://rtsys.informatik.uni-kiel.de/confluence//wiki/spaces/KIELER/pages/8651721/PLDI'14 Artifact on SCCharts
1 +https://rtsys.informatik.uni-kiel.de/confluence//wiki/spaces/KIELER/pages/8651731/PLDI'14 Artifact on SCCharts