Ignore:
Timestamp:
May 16, 2014, 7:01:38 PM (10 years ago)
Author:
cfuguet
Message:

tsar_generic_leti:

  • Replacing tsar_leti_cluster dspin_local_crossbar by vci_local_crossbar
  • Introducing in top.cpp the possibility to pass soft binary, disk image or ramdisk image files through command line args
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/platforms/tsar_generic_leti/tsar_leti_cluster/caba/source/src/tsar_leti_cluster.cpp

    r664 r692  
    5252         uint32_t                           trace_memc_id )
    5353            : soclib::caba::BaseModule(insname),
     54            m_nprocs(nb_procs),
    5455            p_clk("clk"),
    5556            p_resetn("resetn")
     
    114115                      trace_start_cycle,
    115116                      trace_ok );
    116 
    117         std::ostringstream swip;
    118         swip << "wi_proc_" << x_id << "_" << y_id << "_" << p;
    119         wi_proc[p] = new VciDspinInitiatorWrapper<vci_param_int,
    120                                                   dspin_cmd_width,
    121                                                   dspin_rsp_width>(
    122                      swip.str().c_str(),
    123                      x_width + y_width + l_width);
    124117    }
    125118
     
    148141                     trace_ok );
    149142
    150     wt_memc = new VciDspinTargetWrapper<vci_param_int,
    151                                         dspin_cmd_width,
    152                                         dspin_rsp_width>(
    153                      "wt_memc",
    154                      x_width + y_width + l_width);
    155 
    156143    /////////////////////////////////////////////////////////////////////////////
    157144    std::ostringstream sxram;
     
    176163                     16 );                              // number of output IRQs
    177164
    178     wt_xicu = new VciDspinTargetWrapper<vci_param_int,
     165    /////////////////////////////////////////////////////////////////////////////
     166    size_t nb_initiators = nb_procs;
     167    size_t nb_targets    = 2;
     168
     169    if ((x_id == 0) and (y_id == 0))  // cluster(0,0)
     170    {
     171        nb_initiators = nb_procs + 1;
     172        nb_targets    = 4;
     173    }
     174
     175    std::ostringstream s_xbar_cmd;
     176    xbar_cmd = new VciLocalCrossbar<vci_param_int>(
     177                     s_xbar_cmd.str().c_str(),
     178                     mtd,                          // mapping table
     179                     cluster_xy,                   // cluster id
     180                     nb_initiators,                // number of local initiators
     181                     nb_targets,                   // number of local targets
     182                     0 );                          // default target
     183
     184    wi_gate = new VciDspinInitiatorWrapper<vci_param_int,
     185                                           dspin_cmd_width,
     186                                           dspin_rsp_width>(
     187                     "wi_gate",
     188                     x_width + y_width + l_width);
     189
     190    wt_gate = new VciDspinTargetWrapper<vci_param_int,
    179191                                        dspin_cmd_width,
    180192                                        dspin_rsp_width>(
    181                      "wt_xicu",
     193                     "wt_gate",
    182194                     x_width + y_width + l_width);
    183 
    184     /////////////////////////////////////////////////////////////////////////////
    185     size_t nb_initiators = nb_procs;
    186     size_t nb_targets    = 2;
    187 
    188     if ((x_id == 0) and (y_id == 0))  // cluster(0,0)
    189     {
    190         nb_initiators = nb_procs + 1;
    191         nb_targets    = 4;
    192     }
    193 
    194     std::ostringstream s_xbar_cmd;
    195     s_xbar_cmd << "xbar_cmd_" << x_id << "_" << y_id;
    196     xbar_cmd = new DspinLocalCrossbar<dspin_cmd_width>(
    197                      s_xbar_cmd.str().c_str(),
    198                      mtd,                          // mapping table
    199                      x_id, y_id,                   // cluster coordinates
    200                      x_width, y_width, l_width,
    201                      nb_initiators,                // number of local of sources
    202                      nb_targets,                   // number of local dests
    203                      2, 2,                         // fifo depths 
    204                      true,                         // CMD
    205                      true,                         // use local routing table
    206                      false );                      // no broadcast
    207 
    208     /////////////////////////////////////////////////////////////////////////////
    209     std::ostringstream s_xbar_rsp;
    210     s_xbar_rsp << "xbar_rsp_" << x_id << "_" << y_id;
    211     xbar_rsp = new DspinLocalCrossbar<dspin_rsp_width>(
    212                      s_xbar_rsp.str().c_str(),
    213                      mtd,                          // mapping table
    214                      x_id, y_id,                   // cluster coordinates
    215                      x_width, y_width, l_width,
    216                      nb_targets,                   // number of local sources
    217                      nb_initiators,                // number of local dests
    218                      2, 2,                         // fifo depths 
    219                      false,                        // RSP
    220                      false,                        // don't use local routing table
    221                      false );                      // no broadcast
    222195
    223196    /////////////////////////////////////////////////////////////////////////////
     
    313286
    314287    // backup BDV and TTY peripherals in cluster(0,0)
     288    bdev = NULL;
     289    mtty = NULL;
    315290    if ((x_id == 0) and (y_id == 0))
    316291    {
     
    325300                     64 );            // burst size
    326301
    327         wt_bdev = new VciDspinTargetWrapper<vci_param_int,
    328                                             dspin_cmd_width,
    329                                             dspin_rsp_width>(
    330                      "wt_bdev",
    331                      x_width + y_width + l_width);
    332 
    333         wi_bdev = new VciDspinInitiatorWrapper<vci_param_int,
    334                                                dspin_cmd_width,
    335                                                dspin_rsp_width>(
    336                      "wi_bdev",
    337                      x_width + y_width + l_width);
    338 
    339302        /////////////////////////////////////////////
    340303        mtty = new VciMultiTty<vci_param_int>(
     
    342305                     IntTab(cluster_xy, tgtid_mtty),
    343306                     mtd,
    344                      "backup", NULL );
    345 
    346         wt_mtty = new VciDspinTargetWrapper<vci_param_int,
    347                                             dspin_cmd_width,
    348                                             dspin_rsp_width>(
    349                      "wt_mtty",
    350                      x_width + y_width + l_width);
     307                     "tty_backup", NULL );
    351308    }
    352309
     
    408365    xbar_cmd->p_clk                            (this->p_clk);
    409366    xbar_cmd->p_resetn                         (this->p_resetn);
    410     xbar_cmd->p_global_out                     (signal_dspin_cmd_l2g_d);
    411     xbar_cmd->p_global_in                      (signal_dspin_cmd_g2l_d);
    412 
    413     xbar_cmd->p_local_out[tgtid_memc]          (signal_dspin_cmd_memc_t);
    414     xbar_cmd->p_local_out[tgtid_xicu]          (signal_dspin_cmd_xicu_t);
     367    xbar_cmd->p_initiator_to_up                (signal_vci_l2g);
     368    xbar_cmd->p_target_to_up                   (signal_vci_g2l);
     369
     370    xbar_cmd->p_to_target[tgtid_memc]          (signal_vci_tgt_memc);
     371    xbar_cmd->p_to_target[tgtid_xicu]          (signal_vci_tgt_xicu);
    415372
    416373    for (size_t p = 0; p < nb_procs; p++)
    417         xbar_cmd->p_local_in[p]                (signal_dspin_cmd_proc_i[p]);
     374        xbar_cmd->p_to_initiator[p]            (signal_vci_ini_proc[p]);
    418375
    419376    if ((x_id == 0) and (y_id == 0))  // cluster(0,0)
    420377    {
    421         xbar_cmd->p_local_out[tgtid_mtty]      (signal_dspin_cmd_mtty_t);
    422         xbar_cmd->p_local_out[tgtid_bdev]      (signal_dspin_cmd_bdev_t);
    423 
    424         xbar_cmd->p_local_in[nb_procs]         (signal_dspin_cmd_bdev_i);
    425     }
    426 
    427     std::cout << "  - CMD Direct crossbar connected" << std::endl;
    428 
    429     //////////////////////// RSP DSPIN  local crossbar direct
    430     xbar_rsp->p_clk                            (this->p_clk);
    431     xbar_rsp->p_resetn                         (this->p_resetn);
    432     xbar_rsp->p_global_out                     (signal_dspin_rsp_l2g_d);
    433     xbar_rsp->p_global_in                      (signal_dspin_rsp_g2l_d);
    434 
    435     xbar_rsp->p_local_in[tgtid_memc]           (signal_dspin_rsp_memc_t);
    436     xbar_rsp->p_local_in[tgtid_xicu]           (signal_dspin_rsp_xicu_t);
    437 
    438     for (size_t p = 0; p < nb_procs; p++)
    439         xbar_rsp->p_local_out[p]               (signal_dspin_rsp_proc_i[p]);
    440 
    441     if ((x_id == 0) and (y_id == 0))  // cluster(0,0)
    442     {
    443         xbar_rsp->p_local_in[tgtid_mtty]       (signal_dspin_rsp_mtty_t);
    444         xbar_rsp->p_local_in[tgtid_bdev]       (signal_dspin_rsp_bdev_t);
    445 
    446         xbar_rsp->p_local_out[nb_procs]        (signal_dspin_rsp_bdev_i);
    447     }
    448 
    449     std::cout << "  - RSP Direct crossbar connected" << std::endl;
     378        xbar_cmd->p_to_target[tgtid_mtty]      (signal_vci_tgt_mtty);
     379        xbar_cmd->p_to_target[tgtid_bdev]      (signal_vci_tgt_bdev);
     380        xbar_cmd->p_to_initiator[nb_procs]     (signal_vci_ini_bdev);
     381    }
     382
     383    wi_gate->p_clk                             (this->p_clk);
     384    wi_gate->p_resetn                          (this->p_resetn);
     385    wi_gate->p_vci                             (signal_vci_l2g);
     386    wi_gate->p_dspin_cmd                       (signal_dspin_cmd_l2g_d);
     387    wi_gate->p_dspin_rsp                       (signal_dspin_rsp_g2l_d);
     388
     389    wt_gate->p_clk                             (this->p_clk);
     390    wt_gate->p_resetn                          (this->p_resetn);
     391    wt_gate->p_vci                             (signal_vci_g2l);
     392    wt_gate->p_dspin_cmd                       (signal_dspin_cmd_g2l_d);
     393    wt_gate->p_dspin_rsp                       (signal_dspin_rsp_l2g_d);
     394
     395    std::cout << "  - CMD & RSP Direct crossbar connected" << std::endl;
    450396
    451397    ////////////////////// M2P DSPIN local crossbar coherence
     
    497443            else         proc[p]->p_irq[j]  (signal_false);
    498444        }
    499 
    500         wi_proc[p]->p_clk                   (this->p_clk);
    501         wi_proc[p]->p_resetn                (this->p_resetn);
    502         wi_proc[p]->p_dspin_cmd             (signal_dspin_cmd_proc_i[p]);
    503         wi_proc[p]->p_dspin_rsp             (signal_dspin_rsp_proc_i[p]);
    504         wi_proc[p]->p_vci                   (signal_vci_ini_proc[p]);
    505445    }
    506446
     
    533473    }
    534474
    535     // wrapper XICU
    536     wt_xicu->p_clk                     (this->p_clk);
    537     wt_xicu->p_resetn                  (this->p_resetn);
    538     wt_xicu->p_dspin_cmd               (signal_dspin_cmd_xicu_t);
    539     wt_xicu->p_dspin_rsp               (signal_dspin_rsp_xicu_t);
    540     wt_xicu->p_vci                     (signal_vci_tgt_xicu);
    541 
    542475    std::cout << "  - XICU connected" << std::endl;
    543476
     
    552485    memc->p_dspin_clack                (signal_dspin_clack_memc);
    553486
    554     // wrapper MEMC
    555     wt_memc->p_clk                     (this->p_clk);
    556     wt_memc->p_resetn                  (this->p_resetn);
    557     wt_memc->p_dspin_cmd               (signal_dspin_cmd_memc_t);
    558     wt_memc->p_dspin_rsp               (signal_dspin_rsp_memc_t);
    559     wt_memc->p_vci                     (signal_vci_tgt_memc);
    560 
    561487    std::cout << "  - MEMC connected" << std::endl;
    562488
     
    579505        bdev->p_vci_initiator          (signal_vci_ini_bdev);
    580506
    581         // wrapper tgt BDEV
    582         wt_bdev->p_clk                 (this->p_clk);
    583         wt_bdev->p_resetn              (this->p_resetn);
    584         wt_bdev->p_dspin_cmd           (signal_dspin_cmd_bdev_t);
    585         wt_bdev->p_dspin_rsp           (signal_dspin_rsp_bdev_t);
    586         wt_bdev->p_vci                 (signal_vci_tgt_bdev);
    587 
    588         // wrapper ini BDEV
    589         wi_bdev->p_clk                 (this->p_clk);
    590         wi_bdev->p_resetn              (this->p_resetn);
    591         wi_bdev->p_dspin_cmd           (signal_dspin_cmd_bdev_i);
    592         wi_bdev->p_dspin_rsp           (signal_dspin_rsp_bdev_i);
    593         wi_bdev->p_vci                 (signal_vci_ini_bdev);
    594 
    595507        std::cout << "  - BDEV connected" << std::endl;
    596508
     
    600512        mtty->p_vci                    (signal_vci_tgt_mtty);
    601513        mtty->p_irq[0]                 (signal_irq_mtty);
    602 
    603         // wrapper tgt MTTY
    604         wt_mtty->p_clk                 (this->p_clk);
    605         wt_mtty->p_resetn              (this->p_resetn);
    606         wt_mtty->p_dspin_cmd           (signal_dspin_cmd_mtty_t);
    607         wt_mtty->p_dspin_rsp           (signal_dspin_rsp_mtty_t);
    608         wt_mtty->p_vci                 (signal_vci_tgt_mtty);
    609514
    610515        std::cout << "  - MTTY connected" << std::endl;
     
    637542    dealloc_elems<DspinOutput<dspin_cmd_width> >(p_cla_out, 4);
    638543
    639     for (size_t p = 0; p < 4 ; p++)
    640     {
    641         if ( proc[p] )     delete proc[p];
    642         if ( wi_proc[p] )  delete wi_proc[p];
     544    for (size_t p = 0; p < m_nprocs ; p++)
     545    {
     546        if ( proc[p] ) delete proc[p];
    643547    }
    644548
    645549    delete memc;
    646     delete wt_memc;
    647550    delete xram;
    648551    delete xicu;
    649     delete wt_xicu;
    650552    delete xbar_cmd;
    651     delete xbar_rsp;
    652553    delete xbar_m2p;
    653554    delete xbar_p2m;
     
    658559    delete router_p2m;
    659560    delete router_cla;
     561    delete wi_gate;
     562    delete wt_gate;
    660563
    661564    if ( bdev )
    662565    {
    663566        delete bdev;
    664         delete wt_bdev;
    665         delete wi_bdev;
    666567    }
    667568
     
    669570    {
    670571        delete mtty;
    671         delete wt_mtty;
    672572    }
    673573}
Note: See TracChangeset for help on using the changeset viewer.