]> AND Private Git Repository - blast.git/blobdiff - Graph.h
Logo AND Algorithmique Numérique Distribuée

Private GIT Repository
finished testbench generation
[blast.git] / Graph.h
diff --git a/Graph.h b/Graph.h
index 8b2015fdb736c769c9022ba7d05cff2168961406..bbd7eb2fa4553247a1454d5aa8b5b82a03f6c196 100644 (file)
--- a/Graph.h
+++ b/Graph.h
@@ -25,25 +25,32 @@ public:
   // getters  
   inline GroupBlock* getTopGroup() { return topGroup; }
   inline QList<GroupBlock*> getAllGroups() { return groups; }
+  inline double getClock(int id) { return clocks.at(id); }
+  inline QList<double>& getClocks() { return clocks; }
   
+  //setters
+  inline void resetClocks() { clocks.clear(); }
+
   // methods for group blocks
-  GroupBlock* createChildGroupBlock(GroupBlock* parent);
+  GroupBlock* createChildGroupBlock(GroupBlock* parent, bool createGroupIface = true);
   void removeGroupBlock(GroupBlock *group);
   GroupBlock* getGroupBlockByName(QString name);
   
   // methods for functional blocks
-  FunctionalBlock* createFunctionalBlock(GroupBlock *group, ReferenceBlock *ref);
+  FunctionalBlock* createFunctionalBlock(GroupBlock *group, ReferenceBlock *ref, bool createIfaces = true);
   FunctionalBlock* duplicateFunctionalBlock(FunctionalBlock *block);
   bool removeFunctionalBlock(FunctionalBlock* block);
   FunctionalBlock* getFunctionalBlockByName(QString name, GroupBlock* parent = NULL); //! if parent = NULL, search in the whole graph
 
-  // methods for source blocks
-  FunctionalBlock* createSourceBlock(ReferenceBlock *ref);
-  FunctionalBlock* duplicateSourceBlock(FunctionalBlock *block);
-  FunctionalBlock* getSourceBlockByName(QString name);
-  bool removeSourceBlock(FunctionalBlock* block);
+  // methods for stimulis blocks
+  FunctionalBlock* createStimuliBlock(ReferenceBlock *ref, bool createIfaces = true);
+  FunctionalBlock* duplicateStimuliBlock(FunctionalBlock *block);
+  FunctionalBlock* getStimuliBlockByName(QString name);
+  bool removeStimuliBlock(FunctionalBlock* block);
   
   // others
+  void createTopGroup(bool createTopGroupIfaces = true);
+  inline void addClock(double freq) { clocks.append(freq); }
   QList<AbstractInterface *> getOutsideInterfaces();
   QList<QString> getExternalResources(); // returns the list of all external files needed for VHDL generation
 
@@ -58,11 +65,13 @@ public:
   void computeOutputPatterns(int nbExec) throw(Exception);
   
   void generateVHDL(const QString& path) throw(Exception);
+  void generateTestbench(const QString& projectName, const QString& benchFile) throw(Exception);
 
 private:  
   GroupBlock* topGroup;
   QList<GroupBlock *> groups; //! usefull to avoid recursive methods to find a particular group.
-  QList<FunctionalBlock*> sources; //! source for the top group
+  QList<FunctionalBlock*> stimulis; //! source for the top group
+  QList<double> clocks; // clocks[0] is the main clock.
 
 };