Ignore:
Timestamp:
Feb 2, 2008, 12:39:01 PM (16 years ago)
Author:
rosiere
Message:

Add new component : Read_unit (no tested)
Change functionnal_unit : now use type and operation to execute the good function
Change New_Component's script

Location:
trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit
Files:
42 added
29 edited

Legend:

Unmodified
Added
Removed
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/SelfTest/config0.cfg

    r66 r76  
    13134       4       *2      # nb_gpr_write
    14142       2       *2      # nb_spr_write
     154       4       *2      # size_store_queue
     164       4       *2      # size_load_queue   
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/SelfTest/config1.cfg

    r68 r76  
    13132       4       *2      # nb_gpr_write
    14142       4       *2      # nb_spr_write
     154       4       *2      # size_store_queue
     164       4       *2      # size_load_queue   
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/SelfTest/config2.cfg

    r68 r76  
    13131       1       *2      # nb_gpr_write
    14141       1       *2      # nb_spr_write
     154       4       *2      # size_store_queue
     164       4       *2      # size_load_queue   
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/SelfTest/config_min.cfg

    r68 r76  
    13131       1       *2      # nb_gpr_write
    14141       1       *2      # nb_spr_write
     154       4       *2      # size_store_queue
     164       4       *2      # size_load_queue   
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/SelfTest/src/main.cpp

    r66 r76  
    88#include "Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/SelfTest/include/test.h"
    99
    10 #define NB_PARAMS 13
     10#define NB_PARAMS 15
    1111
    1212void usage (int argc, char * argv[])
     
    2727       << " - nb_gpr_write        (unsigned int)" << endl
    2828       << " - nb_spr_write        (unsigned int)" << endl
     29       << " - size_store_queue    (unsigned int)" << endl
     30       << " - size_load_queue     (unsigned int)" << endl
    2931       << "" << endl;
    3032
     
    6062  const uint32_t nb_gpr_write        = atoi(argv[x++]);
    6163  const uint32_t nb_spr_write        = atoi(argv[x++]);
     64  const uint32_t size_store_queue    = atoi(argv[x++]);
     65  const uint32_t size_load_queue     = atoi(argv[x++]);
    6266
    6367  try
     
    7781         ,nb_gpr_write
    7882         ,nb_spr_write
     83         ,size_store_queue
     84         ,size_load_queue
    7985          );
    8086     
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/SelfTest/src/test.cpp

    r68 r76  
    7575  sc_signal<Toperation_t       >         * READ_QUEUE_IN_OPERATION    = new sc_signal<Toperation_t       >         ("READ_QUEUE_IN_OPERATION   ");
    7676  sc_signal<Ttype_t            >         * READ_QUEUE_IN_TYPE         = new sc_signal<Ttype_t            >         ("READ_QUEUE_IN_TYPE        ");
     77  sc_signal<Tlsq_ptr_t         >         * READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE = new sc_signal<Tlsq_ptr_t>         ("READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE");
     78  sc_signal<Tlsq_ptr_t         >         * READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE  = new sc_signal<Tlsq_ptr_t>         ("READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE ");
    7779  sc_signal<Tcontrol_t         >         * READ_QUEUE_IN_HAS_IMMEDIAT = new sc_signal<Tcontrol_t         >         ("READ_QUEUE_IN_HAS_IMMEDIAT");
    7880  sc_signal<Tgeneral_data_t    >         * READ_QUEUE_IN_IMMEDIAT     = new sc_signal<Tgeneral_data_t    >         ("READ_QUEUE_IN_IMMEDIAT    ");
     
    98100  sc_signal<Toperation_t       >         * READ_QUEUE_OUT_OPERATION   = new sc_signal<Toperation_t       >         ("READ_QUEUE_OUT_OPERATION   ");
    99101  sc_signal<Ttype_t            >         * READ_QUEUE_OUT_TYPE        = new sc_signal<Ttype_t            >         ("READ_QUEUE_OUT_TYPE        ");
     102  sc_signal<Tlsq_ptr_t         >         * READ_QUEUE_OUT_STORE_QUEUE_PTR_WRITE = new sc_signal<Tlsq_ptr_t>        ("READ_QUEUE_OUT_STORE_QUEUE_PTR_WRITE");
     103  sc_signal<Tlsq_ptr_t         >         * READ_QUEUE_OUT_LOAD_QUEUE_PTR_WRITE  = new sc_signal<Tlsq_ptr_t>        ("READ_QUEUE_OUT_LOAD_QUEUE_PTR_WRITE ");
    100104  sc_signal<Tcontrol_t         >         * READ_QUEUE_OUT_HAS_IMMEDIAT= new sc_signal<Tcontrol_t         >         ("READ_QUEUE_OUT_HAS_IMMEDIAT");
    101105  sc_signal<Tgeneral_data_t    >         * READ_QUEUE_OUT_IMMEDIAT    = new sc_signal<Tgeneral_data_t    >         ("READ_QUEUE_OUT_IMMEDIAT    ");
     
    226230  (*(_Read_queue-> in_READ_QUEUE_IN_OPERATION      )) (*(READ_QUEUE_IN_OPERATION      ));
    227231  (*(_Read_queue-> in_READ_QUEUE_IN_TYPE           )) (*(READ_QUEUE_IN_TYPE           ));
     232  (*(_Read_queue-> in_READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE)) (*(READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE));
     233  (*(_Read_queue-> in_READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE )) (*(READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE ));
    228234  (*(_Read_queue-> in_READ_QUEUE_IN_HAS_IMMEDIAT   )) (*(READ_QUEUE_IN_HAS_IMMEDIAT   ));
    229235  (*(_Read_queue-> in_READ_QUEUE_IN_IMMEDIAT       )) (*(READ_QUEUE_IN_IMMEDIAT       ));
     
    251257  (*(_Read_queue->out_READ_QUEUE_OUT_OPERATION     )) (*(READ_QUEUE_OUT_OPERATION     ));
    252258  (*(_Read_queue->out_READ_QUEUE_OUT_TYPE          )) (*(READ_QUEUE_OUT_TYPE          ));
     259  (*(_Read_queue->out_READ_QUEUE_OUT_STORE_QUEUE_PTR_WRITE)) (*(READ_QUEUE_OUT_STORE_QUEUE_PTR_WRITE));
     260  (*(_Read_queue->out_READ_QUEUE_OUT_LOAD_QUEUE_PTR_WRITE )) (*(READ_QUEUE_OUT_LOAD_QUEUE_PTR_WRITE ));
    253261  (*(_Read_queue->out_READ_QUEUE_OUT_HAS_IMMEDIAT  )) (*(READ_QUEUE_OUT_HAS_IMMEDIAT  ));
    254262  (*(_Read_queue->out_READ_QUEUE_OUT_IMMEDIAT      )) (*(READ_QUEUE_OUT_IMMEDIAT      ));
    255   (*(_Read_queue->out_READ_QUEUE_OUT_READ_RA       )) (*(READ_QUEUE_OUT_READ_RA       ));
     263//   (*(_Read_queue->out_READ_QUEUE_OUT_READ_RA       )) (*(READ_QUEUE_OUT_READ_RA       ));
    256264  (*(_Read_queue->out_READ_QUEUE_OUT_NUM_REG_RA    )) (*(READ_QUEUE_OUT_NUM_REG_RA    ));
    257265  (*(_Read_queue->out_READ_QUEUE_OUT_DATA_RA_VAL   )) (*(READ_QUEUE_OUT_DATA_RA_VAL   ));
    258266  (*(_Read_queue->out_READ_QUEUE_OUT_DATA_RA       )) (*(READ_QUEUE_OUT_DATA_RA       ));
    259   (*(_Read_queue->out_READ_QUEUE_OUT_READ_RB       )) (*(READ_QUEUE_OUT_READ_RB       ));
     267//   (*(_Read_queue->out_READ_QUEUE_OUT_READ_RB       )) (*(READ_QUEUE_OUT_READ_RB       ));
    260268  (*(_Read_queue->out_READ_QUEUE_OUT_NUM_REG_RB    )) (*(READ_QUEUE_OUT_NUM_REG_RB    ));
    261269  (*(_Read_queue->out_READ_QUEUE_OUT_DATA_RB_VAL   )) (*(READ_QUEUE_OUT_DATA_RB_VAL   ));
    262270  (*(_Read_queue->out_READ_QUEUE_OUT_DATA_RB       )) (*(READ_QUEUE_OUT_DATA_RB       ));
    263   (*(_Read_queue->out_READ_QUEUE_OUT_READ_RC       )) (*(READ_QUEUE_OUT_READ_RC       ));
     271//   (*(_Read_queue->out_READ_QUEUE_OUT_READ_RC       )) (*(READ_QUEUE_OUT_READ_RC       ));
    264272  (*(_Read_queue->out_READ_QUEUE_OUT_NUM_REG_RC    )) (*(READ_QUEUE_OUT_NUM_REG_RC    ));
    265273  (*(_Read_queue->out_READ_QUEUE_OUT_DATA_RC_VAL   )) (*(READ_QUEUE_OUT_DATA_RC_VAL   ));
     
    408416              READ_QUEUE_IN_OPERATION   ->write(0);
    409417              READ_QUEUE_IN_TYPE        ->write(0);
     418              READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE->write(0);
     419              READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE ->write(0);
    410420              READ_QUEUE_IN_HAS_IMMEDIAT->write(0);
    411421              READ_QUEUE_IN_IMMEDIAT    ->write(0);
     
    535545                TEST(Tcontext_t        ,READ_QUEUE_OUT_FRONT_END_ID  ->read(),(3*ctxt)%_param->_nb_front_end);
    536546
    537               TEST(Tcontrol_t        ,READ_QUEUE_OUT_READ_RA    ->read(),_read_ra      [rob_id]);
     547//            TEST(Tcontrol_t        ,READ_QUEUE_OUT_READ_RA    ->read(),_read_ra      [rob_id]);
    538548              TEST(Tgeneral_address_t,READ_QUEUE_OUT_NUM_REG_RA ->read(),_num_reg_ra   [rob_id]);
    539               TEST(Tcontrol_t        ,READ_QUEUE_OUT_DATA_RA_VAL->read(),not READ_QUEUE_OUT_READ_RA->read() or _gpr_val [_num_reg_ra[rob_id]][ctxt]);
    540               if (READ_QUEUE_OUT_READ_RA    ->read() and
     549              TEST(Tcontrol_t        ,READ_QUEUE_OUT_DATA_RA_VAL->read(),not _read_ra [rob_id] or _gpr_val [_num_reg_ra[rob_id]][ctxt]);
     550              if (_read_ra [rob_id] and
    541551                  READ_QUEUE_OUT_DATA_RA_VAL->read())
    542552              TEST(Tgeneral_data_t   ,READ_QUEUE_OUT_DATA_RA    ->read(),_gpr          [_num_reg_ra[rob_id]][ctxt]);
    543               TEST(Tcontrol_t        ,READ_QUEUE_OUT_READ_RB    ->read(),_read_rb      [rob_id]);
     553//            TEST(Tcontrol_t        ,READ_QUEUE_OUT_READ_RB    ->read(),_read_rb      [rob_id]);
    544554              TEST(Tgeneral_address_t,READ_QUEUE_OUT_NUM_REG_RB ->read(),_num_reg_rb   [rob_id]);
    545               TEST(Tcontrol_t        ,READ_QUEUE_OUT_DATA_RB_VAL->read(),not READ_QUEUE_OUT_READ_RB->read() or _gpr_val [_num_reg_rb[rob_id]][ctxt]);
    546               if (READ_QUEUE_OUT_READ_RB    ->read() and
     555              TEST(Tcontrol_t        ,READ_QUEUE_OUT_DATA_RB_VAL->read(),not _read_rb [rob_id] or _gpr_val [_num_reg_rb[rob_id]][ctxt]);
     556              if (_read_rb [rob_id] and
    547557                  READ_QUEUE_OUT_DATA_RB_VAL->read())
    548558              TEST(Tgeneral_data_t   ,READ_QUEUE_OUT_DATA_RB    ->read(),_gpr          [_num_reg_rb[rob_id]][ctxt]);
    549               TEST(Tcontrol_t        ,READ_QUEUE_OUT_READ_RC    ->read(),_read_rc      [rob_id]);
     559//            TEST(Tcontrol_t        ,READ_QUEUE_OUT_READ_RC    ->read(),_read_rc      [rob_id]);
    550560              TEST(Tspecial_address_t,READ_QUEUE_OUT_NUM_REG_RC ->read(),_num_reg_rc   [rob_id]);
    551               TEST(Tcontrol_t        ,READ_QUEUE_OUT_DATA_RC_VAL->read(),not READ_QUEUE_OUT_READ_RC->read() or _spr_val [_num_reg_rc[rob_id]][ctxt]);
    552               if (READ_QUEUE_OUT_READ_RC    ->read() and
     561              TEST(Tcontrol_t        ,READ_QUEUE_OUT_DATA_RC_VAL->read(),not _read_rc [rob_id] or _spr_val [_num_reg_rc[rob_id]][ctxt]);
     562              if (_read_rc [rob_id] and
    553563                  READ_QUEUE_OUT_DATA_RC_VAL->read())
    554564              TEST(Tspecial_data_t   ,READ_QUEUE_OUT_DATA_RC    ->read(),_spr     [_num_reg_rc[rob_id]][ctxt]);
     
    581591   delete    READ_QUEUE_IN_OPERATION    ;
    582592   delete    READ_QUEUE_IN_TYPE         ;
     593   delete    READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE;
     594   delete    READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE ;
    583595   delete    READ_QUEUE_IN_HAS_IMMEDIAT ;
    584596   delete    READ_QUEUE_IN_IMMEDIAT     ;
     
    606618   delete    READ_QUEUE_OUT_OPERATION   ;
    607619   delete    READ_QUEUE_OUT_TYPE        ;
     620   delete    READ_QUEUE_OUT_STORE_QUEUE_PTR_WRITE;
     621   delete    READ_QUEUE_OUT_LOAD_QUEUE_PTR_WRITE ;
    608622   delete    READ_QUEUE_OUT_HAS_IMMEDIAT;
    609623   delete    READ_QUEUE_OUT_IMMEDIAT    ;
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/include/Parameters.h

    r75 r76  
    4141  public : const uint32_t    _nb_gpr_write         ;
    4242  public : const uint32_t    _nb_spr_write         ;
     43  public : const uint32_t    _size_store_queue     ;
     44  public : const uint32_t    _size_load_queue      ;
    4345
    4446  public : const uint32_t    _nb_gpr_read          ;
     
    7375                        uint32_t nb_type            ,
    7476                        uint32_t nb_gpr_write       ,
    75                         uint32_t nb_spr_write       );
     77                        uint32_t nb_spr_write       ,
     78                        uint32_t size_store_queue   ,
     79                        uint32_t size_load_queue    );
     80
    7681  public : Parameters  (Parameters & param) ;
    7782  public : ~Parameters () ;
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/include/Read_queue.h

    r75 r76  
    55 * $Id$
    66 *
    7  * [ Description ]
     7 * [ Description ]
    88 *
    99 */
     
    4545  public    : Toperation_t       _operation    ;
    4646  public    : Ttype_t            _type         ;
     47  public    : Tlsq_ptr_t         _store_queue_ptr_write;
     48  public    : Tlsq_ptr_t         _load_queue_ptr_write;
    4749  public    : Tcontrol_t         _has_immediat ;
    4850  public    : Tgeneral_data_t    _immediat     ;
     
    6163                                morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_read_unit::read_unit::read_queue::Tread_queue_entry_t & x)
    6264    {
    63       output_stream << " * _context_id    : " << toString(x._context_id   ) << std::endl
    64                     << " * _front_end_id  : " << toString(x._front_end_id ) << std::endl
    65                     << " * _ooo_engine_id : " << toString(x._ooo_engine_id) << std::endl
    66                     << " * _rob_id        : " << toString(x._rob_id       ) << std::endl
    67                     << " * _operation     : " << toString(x._operation    ) << std::endl
    68                     << " * _type          : " << toString(x._type         ) << std::endl
    69                     << " * _has_immediat  : " << toString(x._has_immediat ) << std::endl
    70                     << " * _immediat      : " << toString(x._immediat     ) << std::endl
    71                     << " * _read_ra       : " << toString(x._read_ra      ) << std::endl
    72                     << " * _num_reg_ra    : " << toString(x._num_reg_ra   ) << std::endl
    73                     << " * _read_rb       : " << toString(x._read_rb      ) << std::endl
    74                     << " * _num_reg_rb    : " << toString(x._num_reg_rb   ) << std::endl
    75                     << " * _read_rc       : " << toString(x._read_rc      ) << std::endl
    76                     << " * _num_reg_rc    : " << toString(x._num_reg_rc   ) << std::endl
    77                     << " * _write_rd      : " << toString(x._write_rd     ) << std::endl
    78                     << " * _num_reg_rd    : " << toString(x._num_reg_rd   ) << std::endl
    79                     << " * _write_re      : " << toString(x._write_re     ) << std::endl
    80                     << " * _num_reg_re    : " << toString(x._num_reg_re   ) << std::endl;
     65      output_stream << " * _context_id            : " << toString(x._context_id   ) << std::endl
     66                    << " * _front_end_id          : " << toString(x._front_end_id ) << std::endl
     67                    << " * _ooo_engine_id         : " << toString(x._ooo_engine_id) << std::endl
     68                    << " * _rob_id                : " << toString(x._rob_id       ) << std::endl
     69                    << " * _operation             : " << toString(x._operation    ) << std::endl
     70                    << " * _type                  : " << toString(x._type         ) << std::endl
     71                    << " * _store_queue_ptr_write : " << toString(x._store_queue_ptr_write) << std::endl
     72                    << " * _load_queue_ptr_write  : " << toString(x._load_queue_ptr_write ) << std::endl
     73                    << " * _has_immediat          : " << toString(x._has_immediat ) << std::endl
     74                    << " * _immediat              : " << toString(x._immediat     ) << std::endl
     75                    << " * _read_ra               : " << toString(x._read_ra      ) << std::endl
     76                    << " * _num_reg_ra            : " << toString(x._num_reg_ra   ) << std::endl
     77                    << " * _read_rb               : " << toString(x._read_rb      ) << std::endl
     78                    << " * _num_reg_rb            : " << toString(x._num_reg_rb   ) << std::endl
     79                    << " * _read_rc               : " << toString(x._read_rc      ) << std::endl
     80                    << " * _num_reg_rc            : " << toString(x._num_reg_rc   ) << std::endl
     81                    << " * _write_rd              : " << toString(x._write_rd     ) << std::endl
     82                    << " * _num_reg_rd            : " << toString(x._num_reg_rd   ) << std::endl
     83                    << " * _write_re              : " << toString(x._write_re     ) << std::endl
     84                    << " * _num_reg_re            : " << toString(x._num_reg_re   ) << std::endl;
    8185
    8286      return output_stream;
     
    9397  public    : Toperation_t       _operation    ;
    9498  public    : Ttype_t            _type         ;
     99  public    : Tlsq_ptr_t         _store_queue_ptr_write;
     100  public    : Tlsq_ptr_t         _load_queue_ptr_write;
    95101  public    : Tcontrol_t         _has_immediat ;
    96102  public    : Tgeneral_data_t    _immediat     ;
     
    127133      _operation    = x._operation    ;
    128134      _type         = x._type         ;
     135      _store_queue_ptr_write = x._store_queue_ptr_write;
     136      _load_queue_ptr_write  = x._load_queue_ptr_write ;
    129137      _has_immediat = x._has_immediat ;
    130138      _immediat     = x._immediat     ;
     
    157165                                morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_read_unit::read_unit::read_queue::Tread_queue_head_entry_t & x)
    158166    {
    159       output_stream << " * _context_id    : " << x._context_id   << std::endl
    160                     << " * _front_end_id  : " << x._front_end_id << std::endl
    161                     << " * _ooo_engine_id : " << x._ooo_engine_id<< std::endl
    162                     << " * _rob_id        : " << x._rob_id       << std::endl
    163                     << " * _operation     : " << x._operation    << std::endl
    164                     << " * _type          : " << x._type         << std::endl
    165                     << " * _has_immediat  : " << x._has_immediat << std::endl
    166                     << " * _immediat      : " << x._immediat     << std::endl
    167                     << " * _read_ra       : " << x._read_ra      << std::endl
    168                     << " * _read_ra_val   : " << x._read_ra_val  << std::endl
    169                     << " * _num_reg_ra    : " << x._num_reg_ra   << std::endl
    170                     << " * _data_ra_val   : " << x._data_ra_val  << std::endl
    171                     << " * _data_ra       : " << x._data_ra      << std::endl
    172                     << " * _read_rb       : " << x._read_rb      << std::endl
    173                     << " * _read_rb_val   : " << x._read_rb_val  << std::endl
    174                     << " * _num_reg_rb    : " << x._num_reg_rb   << std::endl
    175                     << " * _data_rb_val   : " << x._data_rb_val  << std::endl
    176                     << " * _data_rb       : " << x._data_rb      << std::endl
    177                     << " * _read_rc       : " << x._read_rc      << std::endl
    178                     << " * _read_rc_val   : " << x._read_rc_val  << std::endl
    179                     << " * _num_reg_rc    : " << x._num_reg_rc   << std::endl
    180                     << " * _data_rc_val   : " << x._data_rc_val  << std::endl
    181                     << " * _data_rc       : " << x._data_rc      << std::endl
    182                     << " * _write_rd      : " << x._write_rd     << std::endl
    183                     << " * _num_reg_rd    : " << x._num_reg_rd   << std::endl
    184                     << " * _write_re      : " << x._write_re     << std::endl
    185                     << " * _num_reg_re    : " << x._num_reg_re   << std::endl;
     167      output_stream << " * _context_id            : " << x._context_id   << std::endl
     168                    << " * _front_end_id          : " << x._front_end_id << std::endl
     169                    << " * _ooo_engine_id         : " << x._ooo_engine_id<< std::endl
     170                    << " * _rob_id                : " << x._rob_id       << std::endl
     171                    << " * _operation             : " << x._operation    << std::endl
     172                    << " * _type                  : " << x._type         << std::endl
     173                    << " * _store_queue_ptr_write : " << toString(x._store_queue_ptr_write) << std::endl
     174                    << " * _load_queue_ptr_write  : " << toString(x._load_queue_ptr_write ) << std::endl
     175                    << " * _has_immediat          : " << x._has_immediat << std::endl
     176                    << " * _immediat              : " << x._immediat     << std::endl
     177                    << " * _read_ra               : " << x._read_ra      << std::endl
     178                    << " * _read_ra_val           : " << x._read_ra_val  << std::endl
     179                    << " * _num_reg_ra            : " << x._num_reg_ra   << std::endl
     180                    << " * _data_ra_val           : " << x._data_ra_val  << std::endl
     181                    << " * _data_ra               : " << x._data_ra      << std::endl
     182                    << " * _read_rb               : " << x._read_rb      << std::endl
     183                    << " * _read_rb_val           : " << x._read_rb_val  << std::endl
     184                    << " * _num_reg_rb            : " << x._num_reg_rb   << std::endl
     185                    << " * _data_rb_val           : " << x._data_rb_val  << std::endl
     186                    << " * _data_rb               : " << x._data_rb      << std::endl
     187                    << " * _read_rc               : " << x._read_rc      << std::endl
     188                    << " * _read_rc_val           : " << x._read_rc_val  << std::endl
     189                    << " * _num_reg_rc            : " << x._num_reg_rc   << std::endl
     190                    << " * _data_rc_val           : " << x._data_rc_val  << std::endl
     191                    << " * _data_rc               : " << x._data_rc      << std::endl
     192                    << " * _write_rd              : " << x._write_rd     << std::endl
     193                    << " * _num_reg_rd            : " << x._num_reg_rd   << std::endl
     194                    << " * _write_re              : " << x._write_re     << std::endl
     195                    << " * _num_reg_re            : " << x._num_reg_re   << std::endl;
    186196
    187197      return output_stream;
     
    194204#endif
    195205  {
    196     // -----[ fields ]----------------------------------------------------
     206    // -----[ fields ]----------------------------------------------------
    197207    // Parameters
    198208  protected : const std::string                _name;
     
    207217
    208218#ifdef SYSTEMC
    209     // ~~~~~[ Interface ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     219    // ~~~~~[ Interface ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    210220    // Interface
    211221  public    : SC_CLOCK                      *  in_CLOCK               ;
    212222  public    : SC_IN (Tcontrol_t        )    *  in_NRESET              ;
    213223
    214     // ~~~~~[ Interface "read_queue_in" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    215 
    216   public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_VAL          ;
    217   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_IN_ACK          ;
    218   public    : SC_IN (Tcontext_t        )    *  in_READ_QUEUE_IN_CONTEXT_ID   ;
    219   public    : SC_IN (Tcontext_t        )    *  in_READ_QUEUE_IN_FRONT_END_ID ;
    220   public    : SC_IN (Tcontext_t        )    *  in_READ_QUEUE_IN_OOO_ENGINE_ID;
    221   public    : SC_IN (Tpacket_t         )    *  in_READ_QUEUE_IN_ROB_ID       ;
    222   public    : SC_IN (Toperation_t      )    *  in_READ_QUEUE_IN_OPERATION    ;
    223   public    : SC_IN (Ttype_t           )    *  in_READ_QUEUE_IN_TYPE         ;
    224   public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_HAS_IMMEDIAT ;
    225   public    : SC_IN (Tgeneral_data_t   )    *  in_READ_QUEUE_IN_IMMEDIAT     ;
    226   public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_READ_RA      ;
    227   public    : SC_IN (Tgeneral_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RA   ;
    228   public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_READ_RB      ;
    229   public    : SC_IN (Tgeneral_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RB   ;
    230   public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_READ_RC      ;
    231   public    : SC_IN (Tspecial_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RC   ;
    232   public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_WRITE_RD     ;
    233   public    : SC_IN (Tgeneral_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RD   ;
    234   public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_WRITE_RE     ;
    235   public    : SC_IN (Tspecial_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RE   ;
    236 
    237     // ~~~~~[ Interface "read_queue_out" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    238 
    239   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_VAL         ;
    240   public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_OUT_ACK         ;
    241   public    : SC_OUT(Tcontext_t        )    * out_READ_QUEUE_OUT_CONTEXT_ID   ;
    242   public    : SC_OUT(Tcontext_t        )    * out_READ_QUEUE_OUT_FRONT_END_ID ;
    243   public    : SC_OUT(Tcontext_t        )    * out_READ_QUEUE_OUT_OOO_ENGINE_ID;
    244   public    : SC_OUT(Tpacket_t         )    * out_READ_QUEUE_OUT_ROB_ID       ;
    245   public    : SC_OUT(Toperation_t      )    * out_READ_QUEUE_OUT_OPERATION   ;
    246   public    : SC_OUT(Ttype_t           )    * out_READ_QUEUE_OUT_TYPE        ;
    247   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_HAS_IMMEDIAT;
    248   public    : SC_OUT(Tgeneral_data_t   )    * out_READ_QUEUE_OUT_IMMEDIAT    ;
    249   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_READ_RA     ;
    250   public    : SC_OUT(Tgeneral_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RA  ;
    251   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_DATA_RA_VAL ;
    252   public    : SC_OUT(Tgeneral_data_t   )    * out_READ_QUEUE_OUT_DATA_RA     ;
    253   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_READ_RB     ;
    254   public    : SC_OUT(Tgeneral_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RB  ;
    255   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_DATA_RB_VAL ;
    256   public    : SC_OUT(Tgeneral_data_t   )    * out_READ_QUEUE_OUT_DATA_RB     ;
    257   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_READ_RC     ;
    258   public    : SC_OUT(Tspecial_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RC  ;
    259   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_DATA_RC_VAL ;
    260   public    : SC_OUT(Tspecial_data_t   )    * out_READ_QUEUE_OUT_DATA_RC     ;
    261   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_WRITE_RD    ;
    262   public    : SC_OUT(Tgeneral_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RD  ;
    263   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_WRITE_RE    ;
    264   public    : SC_OUT(Tspecial_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RE  ;
    265 
    266     // ~~~~~[ Interface "gpr_read" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     224    // ~~~~~[ Interface "read_queue_in" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     225
     226  public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_VAL                  ;
     227  public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_IN_ACK                  ;
     228  public    : SC_IN (Tcontext_t        )    *  in_READ_QUEUE_IN_CONTEXT_ID           ;
     229  public    : SC_IN (Tcontext_t        )    *  in_READ_QUEUE_IN_FRONT_END_ID         ;
     230  public    : SC_IN (Tcontext_t        )    *  in_READ_QUEUE_IN_OOO_ENGINE_ID        ;
     231  public    : SC_IN (Tpacket_t         )    *  in_READ_QUEUE_IN_ROB_ID               ;
     232  public    : SC_IN (Toperation_t      )    *  in_READ_QUEUE_IN_OPERATION            ;
     233  public    : SC_IN (Ttype_t           )    *  in_READ_QUEUE_IN_TYPE                 ;
     234  public    : SC_IN (Tlsq_ptr_t        )    *  in_READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE;
     235  public    : SC_IN (Tlsq_ptr_t        )    *  in_READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE ;
     236  public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_HAS_IMMEDIAT         ;
     237  public    : SC_IN (Tgeneral_data_t   )    *  in_READ_QUEUE_IN_IMMEDIAT             ;
     238  public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_READ_RA              ;
     239  public    : SC_IN (Tgeneral_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RA           ;
     240  public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_READ_RB              ;
     241  public    : SC_IN (Tgeneral_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RB           ;
     242  public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_READ_RC              ;
     243  public    : SC_IN (Tspecial_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RC           ;
     244  public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_WRITE_RD             ;
     245  public    : SC_IN (Tgeneral_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RD           ;
     246  public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_IN_WRITE_RE             ;
     247  public    : SC_IN (Tspecial_address_t)    *  in_READ_QUEUE_IN_NUM_REG_RE           ;
     248
     249    // ~~~~~[ Interface "read_queue_out" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     250
     251  public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_VAL                  ;
     252  public    : SC_IN (Tcontrol_t        )    *  in_READ_QUEUE_OUT_ACK                  ;
     253  public    : SC_OUT(Tcontext_t        )    * out_READ_QUEUE_OUT_CONTEXT_ID           ;
     254  public    : SC_OUT(Tcontext_t        )    * out_READ_QUEUE_OUT_FRONT_END_ID         ;
     255  public    : SC_OUT(Tcontext_t        )    * out_READ_QUEUE_OUT_OOO_ENGINE_ID        ;
     256  public    : SC_OUT(Tpacket_t         )    * out_READ_QUEUE_OUT_ROB_ID               ;
     257  public    : SC_OUT(Toperation_t      )    * out_READ_QUEUE_OUT_OPERATION            ;
     258  public    : SC_OUT(Ttype_t           )    * out_READ_QUEUE_OUT_TYPE                 ;
     259  public    : SC_OUT(Tlsq_ptr_t        )    * out_READ_QUEUE_OUT_STORE_QUEUE_PTR_WRITE;
     260  public    : SC_OUT(Tlsq_ptr_t        )    * out_READ_QUEUE_OUT_LOAD_QUEUE_PTR_WRITE ;
     261  public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_HAS_IMMEDIAT         ;
     262  public    : SC_OUT(Tgeneral_data_t   )    * out_READ_QUEUE_OUT_IMMEDIAT             ;
     263//   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_READ_RA              ;
     264  public    : SC_OUT(Tgeneral_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RA           ;
     265  public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_DATA_RA_VAL          ;
     266  public    : SC_OUT(Tgeneral_data_t   )    * out_READ_QUEUE_OUT_DATA_RA              ;
     267//   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_READ_RB              ;
     268  public    : SC_OUT(Tgeneral_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RB           ;
     269  public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_DATA_RB_VAL          ;
     270  public    : SC_OUT(Tgeneral_data_t   )    * out_READ_QUEUE_OUT_DATA_RB              ;
     271//   public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_READ_RC              ;
     272  public    : SC_OUT(Tspecial_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RC           ;
     273  public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_DATA_RC_VAL          ;
     274  public    : SC_OUT(Tspecial_data_t   )    * out_READ_QUEUE_OUT_DATA_RC              ;
     275  public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_WRITE_RD             ;
     276  public    : SC_OUT(Tgeneral_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RD           ;
     277  public    : SC_OUT(Tcontrol_t        )    * out_READ_QUEUE_OUT_WRITE_RE             ;
     278  public    : SC_OUT(Tspecial_address_t)    * out_READ_QUEUE_OUT_NUM_REG_RE           ;
     279
     280    // ~~~~~[ Interface "gpr_read" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    267281
    268282  public    : SC_OUT(Tcontrol_t        )   ** out_GPR_READ_VAL          ;
     
    273287  public    : SC_IN (Tcontrol_t        )   **  in_GPR_READ_DATA_VAL     ;
    274288
    275     // ~~~~~[ Interface "spr_read" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     289    // ~~~~~[ Interface "spr_read" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    276290
    277291  public    : SC_OUT(Tcontrol_t        )   ** out_SPR_READ_VAL          ;
     
    282296  public    : SC_IN (Tcontrol_t        )   **  in_SPR_READ_DATA_VAL     ;
    283297
    284     // ~~~~~[ Interface "gpr_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     298    // ~~~~~[ Interface "gpr_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    285299
    286300  public    : SC_IN (Tcontrol_t        )   **  in_GPR_WRITE_VAL          ;
     
    289303  public    : SC_IN (Tgeneral_data_t   )   **  in_GPR_WRITE_DATA         ;
    290304
    291     // ~~~~~[ Interface "spr_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     305    // ~~~~~[ Interface "spr_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    292306
    293307  public    : SC_IN (Tcontrol_t        )   **  in_SPR_WRITE_VAL          ;
     
    296310  public    : SC_IN (Tspecial_data_t   )   **  in_SPR_WRITE_DATA         ;
    297311
    298     // ~~~~~[ Component ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
    299 
    300     // ~~~~~[ Register ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
     312    // ~~~~~[ Component ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
     313
     314    // ~~~~~[ Register ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
    301315  protected : Tread_queue_head_entry_t       * _queue_head;
    302316  protected : std::queue<Tread_queue_entry_t *>   * _queue;
    303317
    304     // ~~~~~[ Internal ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     318    // ~~~~~[ Internal ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    305319 
    306320  protected  :Tcontrol_t                       internal_READ_QUEUE_OUT_VAL         ;
     
    317331#endif
    318332
    319     // -----[ methods ]---------------------------------------------------
     333    // -----[ methods ]---------------------------------------------------
    320334
    321335#ifdef SYSTEMC
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/src/Parameters.cpp

    r68 r76  
    3030                          uint32_t nb_type            ,
    3131                          uint32_t nb_gpr_write       ,
    32                           uint32_t nb_spr_write       ):
     32                          uint32_t nb_spr_write       ,
     33                          uint32_t size_store_queue   ,
     34                          uint32_t size_load_queue    ):
    3335    _size_queue            (size_queue           ),
    3436    _nb_context            (nb_context           ),
     
    4446    _nb_gpr_write          (nb_gpr_write         ),
    4547    _nb_spr_write          (nb_spr_write         ),
     48    _size_store_queue      (size_store_queue     ),
     49    _size_load_queue       (size_load_queue      ),
    4650
    4751    _nb_gpr_read           (2                    ),
     
    6771                              + _size_operation        //_operation   
    6872                              + _size_type             //_type         
     73                              + log2(_size_store_queue)//_store_queue_ptr_write
     74                              + log2(_size_load_queue )//_load_queue_ptr_write
    6975                              + 1                      //_has_immediat
    7076                              + _size_general_data     //_immediat     
     
    102108    _nb_gpr_write          (param._nb_gpr_write          ),
    103109    _nb_spr_write          (param._nb_spr_write          ),
     110    _size_store_queue      (param._size_store_queue      ),
     111    _size_load_queue       (param._size_load_queue       ),
    104112
    105113    _nb_gpr_read           (param._nb_gpr_read           ),
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/src/Parameters_print.cpp

    r75 r76  
    3939    xml.singleton_begin("nb_gpr_write       "); xml.attribut("value",toString(_nb_gpr_write       )); xml.singleton_end();
    4040    xml.singleton_begin("nb_spr_write       "); xml.attribut("value",toString(_nb_spr_write       )); xml.singleton_end();
     41    xml.singleton_begin("size_store_queue   "); xml.attribut("value",toString(_size_store_queue   )); xml.singleton_end();
     42    xml.singleton_begin("size_load_queue    "); xml.attribut("value",toString(_size_load_queue    )); xml.singleton_end();
     43
    4144    xml.balise_close();
    4245
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/src/Read_queue_allocation.cpp

    r75 r76  
    7070       in_READ_QUEUE_IN_OPERATION      = interface->set_signal_in  <Toperation_t      > ("operation"   ,_param->_size_operation        );
    7171       in_READ_QUEUE_IN_TYPE           = interface->set_signal_in  <Ttype_t           > ("type"        ,_param->_size_type             );
     72       in_READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE = interface->set_signal_in  <Tlsq_ptr_t> ("store_queue_ptr_write", log2(_param->_size_store_queue));
     73       in_READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE  = interface->set_signal_in  <Tlsq_ptr_t> ("load_queue_ptr_write" , log2(_param->_size_load_queue ));
    7274       in_READ_QUEUE_IN_HAS_IMMEDIAT   = interface->set_signal_in  <Tcontrol_t        > ("has_immediat",1                             );
    7375       in_READ_QUEUE_IN_IMMEDIAT       = interface->set_signal_in  <Tgeneral_data_t   > ("immediat"    ,_param->_size_general_data     );
     
    107109      out_READ_QUEUE_OUT_OPERATION      = interface->set_signal_out <Toperation_t      > ("operation"   ,_param->_size_operation        );
    108110      out_READ_QUEUE_OUT_TYPE           = interface->set_signal_out <Ttype_t           > ("type"        ,_param->_size_type             );
     111      out_READ_QUEUE_OUT_STORE_QUEUE_PTR_WRITE = interface->set_signal_out <Tlsq_ptr_t> ("store_queue_ptr_write", log2(_param->_size_store_queue));
     112      out_READ_QUEUE_OUT_LOAD_QUEUE_PTR_WRITE  = interface->set_signal_out <Tlsq_ptr_t> ("load_queue_ptr_write" , log2(_param->_size_load_queue ));
    109113      out_READ_QUEUE_OUT_HAS_IMMEDIAT   = interface->set_signal_out <Tcontrol_t        > ("has_immediat",1                             );
    110114      out_READ_QUEUE_OUT_IMMEDIAT       = interface->set_signal_out <Tgeneral_data_t   > ("immediat"    ,_param->_size_general_data     );
    111       out_READ_QUEUE_OUT_READ_RA        = interface->set_signal_out <Tcontrol_t        > ("read_ra"     ,1                             );
     115//       out_READ_QUEUE_OUT_READ_RA        = interface->set_signal_out <Tcontrol_t        > ("read_ra"     ,1                             );
    112116      out_READ_QUEUE_OUT_NUM_REG_RA     = interface->set_signal_out <Tgeneral_address_t> ("num_reg_ra"  ,_param->_size_general_register );
    113117      out_READ_QUEUE_OUT_DATA_RA_VAL    = interface->set_signal_out <Tcontrol_t        > ("data_ra_val" ,1                             );
    114118      out_READ_QUEUE_OUT_DATA_RA        = interface->set_signal_out <Tgeneral_data_t   > ("data_ra"     ,_param->_size_general_data     );
    115       out_READ_QUEUE_OUT_READ_RB        = interface->set_signal_out <Tcontrol_t        > ("read_rb"     ,1                             );
     119//       out_READ_QUEUE_OUT_READ_RB        = interface->set_signal_out <Tcontrol_t        > ("read_rb"     ,1                             );
    116120      out_READ_QUEUE_OUT_NUM_REG_RB     = interface->set_signal_out <Tgeneral_address_t> ("num_reg_rb"  ,_param->_size_general_register );
    117121      out_READ_QUEUE_OUT_DATA_RB_VAL    = interface->set_signal_out <Tcontrol_t        > ("data_rb_val" ,1                             );
    118122      out_READ_QUEUE_OUT_DATA_RB        = interface->set_signal_out <Tgeneral_data_t   > ("data_rb"     ,_param->_size_general_data     );
    119       out_READ_QUEUE_OUT_READ_RC        = interface->set_signal_out <Tcontrol_t        > ("read_rc"     ,1                             );
     123//       out_READ_QUEUE_OUT_READ_RC        = interface->set_signal_out <Tcontrol_t        > ("read_rc"     ,1                             );
    120124      out_READ_QUEUE_OUT_NUM_REG_RC     = interface->set_signal_out <Tspecial_address_t> ("num_reg_rc"  ,_param->_size_special_register );
    121125      out_READ_QUEUE_OUT_DATA_RC_VAL    = interface->set_signal_out <Tcontrol_t        > ("data_rc_val" ,1                             );
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/src/Read_queue_deallocation.cpp

    r68 r76  
    4141    delete     in_READ_QUEUE_IN_OPERATION      ;
    4242    delete     in_READ_QUEUE_IN_TYPE           ;
     43    delete     in_READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE;
     44    delete     in_READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE ;
    4345    delete     in_READ_QUEUE_IN_HAS_IMMEDIAT   ;
    4446    delete     in_READ_QUEUE_IN_IMMEDIAT       ;
     
    6870    delete    out_READ_QUEUE_OUT_OPERATION      ;
    6971    delete    out_READ_QUEUE_OUT_TYPE           ;
     72    delete    out_READ_QUEUE_OUT_STORE_QUEUE_PTR_WRITE;
     73    delete    out_READ_QUEUE_OUT_LOAD_QUEUE_PTR_WRITE ;
    7074    delete    out_READ_QUEUE_OUT_HAS_IMMEDIAT   ;
    7175    delete    out_READ_QUEUE_OUT_IMMEDIAT       ;
    72     delete    out_READ_QUEUE_OUT_READ_RA        ;
     76//     delete    out_READ_QUEUE_OUT_READ_RA        ;
    7377    delete    out_READ_QUEUE_OUT_NUM_REG_RA     ;
    7478    delete    out_READ_QUEUE_OUT_DATA_RA_VAL    ;
    7579    delete    out_READ_QUEUE_OUT_DATA_RA        ;
    76     delete    out_READ_QUEUE_OUT_READ_RB        ;
     80//     delete    out_READ_QUEUE_OUT_READ_RB        ;
    7781    delete    out_READ_QUEUE_OUT_NUM_REG_RB     ;
    7882    delete    out_READ_QUEUE_OUT_DATA_RB_VAL    ;
    7983    delete    out_READ_QUEUE_OUT_DATA_RB        ;
    80     delete    out_READ_QUEUE_OUT_READ_RC        ;
     84//     delete    out_READ_QUEUE_OUT_READ_RC        ;
    8185    delete    out_READ_QUEUE_OUT_NUM_REG_RC     ;
    8286    delete    out_READ_QUEUE_OUT_DATA_RC_VAL    ;
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/src/Read_queue_genMoore.cpp

    r68 r76  
    4343    PORT_WRITE (out_READ_QUEUE_OUT_OPERATION   , _queue_head->_operation   );
    4444    PORT_WRITE (out_READ_QUEUE_OUT_TYPE        , _queue_head->_type        );
     45    PORT_WRITE (out_READ_QUEUE_OUT_STORE_QUEUE_PTR_WRITE, _queue_head->_store_queue_ptr_write);
     46    PORT_WRITE (out_READ_QUEUE_OUT_LOAD_QUEUE_PTR_WRITE , _queue_head->_load_queue_ptr_write );
    4547    PORT_WRITE (out_READ_QUEUE_OUT_HAS_IMMEDIAT, _queue_head->_has_immediat);
    4648    PORT_WRITE (out_READ_QUEUE_OUT_IMMEDIAT    , _queue_head->_immediat    );
    47     PORT_WRITE (out_READ_QUEUE_OUT_READ_RA     , _queue_head->_read_ra     );
     49//     PORT_WRITE (out_READ_QUEUE_OUT_READ_RA     , _queue_head->_read_ra     );
    4850    PORT_WRITE (out_READ_QUEUE_OUT_NUM_REG_RA  , _queue_head->_num_reg_ra  );
    4951//  PORT_WRITE (out_READ_QUEUE_OUT_DATA_RA_VAL , _queue_head->_data_ra_val ); // in genMealy_gpr
    5052//  PORT_WRITE (out_READ_QUEUE_OUT_DATA_RA     , _queue_head->_data_ra     ); // in genMealy_gpr
    51     PORT_WRITE (out_READ_QUEUE_OUT_READ_RB     , _queue_head->_read_rb     );
     53//     PORT_WRITE (out_READ_QUEUE_OUT_READ_RB     , _queue_head->_read_rb     );
    5254    PORT_WRITE (out_READ_QUEUE_OUT_NUM_REG_RB  , _queue_head->_num_reg_rb  );
    5355//  PORT_WRITE (out_READ_QUEUE_OUT_DATA_RB_VAL , _queue_head->_data_rb_val ); // in genMealy_gpr
    5456//  PORT_WRITE (out_READ_QUEUE_OUT_DATA_RB     , _queue_head->_data_rb     ); // in genMealy_gpr
    55     PORT_WRITE (out_READ_QUEUE_OUT_READ_RC     , _queue_head->_read_rc     );
     57//     PORT_WRITE (out_READ_QUEUE_OUT_READ_RC     , _queue_head->_read_rc     );
    5658    PORT_WRITE (out_READ_QUEUE_OUT_NUM_REG_RC  , _queue_head->_num_reg_rc  );
    5759//  PORT_WRITE (out_READ_QUEUE_OUT_DATA_RC_VAL , _queue_head->_data_rc_val ); // in genMealy_spr
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Read_queue/src/Read_queue_transition.cpp

    r75 r76  
    6666            entry->_operation    = PORT_READ(in_READ_QUEUE_IN_OPERATION   );
    6767            entry->_type         = PORT_READ(in_READ_QUEUE_IN_TYPE        );
     68            entry->_store_queue_ptr_write = PORT_READ(in_READ_QUEUE_IN_STORE_QUEUE_PTR_WRITE);
     69            entry->_load_queue_ptr_write  = PORT_READ(in_READ_QUEUE_IN_LOAD_QUEUE_PTR_WRITE );
    6870            entry->_has_immediat = PORT_READ(in_READ_QUEUE_IN_HAS_IMMEDIAT);
    6971            entry->_immediat     = PORT_READ(in_READ_QUEUE_IN_IMMEDIAT    );
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/SelfTest/configuration_multi_port_bypass_memory.cfg

    r75 r76  
    16160       0       *2      # nb_bypass_write
    17171       4       *2      # nb_bypass_memory
     184       4       *2      # size_store_queue
     194       4       *2      # size_load_queue
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/SelfTest/configuration_multi_port_bypass_write.cfg

    r75 r76  
    16161       4       *2      # nb_bypass_write
    17170       0       *2      # nb_bypass_memory
     184       4       *2      # size_store_queue
     194       4       *2      # size_load_queue
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/SelfTest/configuration_multi_port_retire2.cfg

    r75 r76  
    16160       0       *2      # nb_bypass_write
    17170       0       *2      # nb_bypass_memory
     184       4       *2      # size_store_queue
     194       4       *2      # size_load_queue
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/SelfTest/configuration_multi_port_retire4.cfg

    r75 r76  
    16160       0       *2      # nb_bypass_write
    17170       0       *2      # nb_bypass_memory
     184       4       *2      # size_store_queue
     194       4       *2      # size_load_queue
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/SelfTest/configuration_multi_port_write.cfg

    r75 r76  
    16160       0       *2      # nb_bypass_write
    17170       0       *2      # nb_bypass_memory
     184       4       *2      # size_store_queue
     194       4       *2      # size_load_queue
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/SelfTest/src/main.cpp

    r69 r76  
    88#include "Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/SelfTest/include/test.h"
    99
    10 #define NB_PARAMS 16
     10#define NB_PARAMS 18
    1111
    1212void usage (int argc, char * argv[])
     
    3030       << " - nb_bypass_write     (unsigned int)" << endl
    3131       << " - nb_bypass_memory    (unsigned int)" << endl
     32       << " - size_store_queue    (unsigned int)" << endl
     33       << " - size_load_queue     (unsigned int)" << endl
    3234       << "" << endl;
    3335
     
    6668  const uint32_t nb_bypass_write     = atoi(argv[x++]);
    6769  const uint32_t nb_bypass_memory    = atoi(argv[x++]);
     70  const uint32_t size_store_queue    = atoi(argv[x++]);
     71  const uint32_t size_load_queue     = atoi(argv[x++]);
    6872 
    6973  try
     
    8690         ,nb_bypass_write
    8791         ,nb_bypass_memory
     92         ,size_store_queue
     93         ,size_load_queue
    8894         );
    8995     
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/SelfTest/src/test.cpp

    r75 r76  
    7373  sc_signal<Toperation_t      > *  in_INSERT_OPERATION      = new sc_signal<Toperation_t      >;
    7474  sc_signal<Ttype_t           > *  in_INSERT_TYPE           = new sc_signal<Ttype_t           >;
     75  sc_signal<Tlsq_ptr_t        > *  in_INSERT_STORE_QUEUE_PTR_WRITE = new sc_signal<Tlsq_ptr_t>;
     76  sc_signal<Tlsq_ptr_t        > *  in_INSERT_LOAD_QUEUE_PTR_WRITE  = new sc_signal<Tlsq_ptr_t>;
    7577  sc_signal<Tcontrol_t        > *  in_INSERT_HAS_IMMEDIAT   = new sc_signal<Tcontrol_t        >;
    7678  sc_signal<Tgeneral_data_t   > *  in_INSERT_IMMEDIAT       = new sc_signal<Tgeneral_data_t   >;
     
    100102  sc_signal<Toperation_t      > ** out_RETIRE_OPERATION      = new sc_signal<Toperation_t      > * [_param->_nb_inst_retire];
    101103  sc_signal<Ttype_t           > ** out_RETIRE_TYPE           = new sc_signal<Ttype_t           > * [_param->_nb_inst_retire];
     104  sc_signal<Tlsq_ptr_t        > ** out_RETIRE_STORE_QUEUE_PTR_WRITE = new sc_signal<Tlsq_ptr_t> * [_param->_nb_inst_retire];
     105  sc_signal<Tlsq_ptr_t        > ** out_RETIRE_LOAD_QUEUE_PTR_WRITE  = new sc_signal<Tlsq_ptr_t> * [_param->_nb_inst_retire];
    102106  sc_signal<Tcontrol_t        > ** out_RETIRE_HAS_IMMEDIAT   = new sc_signal<Tcontrol_t        > * [_param->_nb_inst_retire];
    103107  sc_signal<Tgeneral_data_t   > ** out_RETIRE_IMMEDIAT       = new sc_signal<Tgeneral_data_t   > * [_param->_nb_inst_retire];
     
    120124      out_RETIRE_OPERATION       [i] = new sc_signal<Toperation_t      > (rename.c_str());
    121125      out_RETIRE_TYPE            [i] = new sc_signal<Ttype_t           > (rename.c_str());
     126      out_RETIRE_STORE_QUEUE_PTR_WRITE [i] = new sc_signal<Tlsq_ptr_t> (rename.c_str());
     127      out_RETIRE_LOAD_QUEUE_PTR_WRITE  [i] = new sc_signal<Tlsq_ptr_t> (rename.c_str());
    122128      out_RETIRE_HAS_IMMEDIAT    [i] = new sc_signal<Tcontrol_t        > (rename.c_str());
    123129      out_RETIRE_IMMEDIAT        [i] = new sc_signal<Tgeneral_data_t   > (rename.c_str());
     
    209215  (*(_Reservation_station-> in_INSERT_OPERATION        )) (*( in_INSERT_OPERATION        ));
    210216  (*(_Reservation_station-> in_INSERT_TYPE             )) (*( in_INSERT_TYPE             ));
     217  (*(_Reservation_station-> in_INSERT_STORE_QUEUE_PTR_WRITE)) (*( in_INSERT_STORE_QUEUE_PTR_WRITE));
     218  (*(_Reservation_station-> in_INSERT_LOAD_QUEUE_PTR_WRITE )) (*( in_INSERT_LOAD_QUEUE_PTR_WRITE ));
    211219  (*(_Reservation_station-> in_INSERT_HAS_IMMEDIAT     )) (*( in_INSERT_HAS_IMMEDIAT     ));
    212220  (*(_Reservation_station-> in_INSERT_IMMEDIAT         )) (*( in_INSERT_IMMEDIAT         ));
     
    242250  (*(_Reservation_station->out_RETIRE_OPERATION      [i])) (*(out_RETIRE_OPERATION      [i]));
    243251  (*(_Reservation_station->out_RETIRE_TYPE           [i])) (*(out_RETIRE_TYPE           [i]));
     252  (*(_Reservation_station->out_RETIRE_STORE_QUEUE_PTR_WRITE [i])) (*(out_RETIRE_STORE_QUEUE_PTR_WRITE [i]));
     253  (*(_Reservation_station->out_RETIRE_LOAD_QUEUE_PTR_WRITE  [i])) (*(out_RETIRE_LOAD_QUEUE_PTR_WRITE  [i]));
    244254  (*(_Reservation_station->out_RETIRE_HAS_IMMEDIAT   [i])) (*(out_RETIRE_HAS_IMMEDIAT   [i]));
    245255  (*(_Reservation_station->out_RETIRE_IMMEDIAT       [i])) (*(out_RETIRE_IMMEDIAT       [i]));
     
    435445              in_INSERT_OPERATION   ->write(0);
    436446              in_INSERT_TYPE        ->write(0);
     447              in_INSERT_STORE_QUEUE_PTR_WRITE->write(0);
     448              in_INSERT_LOAD_QUEUE_PTR_WRITE ->write(0);
    437449              in_INSERT_HAS_IMMEDIAT->write(0);
    438450              in_INSERT_IMMEDIAT    ->write(0);
     
    679691  delete     in_INSERT_OPERATION   ;
    680692  delete     in_INSERT_TYPE        ;
     693  delete     in_INSERT_STORE_QUEUE_PTR_WRITE;
     694  delete     in_INSERT_LOAD_QUEUE_PTR_WRITE ;
    681695  delete     in_INSERT_HAS_IMMEDIAT;
    682696  delete     in_INSERT_IMMEDIAT    ;
     
    710724  delete [] out_RETIRE_OPERATION   ;
    711725  delete [] out_RETIRE_TYPE        ;
     726  delete [] out_RETIRE_STORE_QUEUE_PTR_WRITE;
     727  delete [] out_RETIRE_LOAD_QUEUE_PTR_WRITE ;
    712728  delete [] out_RETIRE_HAS_IMMEDIAT;
    713729  delete [] out_RETIRE_IMMEDIAT    ;
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/include/Parameters.h

    r75 r76  
    4242  public : const uint32_t    _nb_bypass_write      ;//if nb_bypass=0, then bypass is desactivated
    4343  public : const uint32_t    _nb_bypass_memory     ;//if nb_bypass=0, then bypass is desactivated
     44  public : const uint32_t    _size_store_queue     ;
     45  public : const uint32_t    _size_load_queue      ;
     46
    4447    /*
    4548  public : const bool        _have_immediat        ;
     
    8083                        uint32_t nb_spr_write       ,
    8184                        uint32_t nb_bypass_write    ,
    82                         uint32_t nb_bypass_memory   );
     85                        uint32_t nb_bypass_memory   ,
     86                        uint32_t size_store_queue   ,
     87                        uint32_t size_load_queue    );
    8388
    8489  public : Parameters  (Parameters & param) ;
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/include/Reservation_station.h

    r75 r76  
    55 * $Id$
    66 *
    7  * [ Description ]
     7 * [ Description ]
    88 *
    99 */
     
    4747  public    : Toperation_t       _operation   ;
    4848  public    : Ttype_t            _type        ;
     49  public    : Tlsq_ptr_t         _store_queue_ptr_write;
     50  public    : Tlsq_ptr_t         _load_queue_ptr_write ;
    4951  public    : Tcontrol_t         _has_immediat;
    5052  public    : Tgeneral_data_t    _immediat    ;
     
    6971                                morpheo::behavioural::core::multi_execute_loop::execute_loop::multi_read_unit::read_unit::reservation_station::Treservation_station_entry_t & x)
    7072    {
    71       output_stream << " * _context_id     : " << toString(x._context_id     ) << std::endl
    72                     << " * _front_end_id   : " << toString(x._front_end_id   ) << std::endl
    73                     << " * _ooo_engine_id  : " << toString(x._ooo_engine_id  ) << std::endl
    74                     << " * _rob_id         : " << toString(x._rob_id         ) << std::endl
    75                     << " * _operation      : " << toString(x._operation      ) << std::endl
    76                     << " * _type           : " << toString(x._type           ) << std::endl
    77                     << " * _has_immediat   : " << toString(x._has_immediat   ) << std::endl
    78                     << " * _immediat       : " << toString(x._immediat       ) << std::endl
    79 //                  << " * _read_ra        : " << toString(x._read_ra        ) << std::endl
    80                     << " * _num_reg_ra     : " << toString(x._num_reg_ra     ) << std::endl
    81                     << " * _data_ra_val    : " << toString(x._data_ra_val    ) << std::endl
    82                     << " * _data_ra        : " << toString(x._data_ra        ) << std::endl
    83 //                  << " * _read_rb        : " << toString(x._read_rb        ) << std::endl
    84                     << " * _num_reg_rb     : " << toString(x._num_reg_rb     ) << std::endl
    85                     << " * _data_rb_val    : " << toString(x._data_rb_val    ) << std::endl
    86                     << " * _data_rb        : " << toString(x._data_rb        ) << std::endl
    87 //                  << " * _read_rc        : " << toString(x._read_rc        ) << std::endl
    88                     << " * _num_reg_rc     : " << toString(x._num_reg_rc     ) << std::endl
    89                     << " * _data_rc_val    : " << toString(x._data_rc_val    ) << std::endl
    90                     << " * _data_rc        : " << toString(x._data_rc        ) << std::endl
    91                     << " * _write_rd       : " << toString(x._write_rd       ) << std::endl
    92                     << " * _num_reg_rd     : " << toString(x._num_reg_rd     ) << std::endl
    93                     << " * _write_re       : " << toString(x._write_re       ) << std::endl
    94                     << " * _num_reg_re     : " << toString(x._num_reg_re     ) << std::endl;
     73      output_stream << " * _context_id            : " << toString(x._context_id     ) << std::endl
     74                    << " * _front_end_id          : " << toString(x._front_end_id   ) << std::endl
     75                    << " * _ooo_engine_id         : " << toString(x._ooo_engine_id  ) << std::endl
     76                    << " * _rob_id                : " << toString(x._rob_id         ) << std::endl
     77                    << " * _operation             : " << toString(x._operation      ) << std::endl
     78                    << " * _type                  : " << toString(x._type           ) << std::endl
     79                    << " * _store_queue_ptr_write : " << toString(x._store_queue_ptr_write) << std::endl
     80                    << " * _load_queue_ptr_write  : " << toString(x._load_queue_ptr_write ) << std::endl
     81                    << " * _has_immediat          : " << toString(x._has_immediat   ) << std::endl
     82                    << " * _immediat              : " << toString(x._immediat       ) << std::endl
     83//                  << " * _read_ra               : " << toString(x._read_ra        ) << std::endl
     84                    << " * _num_reg_ra            : " << toString(x._num_reg_ra     ) << std::endl
     85                    << " * _data_ra_val           : " << toString(x._data_ra_val    ) << std::endl
     86                    << " * _data_ra               : " << toString(x._data_ra        ) << std::endl
     87//                  << " * _read_rb               : " << toString(x._read_rb        ) << std::endl
     88                    << " * _num_reg_rb            : " << toString(x._num_reg_rb     ) << std::endl
     89                    << " * _data_rb_val           : " << toString(x._data_rb_val    ) << std::endl
     90                    << " * _data_rb               : " << toString(x._data_rb        ) << std::endl
     91//                  << " * _read_rc               : " << toString(x._read_rc        ) << std::endl
     92                    << " * _num_reg_rc            : " << toString(x._num_reg_rc     ) << std::endl
     93                    << " * _data_rc_val           : " << toString(x._data_rc_val    ) << std::endl
     94                    << " * _data_rc               : " << toString(x._data_rc        ) << std::endl
     95                    << " * _write_rd              : " << toString(x._write_rd       ) << std::endl
     96                    << " * _num_reg_rd            : " << toString(x._num_reg_rd     ) << std::endl
     97                    << " * _write_re              : " << toString(x._write_re       ) << std::endl
     98                    << " * _num_reg_re            : " << toString(x._num_reg_re     ) << std::endl;
    9599
    96100      return output_stream;
    97101    }
    98 
    99102  };
    100103
     
    104107#endif
    105108  {
    106     // -----[ fields ]----------------------------------------------------
     109    // -----[ fields ]----------------------------------------------------
    107110    // Parameters
    108111  protected : const std::string       _name;
     
    118121
    119122#ifdef SYSTEMC
    120     // ~~~~~[ Interface ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     123    // ~~~~~[ Interface ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    121124    // Interface
    122125  public    : SC_CLOCK                      *  in_CLOCK        ;
    123126  public    : SC_IN (Tcontrol_t)            *  in_NRESET       ;
    124127
    125     // ~~~~~[ Interface "insert" ]~~~~~~~~~~~~~~~~~~~~~~~~
     128    // ~~~~~[ Interface "insert" ]~~~~~~~~~~~~~~~~~~~~~~~~
    126129  public    : SC_IN (Tcontrol_t        )    *  in_INSERT_VAL            ;
    127130  public    : SC_OUT(Tcontrol_t        )    * out_INSERT_ACK            ;
     
    132135  public    : SC_IN (Toperation_t      )    *  in_INSERT_OPERATION      ;
    133136  public    : SC_IN (Ttype_t           )    *  in_INSERT_TYPE           ;
     137  public    : SC_IN (Tlsq_ptr_t        )    *  in_INSERT_STORE_QUEUE_PTR_WRITE;
     138  public    : SC_IN (Tlsq_ptr_t        )    *  in_INSERT_LOAD_QUEUE_PTR_WRITE ;
    134139  public    : SC_IN (Tcontrol_t        )    *  in_INSERT_HAS_IMMEDIAT   ;
    135140  public    : SC_IN (Tgeneral_data_t   )    *  in_INSERT_IMMEDIAT       ;
     
    151156  public    : SC_IN (Tspecial_address_t)    *  in_INSERT_NUM_REG_RE     ;
    152157
    153     // ~~~~~[ Interface "retire" ]~~~~~~~~~~~~~~~~~~~~~~~
     158    // ~~~~~[ Interface "retire" ]~~~~~~~~~~~~~~~~~~~~~~~
    154159  public    : SC_OUT(Tcontrol_t        )   ** out_RETIRE_VAL            ;
    155160  public    : SC_IN (Tcontrol_t        )   **  in_RETIRE_ACK            ;
     
    160165  public    : SC_OUT(Toperation_t      )   ** out_RETIRE_OPERATION      ;
    161166  public    : SC_OUT(Ttype_t           )   ** out_RETIRE_TYPE           ;
     167  public    : SC_OUT(Tlsq_ptr_t        )   ** out_RETIRE_STORE_QUEUE_PTR_WRITE;
     168  public    : SC_OUT(Tlsq_ptr_t        )   ** out_RETIRE_LOAD_QUEUE_PTR_WRITE ;
    162169  public    : SC_OUT(Tcontrol_t        )   ** out_RETIRE_HAS_IMMEDIAT   ;
    163170  public    : SC_OUT(Tgeneral_data_t   )   ** out_RETIRE_IMMEDIAT       ;
     
    170177  public    : SC_OUT(Tspecial_address_t)   ** out_RETIRE_NUM_REG_RE     ;
    171178
    172     // ~~~~~[ Interface "gpr_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     179    // ~~~~~[ Interface "gpr_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    173180
    174181  public    : SC_IN (Tcontrol_t        )   **  in_GPR_WRITE_VAL          ; // val and ack
     
    177184  public    : SC_IN (Tgeneral_data_t   )   **  in_GPR_WRITE_DATA         ;
    178185
    179     // ~~~~~[ Interface "spr_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     186    // ~~~~~[ Interface "spr_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    180187
    181188  public    : SC_IN (Tcontrol_t        )   **  in_SPR_WRITE_VAL          ; // val and ack
     
    184191  public    : SC_IN (Tspecial_data_t   )   **  in_SPR_WRITE_DATA         ;
    185192
    186     // ~~~~~[ Interface "bypass_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     193    // ~~~~~[ Interface "bypass_write" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    187194
    188195  public    : SC_IN (Tcontext_t        )   **  in_BYPASS_WRITE_OOO_ENGINE_ID ;
     
    194201  public    : SC_IN (Tspecial_data_t   )   **  in_BYPASS_WRITE_SPR_DATA      ;
    195202
    196     // ~~~~~[ Interface "bypass_memory" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     203    // ~~~~~[ Interface "bypass_memory" ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    197204
    198205  public    : SC_IN (Tcontrol_t        )   **  in_BYPASS_MEMORY_VAL          ;
     
    202209
    203210
    204     // ~~~~~[ Component ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
    205 
    206     // ~~~~~[ Register ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
    207 
    208     // ~~~~~[ Internal ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     211    // ~~~~~[ Component ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
     212
     213    // ~~~~~[ Register ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~   
     214
     215    // ~~~~~[ Internal ]~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    209216#ifdef  SYSTEMC_VHDL_COMPATIBILITY
    210217  protected : bool                          *  _queue_valid;
     
    220227#endif
    221228
    222     // -----[ methods ]---------------------------------------------------
     229    // -----[ methods ]---------------------------------------------------
    223230
    224231#ifdef SYSTEMC
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/src/Parameters.cpp

    r69 r76  
    3535                          uint32_t nb_spr_write       ,
    3636                          uint32_t nb_bypass_write    ,
    37                           uint32_t nb_bypass_memory   ):
     37                          uint32_t nb_bypass_memory   ,
     38                          uint32_t size_store_queue   ,
     39                          uint32_t size_load_queue    ):
    3840    _size_queue            (size_queue           ),
    3941    _nb_inst_retire        (nb_inst_retire       ),
     
    5254    _nb_bypass_write       (nb_bypass_write      ),
    5355    _nb_bypass_memory      (nb_bypass_memory     ),
     56    _size_store_queue      (size_store_queue     ),
     57    _size_load_queue       (size_load_queue      ),
    5458
    5559    _size_context_id       (static_cast<uint32_t>(log2(_nb_context         ))),
     
    9195    _nb_bypass_write       (param._nb_bypass_write       ),
    9296    _nb_bypass_memory      (param._nb_bypass_memory      ),
     97    _size_store_queue      (param._size_store_queue      ),
     98    _size_load_queue       (param._size_load_queue       ),
    9399
    94100    _size_context_id       (param._size_context_id       ),
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/src/Parameters_print.cpp

    r75 r76  
    4444    xml.singleton_begin("nb_bypass_write    "); xml.attribut("value",toString(_nb_bypass_write    )); xml.singleton_end();
    4545    xml.singleton_begin("nb_bypass_memory   "); xml.attribut("value",toString(_nb_bypass_memory   )); xml.singleton_end();
     46    xml.singleton_begin("size_store_queue   "); xml.attribut("value",toString(_size_store_queue   )); xml.singleton_end();
     47    xml.singleton_begin("size_load_queue    "); xml.attribut("value",toString(_size_load_queue    )); xml.singleton_end();
    4648    xml.balise_close();
    4749
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/src/Reservation_station_allocation.cpp

    r75 r76  
    7272       in_INSERT_OPERATION      = interface->set_signal_in <Toperation_t      > ("operation"      ,_param->_size_operation        );
    7373       in_INSERT_TYPE           = interface->set_signal_in <Ttype_t           > ("type"           ,_param->_size_type             );
     74       in_INSERT_STORE_QUEUE_PTR_WRITE = interface->set_signal_in <Tlsq_ptr_t> ("store_queue_ptr_write" ,log2(_param->_size_store_queue));
     75       in_INSERT_LOAD_QUEUE_PTR_WRITE  = interface->set_signal_in <Tlsq_ptr_t> ("load_queue_ptr_write"  ,log2(_param->_size_load_queue) );
    7476       in_INSERT_HAS_IMMEDIAT   = interface->set_signal_in <Tcontrol_t        > ("has_immediat"   ,1                             );
    7577       in_INSERT_IMMEDIAT       = interface->set_signal_in <Tgeneral_data_t   > ("immediat"       ,_param->_size_general_data     );
     
    105107    out_RETIRE_OPERATION      = new SC_OUT(Toperation_t      ) * [_param->_nb_inst_retire];
    106108    out_RETIRE_TYPE           = new SC_OUT(Ttype_t           ) * [_param->_nb_inst_retire];
     109    out_RETIRE_STORE_QUEUE_PTR_WRITE = new SC_OUT(Tlsq_ptr_t ) * [_param->_nb_inst_retire];
     110    out_RETIRE_LOAD_QUEUE_PTR_WRITE  = new SC_OUT(Tlsq_ptr_t ) * [_param->_nb_inst_retire];
    107111    out_RETIRE_HAS_IMMEDIAT   = new SC_OUT(Tcontrol_t        ) * [_param->_nb_inst_retire];
    108112    out_RETIRE_IMMEDIAT       = new SC_OUT(Tgeneral_data_t   ) * [_param->_nb_inst_retire];
     
    136140        out_RETIRE_OPERATION    [i] = interface->set_signal_out<Toperation_t      > ("operation"    ,_param->_size_operation);
    137141        out_RETIRE_TYPE         [i] = interface->set_signal_out<Ttype_t           > ("type"         ,_param->_size_type);
     142        out_RETIRE_STORE_QUEUE_PTR_WRITE [i] = interface->set_signal_out<Tlsq_ptr_t> ("store_queue_ptr_write" ,log2(_param->_size_store_queue));
     143        out_RETIRE_LOAD_QUEUE_PTR_WRITE  [i] = interface->set_signal_out<Tlsq_ptr_t> ("load_queue_ptr_write"  ,log2(_param->_size_load_queue) );
     144
    138145        out_RETIRE_HAS_IMMEDIAT [i] = interface->set_signal_out<Tcontrol_t        > ("has_immediat" ,1);
    139146        out_RETIRE_IMMEDIAT     [i] = interface->set_signal_out<Tgeneral_data_t   > ("immediat"     ,_param->_size_general_data);
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/src/Reservation_station_deallocation.cpp

    r69 r76  
    4343    delete     in_INSERT_OPERATION     ;
    4444    delete     in_INSERT_TYPE          ;
     45    delete     in_INSERT_STORE_QUEUE_PTR_WRITE;
     46    delete     in_INSERT_LOAD_QUEUE_PTR_WRITE ;
    4547    delete     in_INSERT_HAS_IMMEDIAT  ;
    4648    delete     in_INSERT_IMMEDIAT      ;
     
    7476    delete [] out_RETIRE_OPERATION     ;
    7577    delete [] out_RETIRE_TYPE          ;
     78    delete [] out_RETIRE_STORE_QUEUE_PTR_WRITE;
     79    delete [] out_RETIRE_LOAD_QUEUE_PTR_WRITE ;
    7680    delete [] out_RETIRE_HAS_IMMEDIAT  ;
    7781    delete [] out_RETIRE_IMMEDIAT      ;
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/src/Reservation_station_genMoore.cpp

    r70 r76  
    101101            PORT_WRITE(out_RETIRE_OPERATION     [i],_queue[index_find]._operation);
    102102            PORT_WRITE(out_RETIRE_TYPE          [i],_queue[index_find]._type);
     103            PORT_WRITE(out_RETIRE_STORE_QUEUE_PTR_WRITE [i],_queue[index_find]._store_queue_ptr_write);
     104            PORT_WRITE(out_RETIRE_LOAD_QUEUE_PTR_WRITE  [i],_queue[index_find]._load_queue_ptr_write );
    103105            PORT_WRITE(out_RETIRE_HAS_IMMEDIAT  [i],_queue[index_find]._has_immediat);
    104106            PORT_WRITE(out_RETIRE_IMMEDIAT      [i],_queue[index_find]._immediat);
  • trunk/IPs/systemC/processor/Morpheo/Behavioural/Core/Multi_Execute_loop/Execute_loop/Multi_Read_unit/Read_unit/Reservation_station/src/Reservation_station_transition.cpp

    r70 r76  
    258258            _queue[index]._operation       = PORT_READ(in_INSERT_OPERATION      );
    259259            _queue[index]._type            = PORT_READ(in_INSERT_TYPE           );
     260            _queue[index]._store_queue_ptr_write = PORT_READ(in_INSERT_STORE_QUEUE_PTR_WRITE);
     261            _queue[index]._load_queue_ptr_write  = PORT_READ(in_INSERT_LOAD_QUEUE_PTR_WRITE );
    260262            _queue[index]._has_immediat    = PORT_READ(in_INSERT_HAS_IMMEDIAT   );
    261263            _queue[index]._immediat        = PORT_READ(in_INSERT_IMMEDIAT       );
Note: See TracChangeset for help on using the changeset viewer.