[21] | 1 | \begin{taskinfo} |
---|
| 2 | \let\UPMC\leader |
---|
| 3 | \let\ALL\enable |
---|
| 4 | \end{taskinfo} |
---|
| 5 | % |
---|
| 6 | \begin{objectif} |
---|
[107] | 7 | This task deals with the main features of digital systems. |
---|
[39] | 8 | Its objectives are the specification of the designer input, the |
---|
[107] | 9 | definition of the hardware architectural templates and of all the features |
---|
| 10 | that the HAS tools will share. |
---|
[21] | 11 | \end{objectif} |
---|
| 12 | % |
---|
[52] | 13 | \begin{workpackage} |
---|
[123] | 14 | \subtask This \ST specifies the COACH environment for the system designer. At this |
---|
[107] | 15 | level the COACH framework is a black box. The deliverables are documents |
---|
| 16 | specifying: how to feed COACH (the inputs), how to use COACH (the design flow), |
---|
| 17 | what is generated (the outputs). |
---|
| 18 | %(definition of the generic architecture of the |
---|
| 19 | %MPSoC and its 3 targets hardware mapping). |
---|
[21] | 20 | \begin{livrable} |
---|
[231] | 21 | \CoutHorsD{0}{12}{\Sbull}{User specification}{3:0:0} |
---|
[107] | 22 | \itemV{0}{6}{d}{\Supmc}{COACH specification} \setMacroInAuxFile{specGenManualI} |
---|
| 23 | The first version of the COACH specification. |
---|
| 24 | This document contains the general description of the framework, the design flow and the |
---|
[36] | 25 | description of the architectural templates. |
---|
[155] | 26 | It refers to the HAS specification (deliverable {\specHasManual}) and |
---|
| 27 | to the CSG specifcation (deliverable \specCsgManual) for the COACH input |
---|
[36] | 28 | descriptions. |
---|
[107] | 29 | \itemL{6}{12}{d}{\Supmc}{COACH specification}{1:0:0} \setMacroInAuxFile{specGenManual} |
---|
[186] | 30 | The final version of the {\specGenManualI} deliverable updated with the first |
---|
[113] | 31 | feed-backs of the demonstrator \STs. |
---|
[107] | 32 | \itemV{0}{6}{d}{\Stima}{CSG specification} \setMacroInAuxFile{specCsgManualI} |
---|
| 33 | The first version of the CSG (COACH System Generator) specification. |
---|
[38] | 34 | It specifies how the task graph is described, the communication schemes and its |
---|
[36] | 35 | associated API (Application Programming Interface). |
---|
[38] | 36 | The base is the SRL library and the MWMR communication component defined by the SocLib |
---|
[36] | 37 | ANR project. |
---|
[56] | 38 | Nevertheless, these basic schemes will be enhanced to allow more efficient |
---|
[36] | 39 | synthesis. |
---|
[107] | 40 | \itemL{6}{12}{d}{\Stima}{CSG specification}{1:0:0} \setMacroInAuxFile{specCsgManual} |
---|
[186] | 41 | The final version of the {\specGenManualI} deliverable updated with the first |
---|
[113] | 42 | feed-backs of the demonstrator \STs. |
---|
[218] | 43 | \itemV{0}{6}{d}{\Subs}{HAS specification} \setMacroInAuxFile{specHasManualI} |
---|
[107] | 44 | The first version of the HAS (Hardware Accelerator Synthesis) specification. |
---|
[38] | 45 | It specifies how tasks must be written (C/C++ subset) and how |
---|
[155] | 46 | communication schemes defined in the {\specCsgManual} deliverable must be described for |
---|
[36] | 47 | coprocessor synthesis. |
---|
[206] | 48 | \itemL{6}{12}{d}{\Subs}{HAS specification}{2:0:0} \setMacroInAuxFile{specHasManual} |
---|
[186] | 49 | The final version of the {\specGenManualI} deliverable updated with the first |
---|
[113] | 50 | feed-backs of the demonstrator \STs. |
---|
[21] | 51 | \end{livrable} |
---|
[123] | 52 | \subtask This \ST specifies the software COACH structure. The deliverable is a |
---|
[21] | 53 | document listing all the COACH software components and how they cooperate. |
---|
| 54 | \begin{livrable} |
---|
[213] | 55 | \CoutHorsD{0}{12}{\Sthales}{User specification}{1:0:0} |
---|
[218] | 56 | \itemL{0}{6}{d}{\Supmc}{COACH internal \ganttlf software architecture}{1:0:0} |
---|
| 57 | Description of the software list and the data flow among the tools. |
---|
[21] | 58 | \end{livrable} |
---|
[186] | 59 | \subtask This \ST specifies the \xcoach and the \xcoachplus formats. |
---|
[21] | 60 | \begin{livrable} |
---|
[115] | 61 | \itemV{0}{6}{d+x}{\Slip}{\xcoach format specification} |
---|
[36] | 62 | \setMacroInAuxFile{specXcoachDocI} |
---|
| 63 | First release of the XML specification of the \xcoach format (DTD) |
---|
[21] | 64 | and its associated documentation allowing to start HLS tools development. |
---|
[115] | 65 | \itemV{6}{12}{d+x}{\Slip}{\xcoach format specification} |
---|
[36] | 66 | \setMacroInAuxFile{specXcoachDocII} |
---|
[21] | 67 | Second release of XML specification of the \xcoach format |
---|
| 68 | taking into account the corrections and modifications that the |
---|
[38] | 69 | developers of HAS tools suggested. |
---|
[167] | 70 | \itemL{12}{18}{d+x}{\Slip}{\xcoach format specification}{7:3:0} |
---|
[36] | 71 | \setMacroInAuxFile{specXcoachDoc} |
---|
| 72 | Last release of XML specification of the \xcoach format enhanced with |
---|
[38] | 73 | the expression of loop potential parallelism. |
---|
[213] | 74 | \itemV{6}{12}{x}{\Subs}{First release of C2X} |
---|
[47] | 75 | \setMacroInAuxFile{specXcoachToCAI} |
---|
[107] | 76 | A GCC plugin C2X that generates a \xcoach description |
---|
| 77 | (defined in {\specXcoachDocI} deliverable) from a C/C++ task description |
---|
[47] | 78 | (defined in {\specHasManual} deliverable). |
---|
[214] | 79 | \itemL{12}{18}{x}{\Subs}{C2X tool}{2:1:0} |
---|
[73] | 80 | \setMacroInAuxFile{specXcoachToCA} |
---|
[206] | 81 | An updated version of C2X (\specXcoachToCAI) which supports the \xcoach format defined |
---|
| 82 | in the {\specXcoachDoc} deliverable and the HAS input format defined in the {\specHasManual} |
---|
[47] | 83 | deliverable. |
---|
[213] | 84 | \itemV{7}{12}{x}{\Subs}{First release of X2C} |
---|
[47] | 85 | \setMacroInAuxFile{specXcoachToCBI} |
---|
[107] | 86 | This second tool X2C regenerates a C description from a \xcoach |
---|
[21] | 87 | description. |
---|
[214] | 88 | \itemL{12}{18}{x}{\Subs}{X2C tool}{2:1:0} |
---|
[47] | 89 | \setMacroInAuxFile{specXcoachToCB} |
---|
| 90 | The same software as the former (\specXcoachToCBI) but for the \xcoach format as defined |
---|
[38] | 91 | in the {\specXcoachDoc} deliverable and HAS input as defined in the {\specHasManual} |
---|
[36] | 92 | deliverable. |
---|
[213] | 93 | \itemV{12}{18}{x}{\Supmc}{First release of X2SC} |
---|
[36] | 94 | \setMacroInAuxFile{specXcoachToSystemCI} |
---|
[107] | 95 | The first release of the software tool X2SC that translates \xcoachplus description to CABA |
---|
[36] | 96 | and TLM-DT SystemC module. |
---|
[214] | 97 | \itemL{18}{24}{x}{\Supmc}{X2SC tool}{0:2:0} |
---|
[36] | 98 | \setMacroInAuxFile{specXcoachToSystemC} |
---|
[186] | 99 | Final release of the former software (\specXcoachToSystemCI). |
---|
[213] | 100 | \itemV{12}{18}{x}{\Subs}{First release of the X2VHDL} |
---|
[36] | 101 | \setMacroInAuxFile{specXcoachToVhdlI} |
---|
[213] | 102 | The first release of the software tool X2VHDL that translates \xcoachplus description to |
---|
[21] | 103 | synthesizable VHDL description. |
---|
[214] | 104 | \itemL{18}{24}{x}{\Subs}{X2VHDL tool}{0:3:0} |
---|
[36] | 105 | \setMacroInAuxFile{specXcoachToVhdl} |
---|
[186] | 106 | Final release of the former software (\specXcoachToVhdlI) and integration |
---|
[113] | 107 | of enhancements proposed in \novers{\specXilinxOptimization} deliverable. |
---|
[244] | 108 | \itemL{18}{21}{d}{\Sxilinx}{\xilinx RTL optimisation (1)}{0:3:0} |
---|
[113] | 109 | \setMacroInAuxFile{specXilinxOptimization} |
---|
| 110 | This deliverable consists in optimizing the VHDL generated from \xcoachplus format |
---|
[237] | 111 | (deliverable \novers{\specXcoachToVhdl}) for the \xilinx RTL synthesis tools. |
---|
[113] | 112 | \ubs will provide several examples of VHDL source files generated from \xcoachplus, |
---|
| 113 | with explanations about generation process of main data structures used in VHDL sources, |
---|
| 114 | \xilinx will provide back a documentation listing that proposes VHDL generation enhancements. |
---|
[21] | 115 | \end{livrable} |
---|
[73] | 116 | |
---|
[123] | 117 | \subtask This \ST aims to define a tool in order to pilot the GCC/xcoach compiler. |
---|
[73] | 118 | \begin{livrable} |
---|
[215] | 119 | \itemL{0}{3}{d}{\Subs}{GCC driver specification}{1:0:0} |
---|
[186] | 120 | Specification of the GCC driver tool. |
---|
[215] | 121 | \itemV{3}{9}{x}{\Subs}{GCC driver} |
---|
[187] | 122 | First release of the GCC driver tool. |
---|
[186] | 123 | %en T0+18 car va peut etre evoluer en fonction du DSE µ-archi |
---|
[215] | 124 | \itemL{9}{12}{x}{\Subs}{GCC driver}{3:0:0} |
---|
[186] | 125 | Final release of the GCC driver tool. |
---|
[73] | 126 | \end{livrable} |
---|
| 127 | |
---|
[123] | 128 | \subtask Backend HLS tools use a characterized macro-cell library to build the |
---|
[38] | 129 | micro-architecture of a coprocessor. The characterisation of a cell depends |
---|
[21] | 130 | on the target device. The role of this \ST is to define the macro-cells and |
---|
| 131 | to provite a tool that characterizes them automatically by synthesizing them |
---|
| 132 | and by extracting their delays. This is done by using RTL synthesis. |
---|
| 133 | \begin{livrable} |
---|
[213] | 134 | \itemL{0}{6}{d}{\Subs}{Macro-cell definition}{1:0:0} |
---|
[123] | 135 | \setMacroInAuxFile{specMacroCell} |
---|
[186] | 136 | Definition of the macro cells and the file format describing them. |
---|
[213] | 137 | \itemL{6}{12}{x}{\Subs}{Macro-cell library generator}{2:0:0} |
---|
[186] | 138 | Final release of the software tool that generates automatically the characterized macro-cell library |
---|
[21] | 139 | for a FPGA device. |
---|
| 140 | \end{livrable} |
---|
| 141 | \end{workpackage} |
---|