From 0f36d8c38604a910afbe13fad4b1e7fc099fc025 Mon Sep 17 00:00:00 2001
From: Daniela Genius <Daniela.Genius@lip6.fr>
Date: Tue, 11 Oct 2016 10:31:01 +0000
Subject: [PATCH] update on mapping table

---
 .../toTopCell/MappingTable.java               | 120 ++++--------------
 src/ddtranslatorSoclib/toTopCell/NetList.java |  24 +---
 2 files changed, 32 insertions(+), 112 deletions(-)

diff --git a/src/ddtranslatorSoclib/toTopCell/MappingTable.java b/src/ddtranslatorSoclib/toTopCell/MappingTable.java
index 8735a5847f..907400d398 100755
--- a/src/ddtranslatorSoclib/toTopCell/MappingTable.java
+++ b/src/ddtranslatorSoclib/toTopCell/MappingTable.java
@@ -64,58 +64,54 @@ public class MappingTable {
 	int j=0; int i=0;
 	int size;
 	//if(TopCellGenerator.avatardd.getAllCrossbar().size()==0){	     
-	    for (AvatarRAM ram : TopCellGenerator.avatardd.getAllRAM()) {
-	
-			 if(ram.getDataSize()==0){
+	 
+	for (AvatarRAM ram : TopCellGenerator.avatardd.getAllRAM()) {
+	    // if no data size is given calculate default data size
+	    if(ram.getDataSize()==0){
 	
 		if((nb_clusters<16)||(TopCellGenerator.avatardd.getAllRAM().size()<16)){
 		    size = 1073741824;
 		}
-		else {//smaller segments
+		else {//dimension segments to be smaller
 		    size = 268435456; 
-		} // to be refined, a la DSX
+		}
 	    }
 	    else{
 		size = ram.getDataSize();
 	    }
 	    ram.setDataSize(size);
-	    //ram.setDataSize(0);
+	    
 	    size = ram.getDataSize(); // this is the hardware RAM size 
 
-	    int cacheability_bit= 2097152; //0x00200000			      
+	    int step = 268435456;// DG 11.10. attention cacheability bit, cannot take any size given in DD, must be checked, toDo
+
+	    int cacheability_bit= 2097152; //0x00200000	
+		      
 		/* Boot Ram segments 0,1,2 */
 		if(ram.getNo_ram() ==0){
-		    ram.setNo_target(2);//in the following assign target number 2	
-		    //mapping += "maptab.add(Segment(\"cram" + ram.getNo_ram() + "\", 0x" +(ram.getNo_ram()+1)+ "0000000, 0x00100000, IntTab("+(ram.getNo_target())+"), true));" + CR;
-		    //mapping += "maptab.add(Segment(\"uram" + ram.getNo_ram() + "\", 0x" +(ram.getNo_ram()+1)+ "0200000, 0x00100000, IntTab("+(ram.getNo_target())+"), false));" + CR;	
-
-		    /*   mapping += "maptab.add(Segment(\"cram" + ram.getNo_ram() + "\", 0x" +(ram.getNo_ram()+1)+ "0000000, "+ram.getDataSize()+", IntTab("+(ram.getNo_target())+"), true));" + CR;
-			 mapping += "maptab.add(Segment(\"uram" + ram.getNo_ram() + "\", 0x" +(ram.getNo_ram()+1)+ "0200000, "+ram.getDataSize()+", IntTab("+(ram.getNo_target())+"), false));" + CR;*/
+		    ram.setNo_target(2);//in the following assign target number 2			
 		   
- mapping += "maptab.add(Segment(\"cram" + ram.getNo_ram() + "\", 0x" +Integer.toHexString(address_start+i*size)+ ", 0x"+Integer.toHexString(ram.getDataSize()/2)+", IntTab("+(ram.getNo_target())+"), true));" + CR;
- mapping += "maptab.add(Segment(\"uram" + ram.getNo_ram() + "\", 0x" + Integer.toHexString(address_start+i*size+cacheability_bit+ram.getDataSize()/2)+ ", 0x"+Integer.toHexString(ram.getDataSize()/2)+", IntTab("+(ram.getNo_target())+"), false));" + CR;
-	
-	
+		    mapping += "maptab.add(Segment(\"cram" + ram.getNo_ram() + "\", 0x" +Integer.toHexString(address_start+i*step)+ ", 0x"+Integer.toHexString(ram.getDataSize()/2)+", IntTab("+(ram.getNo_target())+"), true));" + CR;
+ mapping += "maptab.add(Segment(\"uram" + ram.getNo_ram() + "\", 0x" + Integer.toHexString(address_start+i*step+cacheability_bit+ram.getDataSize()/2)+ ", 0x"+Integer.toHexString(ram.getDataSize()/2)+", IntTab("+(ram.getNo_target())+"), false));" + CR;
+                i++;
 		}
 		else{
 		    ram.setNo_target(7+j);
-		    //mapping += "maptab.add(Segment(\"cram" + ram.getNo_ram() + "\", 0x" +(ram.getNo_ram()+1)+ "0000000, 0x00100000, IntTab("+(ram.getNo_target())+"), true));" + CR;
-		    //mapping += "maptab.add(Segment(\"uram" + ram.getNo_ram() + "\", 0x" +(ram.getNo_ram()+1)+ "0200000, 0x00100000, IntTab("+(ram.getNo_target())+"), false));" + CR;
-		    mapping += "maptab.add(Segment(\"cram" + ram.getNo_ram() + "\", 0x" + Integer.toHexString(address_start+i*size)+ ",  0x"+Integer.toHexString(ram.getDataSize()/2)+", IntTab("+(ram.getNo_target())+"), true));" + CR;
- mapping += "maptab.add(Segment(\"uram" + ram.getNo_ram() + "\", 0x" + Integer.toHexString(address_start+i*size+size/2+cacheability_bit) + " ,  0x"+Integer.toHexString(ram.getDataSize()/2)+", IntTab("+(ram.getNo_target())+"), false));" + CR;
-
-		    j++;	 
+		
+		    mapping += "maptab.add(Segment(\"cram" + ram.getNo_ram() + "\", 0x" + Integer.toHexString(address_start+i*step)+ ",  0x"+Integer.toHexString(ram.getDataSize()/2)+", IntTab("+(ram.getNo_target())+"), true));" + CR;
+ mapping += "maptab.add(Segment(\"uram" + ram.getNo_ram() + "\", 0x" + Integer.toHexString(address_start+i*step+ram.getDataSize()/2+cacheability_bit) + " ,  0x"+Integer.toHexString(ram.getDataSize()/2)+", IntTab("+(ram.getNo_target())+"), false));" + CR;
+		    j++;	
+		    i++;	 
 		}
-		i++;
 	    }
       int m=0;
       for (AvatarTTY tty : TopCellGenerator.avatardd.getAllTTY()) {
 	  /* we calculate the target number of one or several (multi-) ttys which come after the j rams and the 7 compulsory targets */	
         tty.setNo_target(7+j);		 
         /* we use a simple formula for calculating the TTY address in case of multiple (multi-) ttys */	
+
 	/* attention this will not work for more than 10 TTYs */
 	mapping += "maptab.add(Segment(\"vci_multi_tty"+m+"\" , 0xd"+tty.getNo_tty()+"200000, 0x00000010, IntTab(" +tty.getNo_target() +"), false));" + CR;
-	//	mapping += "maptab.add(Segment(\"vci_multi_tty"+m+"\" , 0xe"+(m+1)+"200000, 0x00000010, IntTab(" +tty.getNo_target() +"), false));" + CR; 
 
         j++;
 	m++;
@@ -126,50 +122,10 @@ public class MappingTable {
       mapping = mapping + "maptab.add(Segment(\"vci_ethernet\",  0xd5000000, 0x00000020, IntTab("+(l+2)+"), false));" + CR;
       mapping = mapping + "maptab.add(Segment(\"vci_block_device\", 0xd1200000, 0x00000020, IntTab("+(l+3)+"), false));" + CR2;
       mapping = mapping + "maptab.add(Segment(\"vci_locks\", 0xC0200000, 0x00000100, IntTab("+(l+4)+"), false));" + CR2;
-      // mapping = mapping + "maptab.add(Segment(\"mwmr_ram\", 0xA0200000,  0x00001000, IntTab("+(l+5)+"), false));" + CR2;
-      //mapping = mapping + "maptab.add(Segment(\"mwmrd_ram\", 0xB0200000,  0x00003000, IntTab("+(l+6)+"), false));" + CR2;
-     
-      //DG 29.08.
-      // mapping = mapping + "maptab.add(Segment(\"cram\", 0xA0200000,  0x00001000, IntTab("+(l+5)+"), true));" + CR2;
-      //mapping = mapping + "maptab.add(Segment(\"uram\", 0xB0200000,  0x00003000, IntTab("+(l+6)+"), false));" + CR2;
+    
       return mapping;   
     }
 
-
-  ///////////////////////////////////////////////////////////////////////////////////////////////////
-    //                 Mapping Table                                                                 //
-    // There are 4 replicated segments in each cluster, and 8 single (not replicated) segments.      //
-    // - Peripheral single segments (rom, ramdac, tg) are mapped in the cluster_rom and cluster_io.  //
-    // - RAM single segments are mapped in each cluster at the first addresse of the cluster.        //
-    // - Peripherals replicated segments (timer, icu, dma) are replicated in each cluster.           //
-    ///////////////////////////////////////////////////////////////////////////////////////////////////
-    
-    /*    MappingTable maptab(32, IntTab(8,4), IntTab(8,4), 0xFFFF0000);
-
-    maptab.add(Segment("seg_ie"    , SEG_IE_BASE    , SEG_IE_SIZE    , IntTab(cluster_io , TGTID_IE),     false));
-    maptab.add(Segment("seg_oe", SEG_OE_BASE, SEG_OE_SIZE, IntTab(cluster_io , TGTID_OE), false));
-    maptab.add(Segment("seg_tty"   , SEG_TTY_BASE   , SEG_TTY_SIZE   , IntTab(cluster_io , TGTID_TTY),    false));
-    maptab.add(Segment("seg_reset" , SEG_RESET_BASE , SEG_RESET_SIZE , IntTab(cluster_rom, tgtid_rom),    true));
-
-    for (size_t c = 0; c < nc; c++) {
-        uint32_t ram_base = SEG_RAM_BASE + c * CLUSTER_SIZE;
-        uint32_t ram_size = SEG_RAM_SIZE;
-        std::ostringstream seg_ram_name;
-        seg_ram_name << "seg_ram_" << c;
-        maptab.add(Segment(seg_ram_name.str(), ram_base, ram_size, IntTab(c, TGTID_RAM), true));
-
-        uint32_t timer_base = SEG_TIM_BASE + c * CLUSTER_SIZE;
-        uint32_t timer_size = SEG_TIM_SIZE;
-        std::ostringstream seg_timer_name;
-        seg_timer_name << "seg_timer_" << c;
-        maptab.add(Segment(seg_timer_name.str(), timer_base, timer_size, IntTab(c, TGTID_TIM), true));
-
-        uint32_t icu_base = SEG_ICU_BASE + c * CLUSTER_SIZE;
-        uint32_t icu_size = SEG_ICU_SIZE;
-        std::ostringstream seg_icu_name;
-        seg_icu_name << "seg_icu_" << c;
-        maptab.add(Segment(seg_icu_name.str(), icu_base, icu_size, IntTab(c, TGTID_ICU), false)); */
-
     else{
 	/* clustered version */
 
@@ -188,31 +144,7 @@ public class MappingTable {
       mapping = mapping + "maptab.add(Segment(\"vci_ethernet\",  0x18200000, 0x00000020, IntTab(0,6), false));" + CR;
       mapping = mapping + "maptab.add(Segment(\"vci_block_device\", 0x19200000, 0x00000020, IntTab(0,7), false));" + CR2;
          mapping = mapping + "maptab.add(Segment(\"vci_locks\", 0x1A200000, 0x00000020, IntTab(0,8), false));" + CR2;
-    
-      // uint32_t ram_base = SEG_RAM_BASE + c * CLUSTER_SIZE;
-      // soft/hard_config.h:#define	 CLUSTER_SIZE  0x40000000
-
-      //  int SEG_RAM_BASE   =        0x10000000;
-     
-      //the following three components are added transparently in the deployment diagram    
-      /* int SEG_ICU_BASE   =          0x11000000;
-      int SEG_ICU_SIZE   =          0x00000014;
-
-      int NB_DMAS  = 1;
-      int SEG_DMA_BASE   =          0x12200000;
-      int SEG_DMA_SIZE  =           (NB_DMAS * 0x00000014);
-
-      int NB_TIMERS  = 1;
-      int SEG_TIM_BASE   =          0x13000000;
-      int SEG_TIM_SIZE  =           (NB_TIMERS * 16 );
-
-      int SEG_TTY_BASE   =        0x14200000;
-      int SEG_TTY_SIZE   =        0x00000010;
-
-      int CLUSTER_SIZE  =  0x40000000;*/
-
-      
-
+        
       int SEG_ICU_BASE  =          285212672;
       int SEG_ICU_SIZE  =          20;
 
@@ -236,7 +168,7 @@ public class MappingTable {
 	  CLUSTER_SIZE = 134217728; 
       }// to be refined, cf DSX -> dynamically adapt
 
-      /* RAM adresses always start at 0x10000000 dec 268435456*/
+      /* RAM adresses always start at 0x10000000 decimal 268435456*/
 
       int SEG_RAM_BASE   =        268435456;    
       int    cluster = 0;
@@ -250,7 +182,7 @@ mapping += "maptab.add(Segment(\"dma\", 0x"+ Integer.toHexString(SEG_DMA_BASE)+"
 
 mapping += "maptab.add(Segment(\"vci_rttimer\", 0x"+ Integer.toHexString(SEG_TIM_BASE)+", 0x"+ Integer.toHexString(SEG_TIM_SIZE)+", IntTab(0,11), true));" + CR;
 
-  // all other clusters  
+// all other clusters  
 //   for(cluster=1;cluster<nb_clusters; cluster++){
       
 	  //	  mapping += "maptab.add(Segment(\"icu" + cluster + "\", 0x"+ Integer.toHexString(SEG_ICU_BASE + cluster * CLUSTER_SIZE)+", 0x"+Integer.toHexString(SEG_ICU_SIZE)+", IntTab("+cluster +","+1+"), true));" + CR;
@@ -261,7 +193,7 @@ mapping += "maptab.add(Segment(\"vci_rttimer\", 0x"+ Integer.toHexString(SEG_TIM
  	   
 	  // }
  
-      int cacheability_bit= 2097152; //0x00200000
+      int cacheability_bit= 2097152; //0x00200000 T
 
       /* RAM base address is SEG_RAM_BASE + CLUSTER_NUMBER * CLUSTER_SIZE;
      this is the memory space covered by the RAMs of a cluster */
diff --git a/src/ddtranslatorSoclib/toTopCell/NetList.java b/src/ddtranslatorSoclib/toTopCell/NetList.java
index 1c71a31cac..c81b2dfcc6 100755
--- a/src/ddtranslatorSoclib/toTopCell/NetList.java
+++ b/src/ddtranslatorSoclib/toTopCell/NetList.java
@@ -139,19 +139,7 @@ public class NetList {
 		else{
 		    netlist = netlist + "vgsb.p_to_target["+(ram.getNo_target())+"](signal_vci_vciram"+ram.getNo_ram()+");" + CR2;
 		}		   
-	    }
-	
-	    //MWMR RAM added transparently
-	    /*    netlist = netlist +"mwmr_ram.p_clk(" + NAME_CLK + ");" + CR;
-	    netlist = netlist +"mwmr_ram.p_resetn(" + NAME_RST + ");" + CR;
-	    netlist = netlist +"mwmr_ram.p_vci(signal_vci_mwmr_ram);" + CR2;
-	    netlist = netlist + "vgsb.p_to_target["+(TopCellGenerator.avatardd.getNb_target()+4)+"](signal_vci_mwmr_ram);" + CR2;
-
-	    //MWMRd RAM added transparently
-	    netlist = netlist +"mwmrd_ram.p_clk(" + NAME_CLK + ");" + CR;
-	    netlist = netlist +"mwmrd_ram.p_resetn(" + NAME_RST + ");" + CR;
-	    netlist = netlist +"mwmrd_ram.p_vci(signal_vci_mwmrd_ram);" + CR2;
-	    netlist = netlist + "vgsb.p_to_target["+(TopCellGenerator.avatardd.getNb_target()+5)+"](signal_vci_mwmrd_ram);" + CR2;*/
+	    }		  
 	}
 
 	/* clustered version */
@@ -351,7 +339,7 @@ public class NetList {
 	}
 		
 	//generate trace file if marked trace option 
-	netlist += "sc_trace_file *tf;" + CR;
+	/*	netlist += "sc_trace_file *tf;" + CR;
 	netlist += "tf=sc_create_vcd_trace_file(\"mytrace\");" + CR;
 	netlist += "sc_trace(tf,signal_clk,\"CLK\");" + CR;
 	netlist += "sc_trace(tf,signal_resetn,\"RESETN\");" + CR;
@@ -391,16 +379,16 @@ public class NetList {
 	    if (ram.getMonitored()==0){			
 		netlist += "sc_trace(tf,signal_vci_vciram"+ram.getNo_ram()+",\"Memory"+ram.getNo_ram()+"\");" + CR;
 	    }
-	}	   
+	    }*/	   
     	
     netlist = netlist + "  sc_core::sc_start(sc_core::sc_time(0, sc_core::SC_NS));" + CR;
     netlist = netlist + "  signal_resetn = false;" + CR;
     netlist = netlist + "  sc_core::sc_start(sc_core::sc_time(1, sc_core::SC_NS));" + CR;
     netlist = netlist + "  signal_resetn = true;" + CR;
     netlist = netlist + "  sc_core::sc_start();" + CR;
-    if(tracing){
-	netlist += "sc_close_vcd_trace_file(tf);" + CR;
-    }
+    //if(tracing){
+    //	netlist += "sc_close_vcd_trace_file(tf);" + CR;
+    //	}
     netlist = netlist + CR + "  return EXIT_SUCCESS;"+ CR;
     netlist = netlist +"}" + CR;
     return netlist;		
-- 
GitLab