|
| 1 | +# pre place all macro |
| 2 | +# |
| 3 | +set block [ord::get_db_block] |
| 4 | +set units [$block getDefUnits] |
| 5 | + |
| 6 | +set coreArea [$block getCoreArea] |
| 7 | +set xMin [$coreArea xMin] |
| 8 | +set yMin [$coreArea yMin] |
| 9 | + |
| 10 | +# macro pins on M4 starts with an offset of 0.012 from the bottom |
| 11 | +# of the macro; then, will need to adjust the placement of the macro |
| 12 | +# such that the pins will be on M4 grid |
| 13 | +set x $xMin |
| 14 | +set y [expr $yMin - int(0.012 * $units)] |
| 15 | + |
| 16 | +# the algorithm is to place macro such what if 2 macros are side by side, |
| 17 | +# the macro should be flip alternately |
| 18 | +set orientList [list R0 MY] |
| 19 | +set flag 1 |
| 20 | +foreach instName [list \ |
| 21 | + coreplex/RocketTile/frontend/icache/_T_850/_T_850_ext/u_ram \ |
| 22 | + coreplex/RocketTile/frontend/icache/_T_869/_T_850_ext/u_ram \ |
| 23 | + coreplex/RocketTile/frontend/icache/_T_888/_T_850_ext/u_ram \ |
| 24 | + coreplex/RocketTile/frontend/icache/_T_907/_T_850_ext/u_ram \ |
| 25 | + coreplex/RocketTile/dcache/data/_T_118/_T_80_ext/u_ram_bank_0 \ |
| 26 | + coreplex/RocketTile/dcache/data/_T_118/_T_80_ext/u_ram_bank_1 \ |
| 27 | + coreplex/RocketTile/dcache/data/_T_215/_T_80_ext/u_ram_bank_0 \ |
| 28 | + coreplex/RocketTile/dcache/data/_T_215/_T_80_ext/u_ram_bank_1 \ |
| 29 | + coreplex/RocketTile/dcache/data/_T_253/_T_80_ext/u_ram_bank_0 \ |
| 30 | + coreplex/RocketTile/dcache/data/_T_253/_T_80_ext/u_ram_bank_1 \ |
| 31 | + coreplex/RocketTile/dcache/data/_T_80/_T_80_ext/u_ram_bank_0 \ |
| 32 | + coreplex/RocketTile/dcache/data/_T_80/_T_80_ext/u_ram_bank_1 \ |
| 33 | + coreplex/RocketTile/core/bpd_stage/br_predictor/counters/h_table/h_table/smem/smem_0_ext/u_regfile \ |
| 34 | + coreplex/RocketTile/dcache/meta/_T_157/_T_157_ext/u_ram_bank_0 \ |
| 35 | + coreplex/RocketTile/dcache/meta/_T_157/_T_157_ext/u_ram_bank_1 \ |
| 36 | + coreplex/RocketTile/dcache/meta/_T_157/_T_157_ext/u_ram_bank_2 \ |
| 37 | + coreplex/RocketTile/dcache/meta/_T_157/_T_157_ext/u_ram_bank_3 \ |
| 38 | + coreplex/RocketTile/frontend/icache/tag_array/tag_array_ext/u_ram_bank_0 \ |
| 39 | + coreplex/RocketTile/frontend/icache/tag_array/tag_array_ext/u_ram_bank_1 \ |
| 40 | + coreplex/RocketTile/frontend/icache/tag_array/tag_array_ext/u_ram_bank_2 \ |
| 41 | + coreplex/RocketTile/frontend/icache/tag_array/tag_array_ext/u_ram_bank_3 \ |
| 42 | + coreplex/RocketTile/core/bpd_stage/br_predictor/counters/p_table/p_table_0/smem/u_smem_ext/u_regfile \ |
| 43 | + coreplex/RocketTile/core/bpd_stage/br_predictor/counters/p_table/p_table_1/smem/u_smem_ext/u_regfile \ |
| 44 | + coreplex/RocketTile/core/bpd_stage/br_predictor/brob/entries_info/u_entries_info_ext/u_regfile \ |
| 45 | + ] { |
| 46 | + set orient [lindex $orientList $flag] |
| 47 | + puts "====> instance $instName" |
| 48 | + set inst [$block findInst $instName] |
| 49 | + if {$inst == "NULL"} { |
| 50 | + puts "ERROR ====> instance $instName" |
| 51 | + } |
| 52 | + |
| 53 | + set bbox [$inst getBBox] |
| 54 | + set w [$bbox getDX] |
| 55 | + set h [$bbox getDY] |
| 56 | + |
| 57 | + set x [expr $x + ($flag * $w)] |
| 58 | + |
| 59 | + $inst setPlacementStatus UNPLACE |
| 60 | + $inst setOrient $orient |
| 61 | + $inst setOrigin $x $y |
| 62 | + $inst setPlacementStatus FIRM |
| 63 | + |
| 64 | + set x [expr $x + ([expr {! $flag}] * $w) + ((4 * $units) * ($flag + 1))] |
| 65 | + |
| 66 | + set bx1 [expr $x + ($flag * $w)] |
| 67 | + set by1 [expr $x + ([expr {! $flag}] * $w)] |
| 68 | + set bx2 [expr $y] |
| 69 | + set by2 [expr $y + $h] |
| 70 | + |
| 71 | + set flag [expr {! $flag}] |
| 72 | +} |
0 commit comments