Changeset 730


Ignore:
Timestamp:
Jun 29, 2014, 1:51:52 PM (11 years ago)
Author:
alain
Message:

Introducing distributed page_tables and kernel code in arch.py for the
tsar_generic_iob platform.

Location:
trunk/platforms/tsar_generic_iob
Files:
1 added
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/platforms/tsar_generic_iob/arch.py

    r714 r730  
    1212#  physical space segmentation) and the mapping of all kernel objects (global vsegs).
    1313#  This platform includes 6 external peripherals, accessible through two IO_Bridge
    14 # components located in cluster [0,0] and cluster [x_size-1, y_size-1].
    15 # Available peripherals are: TTY, BDV, FBF, ROM, NIC, CMA.
     14#  components located in cluster [0,0] and cluster [x_size-1, y_size-1].
     15#  Available peripherals are: TTY, BDV, FBF, ROM, NIC, CMA.
    1616#
    1717#  The "constructor" parameters are:
     
    113113
    114114    boot_mapping_vbase   = 0x00000000      # ident
    115     boot_mapping_size    = 0x00010000      # 64 Kbytes
    116 
    117     boot_code_vbase      = 0x00010000      # ident
     115    boot_mapping_size    = 0x00040000      # 256 Kbytes
     116
     117    boot_code_vbase      = 0x00040000      # ident
    118118    boot_code_size       = 0x00020000      # 128 Kbytes
    119119 
    120     boot_data_vbase      = 0x00030000      # ident
     120    boot_data_vbase      = 0x00060000      # ident
    121121    boot_data_size       = 0x00010000      # 64 Kbytes
    122122
    123     boot_buffer_vbase    = 0x00040000      # ident
     123    boot_buffer_vbase    = 0x00070000      # ident
    124124    boot_buffer_size     = 0x00060000      # 384 Kbytes
    125125
    126     boot_stack_vbase     = 0x000A0000      # ident
     126    boot_stack_vbase     = 0x000D0000      # ident
    127127    boot_stack_size      = 0x00050000      # 320 Kbytes
    128128
     
    218218                mapping.addProc( x, y, p )
    219219
    220     ### global vsegs for boot_loader / identity mapping
    221 
    222     mapping.addGlobal( 'seg_boot_mapping'  , boot_mapping_vbase  , boot_mapping_size  , 'C_W_',
    223                        vtype = 'BLOB'  , x = 0, y = 0, pseg = 'RAM', identity = True )
    224 
    225     mapping.addGlobal( 'seg_boot_code'     , boot_code_vbase     , boot_code_size     , 'CXW_',
    226                        vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM', identity = True )
    227 
    228     mapping.addGlobal( 'seg_boot_data'     , boot_data_vbase     , boot_data_size     , 'C_W_',
    229                        vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM', identity = True )
    230 
    231     mapping.addGlobal( 'seg_boot_buffer'   , boot_buffer_vbase   , boot_buffer_size   , 'C_W_',
    232                        vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM', identity = True )
    233 
    234     mapping.addGlobal( 'seg_boot_stack'    , boot_stack_vbase    , boot_stack_size    , 'C_W_',
    235                        vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM', identity = True )
    236 
    237     ### global vsegs for kernel   
    238 
    239     mapping.addGlobal( 'seg_kernel_code'   , kernel_code_vbase   , kernel_code_size   , 'CXW_',
    240                        vtype = 'ELF'   , x = 0, y = 0, pseg = 'RAM', binpath = 'build/kernel/kernel.elf' )
    241 
    242     mapping.addGlobal( 'seg_kernel_data'   , kernel_data_vbase   , kernel_data_size   , 'C_W_',
    243                        vtype = 'ELF'   , x = 0, y = 0, pseg = 'RAM', binpath = 'build/kernel/kernel.elf' )
    244 
    245     mapping.addGlobal( 'seg_kernel_uncdata', kernel_uncdata_vbase, kernel_uncdata_size, '__W_',
    246                        vtype = 'ELF'   , x = 0, y = 0, pseg = 'RAM', binpath = 'build/kernel/kernel.elf' )
    247 
    248     mapping.addGlobal( 'seg_kernel_init'   , kernel_init_vbase   , kernel_init_size   , 'CXW_',
    249                        vtype = 'ELF'   , x = 0, y = 0, pseg = 'RAM', binpath = 'build/kernel/kernel.elf' )
     220    ### global vsegs for boot_loader / identity mapping
     221
     222    mapping.addGlobal( 'seg_boot_mapping', boot_mapping_vbase, boot_mapping_size,
     223                       'C_W_', vtype = 'BLOB'  , x = 0, y = 0, pseg = 'RAM',
     224                       identity = True )
     225
     226    mapping.addGlobal( 'seg_boot_code', boot_code_vbase, boot_code_size,
     227                       'CXW_', vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM',
     228                       identity = True )
     229
     230    mapping.addGlobal( 'seg_boot_data', boot_data_vbase, boot_data_size,
     231                       'C_W_', vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM',
     232                       identity = True )
     233
     234    mapping.addGlobal( 'seg_boot_buffer', boot_buffer_vbase, boot_buffer_size,
     235                       'C_W_', vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM',
     236                       identity = True )
     237
     238    mapping.addGlobal( 'seg_boot_stack', boot_stack_vbase, boot_stack_size,
     239                       'C_W_', vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM',
     240                       identity = True )
     241
     242    ### local global vsegs for kernel / same virtual address / different physical address
     243
     244    for x in xrange( x_size ):
     245        for y in xrange( y_size ):
     246            cluster_xy = (x << y_width) + y;
     247
     248            mapping.addGlobal( 'seg_kernel_code', kernel_code_vbase, kernel_code_size,
     249                               'CXW_', vtype = 'ELF', x = x , y = y , pseg = 'RAM',
     250                               binpath = 'build/kernel/kernel.elf', local = True )
     251
     252            mapping.addGlobal( 'seg_kernel_init', kernel_init_vbase, kernel_init_size,
     253                               'CXW_', vtype = 'ELF', x = x , y = y , pseg = 'RAM',
     254                               binpath = 'build/kernel/kernel.elf', local = True )
     255
     256    ### shared global vsegs for kernel
     257
     258    mapping.addGlobal( 'seg_kernel_data', kernel_data_vbase, kernel_data_size,
     259                       'C_W_', vtype = 'ELF', x = 0, y = 0, pseg = 'RAM',
     260                       binpath = 'build/kernel/kernel.elf', local = False )
     261
     262    mapping.addGlobal( 'seg_kernel_uncdata', kernel_uncdata_vbase, kernel_uncdata_size,
     263                       '__W_', vtype = 'ELF', x = 0, y = 0, pseg = 'RAM',
     264                       binpath = 'build/kernel/kernel.elf', local = False )
    250265
    251266    ### global vsegs for external peripherals / identity mapping
    252267
    253268    mapping.addGlobal( 'seg_iob', iob_base, iob_size, '__W_',
    254                        vtype = 'PERI', x = 0, y = 0, pseg = 'IOB', identity = True )
     269                       vtype = 'PERI', x = 0, y = 0, pseg = 'IOB',
     270                       identity = True )
    255271
    256272    mapping.addGlobal( 'seg_bdv', bdv_base, bdv_size, '__W_',
    257                        vtype = 'PERI', x = 0, y = 0, pseg = 'BDV', identity = True )
     273                       vtype = 'PERI', x = 0, y = 0, pseg = 'BDV',
     274                       identity = True )
    258275
    259276    mapping.addGlobal( 'seg_tty', tty_base, tty_size, '__W_',
    260                        vtype = 'PERI', x = 0, y = 0, pseg = 'TTY', identity = True )
     277                       vtype = 'PERI', x = 0, y = 0, pseg = 'TTY',
     278                       identity = True )
    261279
    262280    mapping.addGlobal( 'seg_nic', nic_base, nic_size, '__W_',
    263                        vtype = 'PERI', x = 0, y = 0, pseg = 'NIC', identity = True )
     281                       vtype = 'PERI', x = 0, y = 0, pseg = 'NIC',
     282                       identity = True )
    264283
    265284    mapping.addGlobal( 'seg_cma', cma_base, cma_size, '__W_',
    266                        vtype = 'PERI', x = 0, y = 0, pseg = 'CMA', identity = True )
     285                       vtype = 'PERI', x = 0, y = 0, pseg = 'CMA',
     286                       identity = True )
    267287
    268288    mapping.addGlobal( 'seg_fbf', fbf_base, fbf_size, '__W_',
    269                        vtype = 'PERI', x = 0, y = 0, pseg = 'FBF', identity = True )
     289                       vtype = 'PERI', x = 0, y = 0, pseg = 'FBF',
     290                       identity = True )
    270291
    271292    mapping.addGlobal( 'seg_pic', pic_base, pic_size, '__W_',
    272                        vtype = 'PERI', x = 0, y = 0, pseg = 'PIC', identity = True )
     293                       vtype = 'PERI', x = 0, y = 0, pseg = 'PIC',
     294                       identity = True )
    273295
    274296    mapping.addGlobal( 'seg_rom', rom_base, rom_size, 'CXW_',
    275                        vtype = 'PERI', x = 0, y = 0, pseg = 'ROM', identity = True )
    276 
    277     ### Global vsegs for replicated peripherals, and for schedulers
    278     ### name is indexed by (x,y), base address is incremented by (cluster_xy * peri_increment)
     297                       vtype = 'PERI', x = 0, y = 0, pseg = 'ROM',
     298                       identity = True )
     299
     300    ### global vsegs for internal peripherals, and for schedulers
     301    ### name is indexed by (x,y) / vbase address is incremented by (cluster_xy * peri_increment)
    279302
    280303    for x in xrange( x_size ):
     
    303326if __name__ == '__main__':
    304327
    305     mapping = genmap( x_size    = 2,
    306                       y_size    = 2,
    307                       nb_procs  = 2,
    308                       nb_ttys   = 1,
    309                       nb_nics   = 2,
    310                       fbf_width = 128,
    311                       x_io      = 0,
    312                       y_io      = 0 )
     328    mapping = arch( x_size    = 2,
     329                    y_size    = 2,
     330                    nb_procs  = 2 )
    313331
    314332#   print mapping.netbsd_dts()
  • trunk/platforms/tsar_generic_iob/top.cpp

    r718 r730  
    1111// - BROM : boot ROM
    1212// - FBUF : Frame Buffer
    13 // - MTTY : multi TTY (up to 15 channels)
     13// - MTTY : multi TTY (one channel)
    1414// - MNIC : Network controller (up to 2 channels)
    1515// - CDMA : Chained Buffer DMA controller (up to 4 channels)
    16 // - BDEV : Dlock Device controler (1 channel)
     16// - BDEV : Dlock Device controler (one channel)
    1717// - IOPI : HWI to SWI translator.
    1818//
     
    3939// external IOPIC component, that must be configured by the OS to route
    4040// these WTI ITQS to one or several internal XICU components.
    41 // The total number of channels for the external peripherals (MTTY, MNIC, CDMA
    42 // IOC or HBA) is limited by the IOPIC 32 HWI inputs:..
    4341// - IOPIC HWI[1:0]     connected to IRQ_NIC_RX[1:0]
    4442// - IOPIC HWI[3:2]     connected to IRQ_NIC_TX[1:0]
    4543// - IOPIC HWI[7:4]     connected to IRQ_CMA_TX[3:0]]
    4644// - IOPIC HWI[8]       connected to IRQ_BDEV
    47 // - IOPIC HWI[15:9]    unused       (grounded)
    48 // - IOPIC HWI[23:16]   connected to IRQ_TTY_RX[7:0]]
    49 // - IOPIC HWI[31:24]   connected to IRQ_TTY_TX[7:0]]   TBD
     45// - IOPIC HWI[9]       connected to IRQ_TTY_RX[0]
    5046//
    51 // Besides the external peripherals, each cluster contains on XICU component,
     47// Besides the external peripherals, each cluster contains one XICU component,
    5248// and one multi channels DMA component.
    5349// The XICU component is mainly used to handle WTI IRQs, as only 2 HWI IRQs
     
    232228//////////////////////i/////////////////////////////////////
    233229
    234 #define MAX_FROZEN_CYCLES     200000
     230#define MAX_FROZEN_CYCLES     20000000
    235231
    236232/////////////////////////////////////////////////////////
     
    14281424
    14291425        // Monitor a specific address for one L2 cache
    1430         // clusters[0][0]->memc->cache_monitor( 0x170000ULL);
     1426        // clusters[0][0]->memc->cache_monitor( 0x1542c0ULL, true );   // single word monitoring
    14311427
    14321428        // Monitor a specific address for one XRAM
     
    14451441                size_t x          = cluster_xy >> 4;
    14461442                size_t y          = cluster_xy & 0xF;
    1447 
    1448                 clusters[x][y]->proc[l]->print_trace(1);
     1443 
     1444                clusters[x][y]->proc[l]->print_trace(0x40);
    14491445                std::ostringstream proc_signame;
    14501446                proc_signame << "[SIG]PROC_" << x << "_" << y << "_" << l ;
     
    15111507//              clusters[0][0]->signal_ram_vci_ini_iobx.print_trace( "[SIG]IOB0_RAM_INI");
    15121508
    1513                 signal_vci_ini_iob0.print_trace("[SIG]IOB0_IOX_INI");
    1514                 signal_vci_tgt_iob0.print_trace("[SIG]IOB0_IOX_TGT");
     1509//              signal_vci_ini_iob0.print_trace("[SIG]IOB0_IOX_INI");
     1510//              signal_vci_tgt_iob0.print_trace("[SIG]IOB0_IOX_TGT");
    15151511
    15161512//              cdma->print_trace();
     
    15281524                signal_vci_ini_bdev.print_trace("[SIG]BDEV_INI");
    15291525
    1530                 mnic->print_trace();
    1531                 signal_vci_tgt_mnic.print_trace("[SIG]MNIC_TGT");
     1526//              mnic->print_trace();
     1527//              signal_vci_tgt_mnic.print_trace("[SIG]MNIC_TGT");
    15321528
    15331529//              fbuf->print_trace();
Note: See TracChangeset for help on using the changeset viewer.