Ignore:
Timestamp:
Jun 27, 2014, 4:48:54 PM (10 years ago)
Author:
cfuguet
Message:

fault_tolerance/tsar_generic_iob:

main arguments


  • Replacing atoi function by strtol to accept hexadecimal numeric arguments

config files


Introducing:

  • configuration files (conf/preloader*) for compiling preloader.
  • configuration file (soclib.conf) for compiling with soclib-cc.
  • description file (arch.py) for generating hard and soft configuration files using GIET_VM genmap script
File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/fault_tolerance/platforms/tsar_generic_iob/arch.py

    r724 r728  
    88#   author : Alain Greiner
    99#######################################################################################
    10 #  This file contains a mapping generator for the "tsar_generic_iob" platform. 
     10#  This file contains a mapping generator for the "tsar_generic_iob" platform.
    1111#  This includes both the hardware architecture (clusters, processors, peripherals,
    1212#  physical space segmentation) and the mapping of all kernel objects (global vsegs).
     
    4242
    4343    nb_ttys        = 1
    44     nb_nics        = 2 
     44    nb_nics        = 2
    4545    fbf_width      = 1024
    4646    x_io           = 0
     
    5252    use_ramdisk    = False
    5353    peri_increment = 0x10000
    54                  
     54
    5555    ### parameters checking
    5656
    5757    assert( nb_procs <= 4 )
    5858
    59     assert( (x_size == 1) or (x_size == 2) or (x_size == 4) 
     59    assert( (x_size == 1) or (x_size == 2) or (x_size == 4)
    6060             or (y_size == 8) or (x_size == 16) )
    6161
    62     assert( (y_size == 1) or (y_size == 2) or (y_size == 4) 
     62    assert( (y_size == 1) or (y_size == 2) or (y_size == 4)
    6363             or (y_size == 8) or (y_size == 16) )
    6464
     
    6969
    7070    platform_name  = 'tsar_iob_%d_%d_%d' % ( x_size, y_size, nb_procs )
    71    
     71
    7272    ### define physical segments
    7373
    74     ram_base = 0x0000000000
    75     ram_size = 0x4000000                   # 64 Mbytes
    76 
    77     xcu_base = 0x00B0000000
    78     xcu_size = 0x1000                      # 4 Kbytes
    79 
    80     dma_base = 0x00B1000000
    81     dma_size = 0x1000 * nb_procs           # 4 Kbytes * nb_procs
    82 
    83     mmc_base = 0x00B2000000
    84     mmc_size = 0x1000                      # 4 Kbytes
     74    ram_base  = 0x0000000000
     75    ram_size  = 0x4000000                  # 64 Mbytes
     76
     77    xcu_base  = 0x00B0000000
     78    xcu_size  = 0x1000                     # 4 Kbytes
     79
     80    dma_base  = 0x00B1000000
     81    dma_size  = 0x1000 * nb_procs          # 4 Kbytes * nb_procs
     82
     83    mmc_base  = 0x00B2000000
     84    mmc_size  = 0x1000                     # 4 Kbytes
     85
     86    rom_base  = 0x00BFC00000
     87    rom_size  = 0x8000                     # 32 Kbytes
    8588
    8689    offset_io = ((x_io << y_width) + y_io) << (paddr_width - x_width - y_width)
     
    105108
    106109    iob_base  = 0x00BE000000 + offset_io
    107     iob_size  = 0x1000                     # 4kbytes
    108 
    109     rom_base  = 0x00BFC00000 + offset_io
    110     rom_size  = 0x4000                     # 16 Kbytes
     110    iob_size  = 0x1000                     # 4 kbytes
     111
     112    ### GIET_VM specifics virtual segments
    111113
    112114    ### define  bootloader vsegs base addresses
     
    116118
    117119    boot_code_vbase      = 0x00010000      # ident
    118     boot_code_size       = 0x00020000      # 128 Kbytes 
    119  
     120    boot_code_size       = 0x00020000      # 128 Kbytes
     121
    120122    boot_data_vbase      = 0x00030000      # ident
    121123    boot_data_size       = 0x00010000      # 64 Kbytes
     
    129131    ### define kernel vsegs base addresses
    130132
    131     kernel_code_vbase    = 0x80000000           
     133    kernel_code_vbase    = 0x80000000
    132134    kernel_code_size     = 0x00020000      # 128 Kbytes
    133135
     
    146148    ### create mapping
    147149
    148     mapping = Mapping( name           = platform_name, 
    149                        x_size         = x_size,       
    150                        y_size         = y_size,       
    151                        procs_max      = nb_procs,     
    152                        x_width        = x_width,       
    153                        y_width        = y_width,       
    154                        paddr_width    = paddr_width,   
    155                        coherence      = True,         
    156                        irq_per_proc   = irq_per_proc, 
    157                        use_ramdisk    = use_ramdisk, 
    158                        x_io           = x_io,         
     150    mapping = Mapping( name           = platform_name,
     151                       x_size         = x_size,
     152                       y_size         = y_size,
     153                       procs_max      = nb_procs,
     154                       x_width        = x_width,
     155                       y_width        = y_width,
     156                       paddr_width    = paddr_width,
     157                       coherence      = True,
     158                       irq_per_proc   = irq_per_proc,
     159                       use_ramdisk    = use_ramdisk,
     160                       x_io           = x_io,
    159161                       y_io           = y_io,
    160                        peri_increment = peri_increment )         
     162                       peri_increment = peri_increment )
    161163
    162164    ###  external peripherals (accessible in cluster[0,0] only for this mapping)
     
    168170    tty = mapping.addPeriph( 'TTY', base = tty_base, size = tty_size, ptype = 'TTY', channels = nb_ttys )
    169171
    170     nic = mapping.addPeriph( 'NIC', base = nic_base, size = nic_size, ptype = 'NIC', channels = nb_nics ) 
     172    nic = mapping.addPeriph( 'NIC', base = nic_base, size = nic_size, ptype = 'NIC', channels = nb_nics )
    171173
    172174    cma = mapping.addPeriph( 'CMA', base = cma_base, size = cma_size, ptype = 'CMA', channels = 2*nb_nics )
    173175
    174176    fbf = mapping.addPeriph( 'FBF', base = fbf_base, size = fbf_size, ptype = 'FBF', arg = fbf_width )
    175 
    176     rom = mapping.addPeriph( 'ROM', base = rom_base, size = rom_size, ptype = 'ROM' )
    177177
    178178    pic = mapping.addPeriph( 'PIC', base = pic_base, size = pic_size, ptype = 'PIC', channels = 32 )
     
    193193    mapping.addIrq( pic, index = 9, isrtype = 'ISR_TTY_RX', channel = 0 )
    194194
    195     ### hardware components replicated in all clusters   
     195    ### hardware components replicated in all clusters
    196196
    197197    for x in xrange( x_size ):
     
    202202            ram = mapping.addRam( 'RAM', base = ram_base + offset, size = ram_size )
    203203
    204             mmc = mapping.addPeriph( 'MMC', base = mmc_base + offset, size = mmc_size,
     204            rom = mapping.addPeriph( 'ROM', base = rom_base + offset, size = rom_size,
     205                                     ptype = 'ROM' )
     206
     207            mmc = mapping.addPeriph( 'MMC', base = mmc_base + offset, size = mmc_size,
    205208                                     ptype = 'MMC' )
    206209
    207             dma = mapping.addPeriph( 'DMA', base = dma_base + offset, size = dma_size, 
    208                                      ptype = 'DMA', channels = nb_procs ) 
    209 
    210             xcu = mapping.addPeriph( 'XCU', base = xcu_base + offset, size = xcu_size, 
     210            dma = mapping.addPeriph( 'DMA', base = dma_base + offset, size = dma_size,
     211                                     ptype = 'DMA', channels = nb_procs )
     212
     213            xcu = mapping.addPeriph( 'XCU', base = xcu_base + offset, size = xcu_size,
    211214                                     ptype = 'XCU', channels = nb_procs * irq_per_proc, arg = 16 )
    212215
     
    220223    ### global vsegs for boot_loader / identity mapping
    221224
    222     mapping.addGlobal( 'seg_boot_mapping'  , boot_mapping_vbase  , boot_mapping_size  , 'C_W_', 
     225    mapping.addGlobal( 'seg_boot_mapping'  , boot_mapping_vbase  , boot_mapping_size  , 'C_W_',
    223226                       vtype = 'BLOB'  , x = 0, y = 0, pseg = 'RAM', identity = True )
    224227
    225     mapping.addGlobal( 'seg_boot_code'     , boot_code_vbase     , boot_code_size     , 'CXW_', 
     228    mapping.addGlobal( 'seg_boot_code'     , boot_code_vbase     , boot_code_size     , 'CXW_',
    226229                       vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM', identity = True )
    227230
    228     mapping.addGlobal( 'seg_boot_data'     , boot_data_vbase     , boot_data_size     , 'C_W_', 
     231    mapping.addGlobal( 'seg_boot_data'     , boot_data_vbase     , boot_data_size     , 'C_W_',
    229232                       vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM', identity = True )
    230233
    231     mapping.addGlobal( 'seg_boot_buffer'   , boot_buffer_vbase   , boot_buffer_size   , 'C_W_', 
     234    mapping.addGlobal( 'seg_boot_buffer'   , boot_buffer_vbase   , boot_buffer_size   , 'C_W_',
    232235                       vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM', identity = True )
    233236
    234     mapping.addGlobal( 'seg_boot_stack'    , boot_stack_vbase    , boot_stack_size    , 'C_W_', 
     237    mapping.addGlobal( 'seg_boot_stack'    , boot_stack_vbase    , boot_stack_size    , 'C_W_',
    235238                       vtype = 'BUFFER', x = 0, y = 0, pseg = 'RAM', identity = True )
    236239
    237     ### global vsegs for kernel   
    238 
    239     mapping.addGlobal( 'seg_kernel_code'   , kernel_code_vbase   , kernel_code_size   , 'CXW_', 
     240    ### global vsegs for kernel
     241
     242    mapping.addGlobal( 'seg_kernel_code'   , kernel_code_vbase   , kernel_code_size   , 'CXW_',
    240243                       vtype = 'ELF'   , x = 0, y = 0, pseg = 'RAM', binpath = 'build/kernel/kernel.elf' )
    241244
    242     mapping.addGlobal( 'seg_kernel_data'   , kernel_data_vbase   , kernel_data_size   , 'C_W_', 
     245    mapping.addGlobal( 'seg_kernel_data'   , kernel_data_vbase   , kernel_data_size   , 'C_W_',
    243246                       vtype = 'ELF'   , x = 0, y = 0, pseg = 'RAM', binpath = 'build/kernel/kernel.elf' )
    244247
    245     mapping.addGlobal( 'seg_kernel_uncdata', kernel_uncdata_vbase, kernel_uncdata_size, '__W_', 
     248    mapping.addGlobal( 'seg_kernel_uncdata', kernel_uncdata_vbase, kernel_uncdata_size, '__W_',
    246249                       vtype = 'ELF'   , x = 0, y = 0, pseg = 'RAM', binpath = 'build/kernel/kernel.elf' )
    247250
    248     mapping.addGlobal( 'seg_kernel_init'   , kernel_init_vbase   , kernel_init_size   , 'CXW_', 
     251    mapping.addGlobal( 'seg_kernel_init'   , kernel_init_vbase   , kernel_init_size   , 'CXW_',
    249252                       vtype = 'ELF'   , x = 0, y = 0, pseg = 'RAM', binpath = 'build/kernel/kernel.elf' )
    250253
    251254    ### global vsegs for external peripherals / identity mapping
    252255
    253     mapping.addGlobal( 'seg_iob', iob_base, iob_size, '__W_', 
     256    mapping.addGlobal( 'seg_iob', iob_base, iob_size, '__W_',
    254257                       vtype = 'PERI', x = 0, y = 0, pseg = 'IOB', identity = True )
    255258
    256     mapping.addGlobal( 'seg_bdv', bdv_base, bdv_size, '__W_', 
     259    mapping.addGlobal( 'seg_bdv', bdv_base, bdv_size, '__W_',
    257260                       vtype = 'PERI', x = 0, y = 0, pseg = 'BDV', identity = True )
    258261
    259     mapping.addGlobal( 'seg_tty', tty_base, tty_size, '__W_', 
     262    mapping.addGlobal( 'seg_tty', tty_base, tty_size, '__W_',
    260263                       vtype = 'PERI', x = 0, y = 0, pseg = 'TTY', identity = True )
    261264
    262     mapping.addGlobal( 'seg_nic', nic_base, nic_size, '__W_', 
     265    mapping.addGlobal( 'seg_nic', nic_base, nic_size, '__W_',
    263266                       vtype = 'PERI', x = 0, y = 0, pseg = 'NIC', identity = True )
    264267
    265     mapping.addGlobal( 'seg_cma', cma_base, cma_size, '__W_', 
     268    mapping.addGlobal( 'seg_cma', cma_base, cma_size, '__W_',
    266269                       vtype = 'PERI', x = 0, y = 0, pseg = 'CMA', identity = True )
    267270
    268     mapping.addGlobal( 'seg_fbf', fbf_base, fbf_size, '__W_', 
     271    mapping.addGlobal( 'seg_fbf', fbf_base, fbf_size, '__W_',
    269272                       vtype = 'PERI', x = 0, y = 0, pseg = 'FBF', identity = True )
    270273
    271     mapping.addGlobal( 'seg_pic', pic_base, pic_size, '__W_', 
     274    mapping.addGlobal( 'seg_pic', pic_base, pic_size, '__W_',
    272275                       vtype = 'PERI', x = 0, y = 0, pseg = 'PIC', identity = True )
    273276
    274     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
     277    ### Global vsegs for replicated peripherals, and for schedulers
    278278    ### name is indexed by (x,y), base address is incremented by (cluster_xy * peri_increment)
    279279
     
    283283            offset     = cluster_xy * peri_increment
    284284
     285            mapping.addGlobal( 'seg_rom_%d_%d' %(x,y), rom_base + offset, rom_size,
     286                               'CX__', vtype = 'PERI' , x = x , y = y , pseg = 'ROM' )
     287
    285288            mapping.addGlobal( 'seg_xcu_%d_%d' %(x,y), xcu_base + offset, xcu_size,
    286289                               '__W_', vtype = 'PERI' , x = x , y = y , pseg = 'XCU' )
     
    307310                      nb_procs  = 2,
    308311                      nb_ttys   = 1,
    309                       nb_nics   = 2, 
     312                      nb_nics   = 2,
    310313                      fbf_width = 128,
    311314                      x_io      = 0,
     
    317320
    318321#   print mapping.giet_vsegs()
    319                      
     322
    320323
    321324# Local Variables:
Note: See TracChangeset for help on using the changeset viewer.