| # While the code below looks messy, it was taken directly from a vivado example |
| # See here (https://www.xilinx.com/support/answers/66386.html) |
| # See also this link (https://github.com/lowRISC/opentitan/pull/8138#issuecomment-916696830) |
| # for a thorough explanation of why such a custom placement helps. |
| # The placement location has been chosen by evaluating the resulting place and route times of |
| # The most suitable locations include: X0Y4, X0Y2, X1Y6, X1Y5 |
| # The following locations lead to excessive implementation times: X0Y0, X0Y6, X1Y1 |
| # The evaluation has been performed using commit df3c4caee8df70af6b6f3182078ca94ad0022578. |
| # It may become necessary in the future to tweak this if other congestion issues arise. |
| # Clock net "top_earlgrey/u_clkmgr_aon/u_clk_main_aes_trans/u_cg/gen_xilinx.u_impl_xilinx/clocks_o[clk_main_aes]" driven by instance "top_earlgrey/u_clkmgr_aon/u_clk_main_aes_trans/u_cg/gen_xilinx.u_impl_xilinx/gen_gate.gen_bufhce.u_bufhce" located at site "BUFHCE_X0Y2" |
| create_pblock {CLKAG_top_earlgrey/u_clkmgr_aon/u_clk_main_aes_trans/u_cg/gen_xilinx.u_impl_xilinx/clocks_o[clk_main_aes]} |
| set aes_cells [get_cells -filter { PRIMITIVE_GROUP != I/O && IS_PRIMITIVE==1 && PRIMITIVE_LEVEL !=INTERNAL } -of_object [get_pins -filter {DIRECTION==IN} -of_objects [get_nets -hierarchical -filter {PARENT=="top_earlgrey/u_clkmgr_aon/u_clk_main_aes_trans/u_cg/gen_xilinx.u_impl_xilinx/clocks_o[clk_main_aes]"}]]] |
| add_cells_to_pblock [get_pblocks {CLKAG_top_earlgrey/u_clkmgr_aon/u_clk_main_aes_trans/u_cg/gen_xilinx.u_impl_xilinx/clocks_o[clk_main_aes]}] ${aes_cells} |
| resize_pblock [get_pblocks {CLKAG_top_earlgrey/u_clkmgr_aon/u_clk_main_aes_trans/u_cg/gen_xilinx.u_impl_xilinx/clocks_o[clk_main_aes]}] -add {CLOCKREGION_X0Y2:CLOCKREGION_X0Y2} |