Changeset 596 for trunk/modules


Ignore:
Timestamp:
Dec 11, 2013, 12:13:44 PM (11 years ago)
Author:
cfuguet
Message:

Modification in vci_mem_cache:

  • The instrumentation registers are now accesible by software.
  • The different registers have been defined in the vci_mem_cache/include/soclib/mem_cache.h file and should be accessed using MEMC_REG(func,idx) defined also in the same file
Location:
trunk/modules/vci_mem_cache
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • trunk/modules/vci_mem_cache/caba/source/include/vci_mem_cache.h

    r549 r596  
    434434      uint32_t     m_cpt_update_cost;    // Number of (flits * distance) for UPDT
    435435
    436       uint32_t     m_cpt_m_inval;        // Number of requests causing M_INV
    437       uint32_t     m_cpt_m_inval_local;  // Number of local M_INV transactions
    438       uint32_t     m_cpt_m_inval_remote; // Number of remote M_INV transactions
    439       uint32_t     m_cpt_m_inval_cost;   // Number of (flits * distance) for M_INV
    440 
    441       uint32_t     m_cpt_br_inval;       // Number of BROADCAST INVAL
     436      uint32_t     m_cpt_minval;         // Number of requests causing M_INV
     437      uint32_t     m_cpt_minval_local;   // Number of local M_INV transactions
     438      uint32_t     m_cpt_minval_remote; // Number of remote M_INV transactions
     439      uint32_t     m_cpt_minval_cost;    // Number of (flits * distance) for M_INV
     440
     441      uint32_t     m_cpt_binval;         // Number of BROADCAST INVAL
    442442
    443443      uint32_t     m_cpt_cleanup_local;  // Number of local CLEANUP transactions
     
    526526      void genMoore();
    527527      void check_monitor(addr_t addr, data_t data, bool read);
     528
    528529      uint32_t req_distance(uint32_t req_srcid);
    529530      bool is_local_req(uint32_t req_srcid);
     531      int  read_instrumentation(uint32_t regr, uint32_t & rdata);
    530532
    531533      // Component attributes
     
    569571      uint32_t                           m_broadcast_boundaries;
    570572
     573      // configuration interface constants
     574      const uint32_t m_config_addr_mask;
     575      const uint32_t m_config_regr_width;
     576      const uint32_t m_config_func_width;
     577      const uint32_t m_config_regr_idx_mask;
     578      const uint32_t m_config_func_idx_mask;
     579
    571580      // Fifo between TGT_CMD fsm and READ fsm
    572581      GenericFifo<addr_t>    m_cmd_read_addr_fifo;
  • trunk/modules/vci_mem_cache/caba/source/src/vci_mem_cache.cpp

    r582 r596  
    3333
    3434#include "../include/vci_mem_cache.h"
     35#include "mem_cache.h"
    3536
    3637//////   debug services   /////////////////////////////////////////////////////////////
     
    392393        m_broadcast_boundaries(0x7C1F),
    393394
     395        // CONFIG interface
     396        m_config_addr_mask((1<<12)-1),
     397
     398        m_config_regr_width(7),
     399        m_config_func_width(3),
     400        m_config_regr_idx_mask((1<<m_config_regr_width)-1),
     401        m_config_func_idx_mask((1<<m_config_func_width)-1),
    394402
    395403        //  FIFOs
     
    652660    }
    653661
     662    /////////////////////////////////////////////////////
     663    tmpl(int)::read_instrumentation(uint32_t regr, uint32_t & rdata)
     664    /////////////////////////////////////////////////////
     665    {
     666        int error = 0;
     667
     668        switch(regr)
     669        {
     670            ///////////////////////////////////////////////////////
     671            //       DIRECT instrumentation registers            //
     672            // Registers of 32 bits and therefore only LO is     //
     673            // implemented.                                      //
     674            //                                                   //
     675            // The HI may be used in future implementations      //
     676            ///////////////////////////////////////////////////////
     677
     678            // LOCAL
     679
     680            case MEMC_LOCAL_READ_LO   : rdata = m_cpt_read_local        ; break;
     681            case MEMC_LOCAL_WRITE_LO  : rdata = m_cpt_write_flits_local ; break;
     682            case MEMC_LOCAL_LL_LO     : rdata = m_cpt_ll_local          ; break;
     683            case MEMC_LOCAL_SC_LO     : rdata = m_cpt_sc_local          ; break;
     684            case MEMC_LOCAL_CAS_LO    : rdata = m_cpt_cas_local         ; break;
     685            case MEMC_LOCAL_READ_HI   :
     686            case MEMC_LOCAL_WRITE_HI  :
     687            case MEMC_LOCAL_LL_HI     :
     688            case MEMC_LOCAL_SC_HI     :
     689            case MEMC_LOCAL_CAS_HI    : rdata = 0; break;
     690
     691            // REMOTE
     692
     693            case MEMC_REMOTE_READ_LO  : rdata = m_cpt_read_remote        ; break;
     694            case MEMC_REMOTE_WRITE_LO : rdata = m_cpt_write_flits_remote ; break;
     695            case MEMC_REMOTE_LL_LO    : rdata = m_cpt_ll_remote          ; break;
     696            case MEMC_REMOTE_SC_LO    : rdata = m_cpt_sc_remote          ; break;
     697            case MEMC_REMOTE_CAS_LO   : rdata = m_cpt_cas_remote         ; break;
     698            case MEMC_REMOTE_READ_HI  :
     699            case MEMC_REMOTE_WRITE_HI :
     700            case MEMC_REMOTE_LL_HI    :
     701            case MEMC_REMOTE_SC_HI    :
     702            case MEMC_REMOTE_CAS_HI   : rdata = 0; break;
     703
     704            // COST
     705
     706            case MEMC_COST_READ_LO    : rdata = m_cpt_read_cost ; break;
     707            case MEMC_COST_WRITE_LO   : rdata = m_cpt_write_cost; break;
     708            case MEMC_COST_LL_LO      : rdata = m_cpt_ll_cost   ; break;
     709            case MEMC_COST_SC_LO      : rdata = m_cpt_sc_cost   ; break;
     710            case MEMC_COST_CAS_LO     : rdata = m_cpt_cas_cost  ; break;
     711            case MEMC_COST_READ_HI    :
     712            case MEMC_COST_WRITE_HI   :
     713            case MEMC_COST_LL_HI      :
     714            case MEMC_COST_SC_HI      :
     715            case MEMC_COST_CAS_HI     : rdata = 0; break;
     716
     717            ///////////////////////////////////////////////////////
     718            //       COHERENCE instrumentation registers         //
     719            // Registers of 32 bits and therefore only LO is     //
     720            // implemented.                                      //
     721            //                                                   //
     722            // The HI may be used in future implementations      //
     723            ///////////////////////////////////////////////////////
     724
     725            // LOCAL
     726
     727            case MEMC_LOCAL_MUPDATE_LO  : rdata = m_cpt_update_local ; break;
     728            case MEMC_LOCAL_MINVAL_LO   : rdata = m_cpt_minval_local ; break;
     729            case MEMC_LOCAL_CLEANUP_LO  : rdata = m_cpt_cleanup_local; break;
     730            case MEMC_LOCAL_MUPDATE_HI  :
     731            case MEMC_LOCAL_MINVAL_HI   :
     732            case MEMC_LOCAL_CLEANUP_HI  : rdata = 0; break;
     733
     734            // REMOTE
     735
     736            case MEMC_REMOTE_MUPDATE_LO : rdata = m_cpt_update_remote ; break;
     737            case MEMC_REMOTE_MINVAL_LO  : rdata = m_cpt_minval_remote ; break;
     738            case MEMC_REMOTE_CLEANUP_LO : rdata = m_cpt_cleanup_remote; break;
     739            case MEMC_REMOTE_MUPDATE_HI :
     740            case MEMC_REMOTE_MINVAL_HI  :
     741            case MEMC_REMOTE_CLEANUP_HI : rdata = 0; break;
     742
     743            // COST
     744
     745            case MEMC_COST_MUPDATE_LO   : rdata = m_cpt_update_cost   ; break;
     746            case MEMC_COST_MINVAL_LO    : rdata = m_cpt_minval_cost   ; break;
     747            case MEMC_COST_CLEANUP_LO   : rdata = m_cpt_cleanup_cost  ; break;
     748            case MEMC_COST_MUPDATE_HI   :
     749            case MEMC_COST_MINVAL_HI    :
     750            case MEMC_COST_CLEANUP_HI   : rdata = 0; break;
     751
     752            // TOTAL
     753
     754            case MEMC_TOTAL_MUPDATE_LO  : rdata = m_cpt_update ; break;
     755            case MEMC_TOTAL_MINVAL_LO   : rdata = m_cpt_minval ; break;
     756            case MEMC_TOTAL_BINVAL_LO   : rdata = m_cpt_binval ; break;
     757            case MEMC_TOTAL_MUPDATE_HI  :
     758            case MEMC_TOTAL_MINVAL_HI   :
     759            case MEMC_TOTAL_BINVAL_HI   : rdata = 0; break;
     760
     761            // unknown register
     762
     763            default                     : error = 1;
     764        }
     765
     766        return error;
     767    }
    654768
    655769    //////////////////////////////////////////////////
     
    722836                << "[022] UPDT COST (FLITS * DIST)  = " << m_cpt_update_cost << std::endl
    723837                << std::endl
    724                 << "[023] REQUESTS TRIG. M_INV      = " << m_cpt_m_inval << std::endl
    725                 << "[024] LOCAL M_INV               = " << m_cpt_m_inval_local << std::endl
    726                 << "[025] REMOTE M_INV              = " << m_cpt_m_inval_remote << std::endl
    727                 << "[026] M_INV COST (FLITS * DIST) = " << m_cpt_m_inval_cost << std::endl
     838                << "[023] REQUESTS TRIG. M_INV      = " << m_cpt_minval << std::endl
     839                << "[024] LOCAL M_INV               = " << m_cpt_minval_local << std::endl
     840                << "[025] REMOTE M_INV              = " << m_cpt_minval_remote << std::endl
     841                << "[026] M_INV COST (FLITS * DIST) = " << m_cpt_minval_cost << std::endl
    728842                << std::endl
    729                 << "[027] BROADCAT INVAL            = " << m_cpt_br_inval << std::endl
     843                << "[027] BROADCAT INVAL            = " << m_cpt_binval << std::endl
    730844                << std::endl
    731845                << "[028] LOCAL CLEANUP             = " << m_cpt_cleanup_local << std::endl
     
    771885                << "[117] AV. REMOTE UPDT PER UP REQ = " << (double) m_cpt_update_remote / m_cpt_update << std::endl
    772886                << std::endl
    773                 << "[118] INVAL MULTICAST RATE  = " << (double) m_cpt_m_inval / m_cpt_cycles << std::endl
    774                 << "[119] AVE. INVAL PER M_INV  = " << (double) (m_cpt_m_inval_local + m_cpt_m_inval_remote) / m_cpt_m_inval << std::endl
    775                 << "[120] AV. LOC INV PER M_INV = " << (double) m_cpt_m_inval_local / m_cpt_m_inval << std::endl
    776                 << "[121] AV. REM INV PER M_INV = " << (double) m_cpt_m_inval_remote / m_cpt_m_inval << std::endl
     887                << "[118] INVAL MULTICAST RATE  = " << (double) m_cpt_minval / m_cpt_cycles << std::endl
     888                << "[119] AVE. INVAL PER M_INV  = " << (double) (m_cpt_minval_local + m_cpt_minval_remote) / m_cpt_minval << std::endl
     889                << "[120] AV. LOC INV PER M_INV = " << (double) m_cpt_minval_local / m_cpt_minval << std::endl
     890                << "[121] AV. REM INV PER M_INV = " << (double) m_cpt_minval_remote / m_cpt_minval << std::endl
    777891                << std::endl
    778                 << "[122] INVAL BROADCAST RATE  = " << (double) m_cpt_br_inval / m_cpt_cycles << std::endl
     892                << "[122] INVAL BROADCAST RATE  = " << (double) m_cpt_binval / m_cpt_cycles << std::endl
    779893                << "[123] WRITE DIRTY RATE      = " << (double) m_cpt_write_dirty / m_cpt_cycles << std::endl
    780894                << std::endl
     
    9681082            m_cpt_update_remote      = 0;
    9691083            m_cpt_update_cost        = 0;
    970             m_cpt_m_inval            = 0;
    971             m_cpt_m_inval_local      = 0;
    972             m_cpt_m_inval_remote     = 0;
    973             m_cpt_m_inval_cost       = 0;
    974             m_cpt_br_inval           = 0;
     1084            m_cpt_minval             = 0;
     1085            m_cpt_minval_local       = 0;
     1086            m_cpt_minval_remote      = 0;
     1087            m_cpt_minval_cost        = 0;
     1088            m_cpt_binval             = 0;
    9751089            m_cpt_cleanup_local      = 0;
    9761090            m_cpt_cleanup_remote     = 0;
     
    12061320            case TGT_CMD_CONFIG:    // execute config request and return response
    12071321                {
    1208                     addr_t   seg_base = m_seg[m_seg_config]->baseAddress();
    1209                     addr_t   address  = p_vci_tgt.address.read();
    1210                     size_t   cell     = (address - seg_base) / vci_param_int::B;
     1322                    ///////////////////////////////////////////////////////////
     1323                    //  Decoding CONFIG interface commands                   //
     1324                    //                                                       //
     1325                    //  VCI ADDRESS                                          //
     1326                    //  ================================================     //
     1327                    //  GLOBAL | LOCAL | ... | FUNC_IDX | REGS_IDX | 00      //
     1328                    //   IDX   |  IDX  |     | (3 bits) | (7 bits) |         //
     1329                    //  ================================================     //
     1330                    //                                                       //
     1331                    //  For instrumentation : FUNC_IDX = 0b001               //
     1332                    //                                                       //
     1333                    //  REGS_IDX                                             //
     1334                    //  ============================================         //
     1335                    //       Z     |    Y      |    X     |   W              //
     1336                    //    (1 bit)  | (2 bits)  | (3 bits) | (1 bit)          //
     1337                    //  ============================================         //
     1338                    //                                                       //
     1339                    //  Z : DIRECT / COHERENCE                               //
     1340                    //  Y : SUBTYPE ( LOCAL, REMOTE, OTHER )                 //
     1341                    //  X : REGISTER INDEX                                   //
     1342                    //  W : HI / LO                                          //
     1343                    //                                                       //
     1344                    //  For configuration: FUNC_IDX = 0b000                  //
     1345                    //                                                       //
     1346                    //  REGS_IDX                                             //
     1347                    //  ============================================         //
     1348                    //             RESERVED             |    X     |         //
     1349                    //             (4 bits)             | (3 bits) |         //
     1350                    //  ============================================         //
     1351                    //                                                       //
     1352                    //  X : REGISTER INDEX                                   //
     1353                    //                                                       //
     1354                    ///////////////////////////////////////////////////////////
     1355
     1356                    addr_t addr_lsb = p_vci_tgt.address.read() &
     1357                                      m_config_addr_mask;
     1358
     1359                    addr_t cell = (addr_lsb / vci_param_int::B);
     1360
     1361                    size_t regr = cell &
     1362                                  m_config_regr_idx_mask;
     1363
     1364                    size_t func = (cell >> m_config_regr_width) &
     1365                                  m_config_func_idx_mask;
    12111366
    12121367                    bool     need_rsp;
    1213                     size_t   error; 
     1368                    int      error; 
    12141369                    uint32_t rdata = 0;         // default value
    12151370                    uint32_t wdata = p_vci_tgt.wdata.read();
    12161371
    1217                     if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_READ)         // get lock
    1218                             and (cell == MEMC_LOCK))
    1219                     {
    1220                         rdata            = (uint32_t) r_config_lock.read();
    1221                         need_rsp         = true;
    1222                         error            = 0;
    1223                         r_config_lock    = true;
    1224                     }
    1225                     else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)  // release lock
    1226                             and (cell == MEMC_LOCK))
    1227                     {
    1228                         need_rsp      = true;
    1229                         error         = 0;
    1230                         r_config_lock = false;
    1231                     }
    1232                     else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)   // set addr_lo
    1233                             and (cell == MEMC_ADDR_LO))
    1234                     {
    1235                         assert( ((wdata % (m_words * vci_param_int::B)) == 0) and
    1236                                 "VCI_MEM_CACHE CONFIG ERROR: The buffer must be aligned on a cache line");
    1237 
    1238                         need_rsp         = true;
    1239                         error            = 0;
    1240                         r_config_address = (r_config_address.read() & 0xFFFFFFFF00000000LL) |
    1241                             ((addr_t)wdata);
    1242                     }
    1243                     else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)   // set addr_hi
    1244                             and (cell == MEMC_ADDR_HI))
    1245 
    1246                     {
    1247                         need_rsp         = true;
    1248                         error            = 0;
    1249                         r_config_address = (r_config_address.read() & 0x00000000FFFFFFFFLL) |
    1250                             (((addr_t) wdata) << 32);
    1251                     }
    1252                     else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)   // set buf_lines
    1253                             and (cell == MEMC_BUF_LENGTH))
    1254                     {
    1255                         need_rsp         = true;
    1256                         error            = 0;
    1257                         size_t lines     = wdata / (m_words << 2);
    1258                         if (wdata % (m_words << 2)) lines++;
    1259                         r_config_cmd_lines = lines;
    1260                         r_config_rsp_lines = 0;
    1261                     }
    1262                     else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)   // set cmd type
    1263                             and (cell == MEMC_CMD_TYPE))
    1264                     {
    1265                         need_rsp         = false;
    1266                         error            = 0;
    1267                         r_config_cmd     = wdata;
    1268 
    1269                         // prepare delayed response from CONFIG FSM
    1270                         r_config_srcid   = p_vci_tgt.srcid.read();
    1271                         r_config_trdid   = p_vci_tgt.trdid.read();
    1272                         r_config_pktid   = p_vci_tgt.pktid.read();
    1273                     }
    1274                     else
    1275                     {
    1276                         need_rsp         = true;
    1277                         error            = 1;
     1372                    switch(func)
     1373                    {
     1374                        // memory operation
     1375                        case MEMC_CONFIG:
     1376                        {
     1377                            if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_READ)         // get lock
     1378                                    and (regr == MEMC_LOCK))
     1379                            {
     1380                                rdata            = (uint32_t) r_config_lock.read();
     1381                                need_rsp         = true;
     1382                                error            = 0;
     1383                                r_config_lock    = true;
     1384                            }
     1385                            else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)  // release lock
     1386                                    and (regr == MEMC_LOCK))
     1387                            {
     1388                                need_rsp      = true;
     1389                                error         = 0;
     1390                                r_config_lock = false;
     1391                            }
     1392                            else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)   // set addr_lo
     1393                                    and (regr == MEMC_ADDR_LO))
     1394                            {
     1395                                assert( ((wdata % (m_words * vci_param_int::B)) == 0) and
     1396                                        "VCI_MEM_CACHE CONFIG ERROR: The buffer must be aligned on a cache line");
     1397
     1398                                need_rsp         = true;
     1399                                error            = 0;
     1400                                r_config_address = (r_config_address.read() & 0xFFFFFFFF00000000LL) |
     1401                                    ((addr_t)wdata);
     1402                            }
     1403                            else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)   // set addr_hi
     1404                                    and (regr == MEMC_ADDR_HI))
     1405
     1406                            {
     1407                                need_rsp         = true;
     1408                                error            = 0;
     1409                                r_config_address = (r_config_address.read() & 0x00000000FFFFFFFFLL) |
     1410                                    (((addr_t) wdata) << 32);
     1411                            }
     1412                            else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)   // set buf_lines
     1413                                    and (regr == MEMC_BUF_LENGTH))
     1414                            {
     1415                                need_rsp         = true;
     1416                                error            = 0;
     1417                                size_t lines     = wdata / (m_words << 2);
     1418                                if (wdata % (m_words << 2)) lines++;
     1419                                r_config_cmd_lines = lines;
     1420                                r_config_rsp_lines = 0;
     1421                            }
     1422                            else if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)   // set cmd type
     1423                                    and (regr == MEMC_CMD_TYPE))
     1424                            {
     1425                                need_rsp         = false;
     1426                                error            = 0;
     1427                                r_config_cmd     = wdata;
     1428
     1429                                // prepare delayed response from CONFIG FSM
     1430                                r_config_srcid   = p_vci_tgt.srcid.read();
     1431                                r_config_trdid   = p_vci_tgt.trdid.read();
     1432                                r_config_pktid   = p_vci_tgt.pktid.read();
     1433                            }
     1434                            else
     1435                            {
     1436                                need_rsp         = true;
     1437                                error            = 1;
     1438                            }
     1439
     1440                            break;
     1441                        }
     1442
     1443                        // instrumentation registers
     1444                        case MEMC_INSTRM:
     1445                        {
     1446                            need_rsp = true;
     1447
     1448                            if (p_vci_tgt.cmd.read() == vci_param_int::CMD_READ)
     1449                            {
     1450                                error = read_instrumentation(regr, rdata);
     1451                            }
     1452                            else
     1453                            {
     1454                                error = 1;
     1455                            }
     1456
     1457                            break;
     1458                        }
     1459
     1460                        //unknown function
     1461                        default:
     1462                        {
     1463                            need_rsp = true;
     1464                            error    = 1;
     1465
     1466                            break;
     1467                        }
    12781468                    }
    12791469
     
    12891479                        r_tgt_cmd_to_tgt_rsp_error = error;
    12901480                        r_tgt_cmd_to_tgt_rsp_rdata = rdata;
    1291                         r_tgt_cmd_fsm              = TGT_CMD_IDLE;
    1292                     }
    1293                     else
    1294                     {
    1295                         r_tgt_cmd_fsm              = TGT_CMD_IDLE;
    1296                     }
     1481                    }
     1482
     1483                    r_tgt_cmd_fsm = TGT_CMD_IDLE;
    12971484
    12981485#if DEBUG_MEMC_TGT_CMD
     
    13001487                        std::cout << "  <MEMC " << name() << " TGT_CMD_CONFIG> Configuration request:"
    13011488                            << " address = " << std::hex << p_vci_tgt.address.read()
     1489                            << " / func = " << func
     1490                            << " / regr = " << regr
     1491                            << " / rdata = " << rdata
    13021492                            << " / wdata = " << p_vci_tgt.wdata.read()
    13031493                            << " / need_rsp = " << need_rsp
     
    13551545                        if (is_local_req(p_vci_tgt.srcid.read())) m_cpt_read_local++;
    13561546                        else                                      m_cpt_read_remote++;
    1357                         m_cpt_read_cost += m_words * req_distance(p_vci_tgt.srcid.read());
     1547                        m_cpt_read_cost += req_distance(p_vci_tgt.srcid.read());
    13581548                    }
    13591549                    // </Activity counters>
     
    16771867#if DEBUG_MEMC_CONFIG
    16781868if (m_debug)
    1679 std::cout << "  <MEMC " << name() << " CONFIG_IDLE> Config Request received"
    1680           << " / address = " << std::hex << r_config_address.read()
    1681           << " / lines = " << std::dec << r_config_cmd_lines.read()
    1682           << " / type = " << r_config_cmd.read() << std::endl;
     1869    std::cout << "  <MEMC " << name() << " CONFIG_IDLE> Config Request received"
     1870              << " / address = " << std::hex << r_config_address.read()
     1871              << " / lines = " << std::dec << r_config_cmd_lines.read()
     1872              << " / type = " << r_config_cmd.read() << std::endl;
    16831873#endif
    16841874                }
     
    46994889                            "MEMC ERROR in CLEANUP_IDLE state : illegal SRCID value");
    47004890
    4701                     // <Activity Counters>
    4702                     if (is_local_req(srcid)) {
    4703                         m_cpt_cleanup_local++;
    4704                     }
    4705                     else {
    4706                         m_cpt_cleanup_remote++;
    4707                         m_cpt_cleanup_cost += req_distance(srcid);
    4708                     }
    4709                     // </Activity Counters>
    47104891                    cc_receive_to_cleanup_fifo_get = true;
    47114892                    r_cleanup_fsm                  = CLEANUP_GET_NLINE;
     
    62076388                        if (is_local_req(m_config_to_cc_send_srcid_fifo.read()))
    62086389                        {
    6209                             m_cpt_m_inval_local++;
     6390                            m_cpt_minval_local++;
    62106391                        }
    62116392                        else
    62126393                        {
    6213                             m_cpt_m_inval_remote++;
    6214                             m_cpt_m_inval_cost += req_distance(m_config_to_cc_send_srcid_fifo.read());
     6394                            m_cpt_minval_remote++;
     6395                            m_cpt_minval_cost += req_distance(m_config_to_cc_send_srcid_fifo.read());
    62156396                        }
    62166397                        // </Activity Counters>
     
    62206401                    if (r_config_to_cc_send_multi_req.read()) r_config_to_cc_send_multi_req = false;
    62216402                    // <Activity Counters>
    6222                     m_cpt_m_inval++;
     6403                    m_cpt_minval++;
    62236404                    // </Activity Counters>
    62246405                    r_cc_send_fsm = CC_SEND_CONFIG_IDLE;
     
    62526433                    if (not p_dspin_m2p.read) break;
    62536434                    // <Activity Counters>
    6254                     m_cpt_br_inval++;
     6435                    m_cpt_binval++;
    62556436                    // </Activity Counters>
    62566437                    r_config_to_cc_send_brdcast_req = false;
     
    62746455                        if (is_local_req(m_xram_rsp_to_cc_send_srcid_fifo.read()))
    62756456                        {
    6276                             m_cpt_m_inval_local++;
     6457                            m_cpt_minval_local++;
    62776458                        }
    62786459                        else
    62796460                        {
    6280                             m_cpt_m_inval_remote++;
    6281                             m_cpt_m_inval_cost += req_distance(m_xram_rsp_to_cc_send_srcid_fifo.read());
     6461                            m_cpt_minval_remote++;
     6462                            m_cpt_minval_cost += req_distance(m_xram_rsp_to_cc_send_srcid_fifo.read());
    62826463                        }
    62836464                        // </Activity Counters>
     
    62876468                    if (r_xram_rsp_to_cc_send_multi_req.read()) r_xram_rsp_to_cc_send_multi_req = false;
    62886469                    // <Activity Counters>
    6289                     m_cpt_m_inval++;
     6470                    m_cpt_minval++;
    62906471                    // </Activity Counters>
    62916472                    r_cc_send_fsm = CC_SEND_XRAM_RSP_IDLE;
     
    63196500                    if (not p_dspin_m2p.read) break;
    63206501                    // <Activity Counters>
    6321                     m_cpt_br_inval++;
     6502                    m_cpt_binval++;
    63226503                    // </Activity Counters>
    63236504                    r_xram_rsp_to_cc_send_brdcast_req = false;
     
    63456526
    63466527                    // <Activity Counters>
    6347                     m_cpt_br_inval++;
     6528                    m_cpt_binval++;
    63486529                    // </Activity Counters>
    63496530
     
    64346615                    if (not p_dspin_m2p.read) break;
    64356616                    // <Activity Counters>
    6436                     m_cpt_br_inval++;
     6617                    m_cpt_binval++;
    64376618                    // </Activity Counters>
    64386619
     
    65766757                    cc_receive_to_cleanup_fifo_put = true;
    65776758                    r_cc_receive_fsm               = CC_RECEIVE_CLEANUP_EOP;
     6759
     6760                    // <Activity Counters>
     6761                    uint32_t srcid = DspinDhccpParam::dspin_get(
     6762                            p_dspin_p2m.data.read(),
     6763                            DspinDhccpParam::CLEANUP_SRCID);
     6764
     6765                    if (is_local_req(srcid)) {
     6766                        m_cpt_cleanup_local++;
     6767                    }
     6768                    else {
     6769                        m_cpt_cleanup_remote++;
     6770                        m_cpt_cleanup_cost += req_distance(srcid);
     6771                    }
     6772                    // </Activity Counters>
    65786773
    65796774                    break;
     
    80298224
    80308225            case TGT_CMD_CONFIG:
     8226            {
     8227                addr_t addr_lsb = p_vci_tgt.address.read() &
     8228                                  m_config_addr_mask;
     8229
     8230                addr_t cell = (addr_lsb / vci_param_int::B);
     8231
     8232                size_t regr = cell &
     8233                              m_config_regr_idx_mask;
     8234
     8235                size_t func = (cell >> m_config_regr_width) &
     8236                              m_config_func_idx_mask;
     8237
     8238                switch(func)
     8239                {
     8240                    case MEMC_CONFIG:
     8241                        if ((p_vci_tgt.cmd.read() == vci_param_int::CMD_WRITE)
     8242                                and (regr == MEMC_CMD_TYPE))
     8243                        {
     8244                            p_vci_tgt.cmdack = true;
     8245                        }
     8246                        else
     8247                        {
     8248                            p_vci_tgt.cmdack = not r_tgt_cmd_to_tgt_rsp_req.read();
     8249                        }
     8250                        break;
     8251
     8252                    default:
     8253                        p_vci_tgt.cmdack = not r_tgt_cmd_to_tgt_rsp_req.read();
     8254                        break;
     8255                }
     8256
     8257                break;
     8258            }
    80318259            case TGT_CMD_ERROR:
    80328260                p_vci_tgt.cmdack = not r_tgt_cmd_to_tgt_rsp_req.read();
  • trunk/modules/vci_mem_cache/include/soclib/mem_cache.h

    r489 r596  
    2828#define MEM_CACHE_REGS_H
    2929
     30enum SoclibMemCacheFunc
     31{
     32    MEMC_CONFIG = 0,
     33    MEMC_INSTRM = 1,
     34
     35    MEMC_FUNC_SPAN = 0x200
     36};
     37
    3038enum SoclibMemCacheConfigRegs
    3139{
     
    4452};
    4553
     54///////////////////////////////////////////////////////////
     55//  Decoding CONFIG interface commands                   //
     56//                                                       //
     57//  VCI ADDRESS                                          //
     58//  ================================================     //
     59//  GLOBAL | LOCAL | ... | FUNC_IDX | REGS_IDX | 00      //
     60//   IDX   |  IDX  |     | (3 bits) | (7 bits) |         //
     61//  ================================================     //
     62//                                                       //
     63//  For instrumentation: FUNC_IDX = 0b001                //
     64//                                                       //
     65//  REGS_IDX                                             //
     66//  ============================================         //
     67//       Z     |    Y      |    X     |   W              //
     68//    (1 bit)  | (2 bits)  | (3 bits) | (1 bit)          //
     69//  ============================================         //
     70//                                                       //
     71//  For configuration: FUNC_IDX = 0b000                  //
     72//                                                       //
     73//  REGS_IDX                                             //
     74//  ============================================         //
     75//             RESERVED             |    X     |         //
     76//             (4 bits)             | (3 bits) |         //
     77//  ============================================         //
     78//                                                       //
     79//  X : REGISTER INDEX                                   //
     80//                                                       //
     81///////////////////////////////////////////////////////////
     82
     83enum SoclibMemCacheInstrRegs {
     84    ///////////////////////////////////////////////////////
     85    //          DIRECT instrumentation registers         //
     86    ///////////////////////////////////////////////////////
     87
     88    // LOCAL
     89
     90    MEMC_LOCAL_READ_LO   = 0x00,
     91    MEMC_LOCAL_READ_HI   = 0x01,
     92    MEMC_LOCAL_WRITE_LO  = 0x02,
     93    MEMC_LOCAL_WRITE_HI  = 0x03,
     94    MEMC_LOCAL_LL_LO     = 0x04,
     95    MEMC_LOCAL_LL_HI     = 0x05,
     96    MEMC_LOCAL_SC_LO     = 0x06,
     97    MEMC_LOCAL_SC_HI     = 0x07,
     98    MEMC_LOCAL_CAS_LO    = 0x08,
     99    MEMC_LOCAL_CAS_HI    = 0x09,
     100
     101    // REMOTE
     102
     103    MEMC_REMOTE_READ_LO  = 0x10,
     104    MEMC_REMOTE_READ_HI  = 0x11,
     105    MEMC_REMOTE_WRITE_LO = 0x12,
     106    MEMC_REMOTE_WRITE_HI = 0x13,
     107    MEMC_REMOTE_LL_LO    = 0x14,
     108    MEMC_REMOTE_LL_HI    = 0x15,
     109    MEMC_REMOTE_SC_LO    = 0x16,
     110    MEMC_REMOTE_SC_HI    = 0x17,
     111    MEMC_REMOTE_CAS_LO   = 0x18,
     112    MEMC_REMOTE_CAS_HI   = 0x19,
     113
     114    // COST
     115
     116    MEMC_COST_READ_LO    = 0x20,
     117    MEMC_COST_READ_HI    = 0x21,
     118    MEMC_COST_WRITE_LO   = 0x22,
     119    MEMC_COST_WRITE_HI   = 0x23,
     120    MEMC_COST_LL_LO      = 0x24,
     121    MEMC_COST_LL_HI      = 0x25,
     122    MEMC_COST_SC_LO      = 0x26,
     123    MEMC_COST_SC_HI      = 0x27,
     124    MEMC_COST_CAS_LO     = 0x28,
     125    MEMC_COST_CAS_HI     = 0x29,
     126
     127    ///////////////////////////////////////////////////////
     128    //       COHERENCE instrumentation registers         //
     129    ///////////////////////////////////////////////////////
     130
     131    // LOCAL
     132
     133    MEMC_LOCAL_MUPDATE_LO  = 0x40,
     134    MEMC_LOCAL_MUPDATE_HI  = 0x41,
     135    MEMC_LOCAL_MINVAL_LO   = 0x42,
     136    MEMC_LOCAL_MINVAL_HI   = 0x43,
     137    MEMC_LOCAL_CLEANUP_LO  = 0x44,
     138    MEMC_LOCAL_CLEANUP_HI  = 0x45,
     139
     140    // REMOTE
     141
     142    MEMC_REMOTE_MUPDATE_LO = 0x50,
     143    MEMC_REMOTE_MUPDATE_HI = 0x51,
     144    MEMC_REMOTE_MINVAL_LO  = 0x52,
     145    MEMC_REMOTE_MINVAL_HI  = 0x53,
     146    MEMC_REMOTE_CLEANUP_LO = 0x54,
     147    MEMC_REMOTE_CLEANUP_HI = 0x55,
     148
     149    // COST
     150
     151    MEMC_COST_MUPDATE_LO   = 0x60,
     152    MEMC_COST_MUPDATE_HI   = 0x61,
     153    MEMC_COST_MINVAL_LO    = 0x62,
     154    MEMC_COST_MINVAL_HI    = 0x63,
     155    MEMC_COST_CLEANUP_LO   = 0x64,
     156    MEMC_COST_CLEANUP_HI   = 0x65,
     157
     158    // TOTAL
     159
     160    MEMC_TOTAL_MUPDATE_LO  = 0x68,
     161    MEMC_TOTAL_MUPDATE_HI  = 0x69,
     162    MEMC_TOTAL_MINVAL_LO   = 0x6A,
     163    MEMC_TOTAL_MINVAL_HI   = 0x6B,
     164    MEMC_TOTAL_BINVAL_LO   = 0x6C,
     165    MEMC_TOTAL_BINVAL_HI   = 0x6D,
     166};
     167
     168#define MEMC_REG(func,idx) ((func<<7)|idx)
     169
    46170#endif /* MEM_CACHE_REGS_H */
    47171
Note: See TracChangeset for help on using the changeset viewer.