From 84706cf5465ef49a469ee44d7acfcdd9a6a19126 Mon Sep 17 00:00:00 2001 From: bernardo Date: Thu, 19 Dec 2024 01:05:26 +0000 Subject: [PATCH 1/2] drt: slight routeNet_postAstarPatchMinAreaVio refactor Signed-off-by: bernardo --- src/drt/src/dr/FlexDR.h | 10 ++ src/drt/src/dr/FlexDR_maze.cpp | 240 +++++++++++---------------------- 2 files changed, 88 insertions(+), 162 deletions(-) diff --git a/src/drt/src/dr/FlexDR.h b/src/drt/src/dr/FlexDR.h index 624cd910197..7b2a03f0b14 100644 --- a/src/drt/src/dr/FlexDR.h +++ b/src/drt/src/dr/FlexDR.h @@ -1045,6 +1045,16 @@ class FlexDRWorker drNet* net, const std::vector& path, const std::map& areaMap); + void routeNet_postAstarPatchMinAreaVio_helper( + drNet* net, + drt::frLayer* curr_layer, + frArea reqArea, + frArea currArea, + frCoord startViaHalfEncArea, + frCoord endViaHalfEncArea, + std::vector& points, + int point_idx, + int prev_point_idx); void routeNet_postAstarAddPatchMetal(drNet* net, const FlexMazeIdx& bpIdx, const FlexMazeIdx& epIdx, diff --git a/src/drt/src/dr/FlexDR_maze.cpp b/src/drt/src/dr/FlexDR_maze.cpp index 0b15c41e6a2..04213ad6615 100644 --- a/src/drt/src/dr/FlexDR_maze.cpp +++ b/src/drt/src/dr/FlexDR_maze.cpp @@ -3385,87 +3385,15 @@ void FlexDRWorker::routeNet_postAstarPatchMinAreaVio( // push to minArea violation if (currArea < reqArea) { - FlexMazeIdx bp, ep; - frArea gapArea = reqArea - - (currArea - startViaHalfEncArea - endViaHalfEncArea) - - std::min(startViaHalfEncArea, endViaHalfEncArea); - // new - bool bpPatchStyle = true; // style 1: left only; 0: right only - bool epPatchStyle = false; - // stack via - if (i - 1 == prev_i) { - bp = points[i - 1]; - ep = points[i - 1]; - bpPatchStyle = true; - epPatchStyle = false; - // planar - } else { - bp = points[prev_i]; - ep = points[i - 1]; - if (getTech()->getLayer(layerNum)->getDir() - == dbTechLayerDir::HORIZONTAL) { - if (points[prev_i].x() < points[prev_i + 1].x()) { - bpPatchStyle = true; - } else if (points[prev_i].x() > points[prev_i + 1].x()) { - bpPatchStyle = false; - } else { - if (points[prev_i].x() < points[i - 1].x()) { - bpPatchStyle = true; - } else if (points[prev_i].x() > points[i - 1].x()) { - bpPatchStyle = false; - } else { - // if fully vertical, bpPatch left and epPatch right - bpPatchStyle = false; - } - } - if (points[i - 1].x() < points[i - 2].x()) { - epPatchStyle = true; - } else if (points[i - 1].x() > points[i - 2].x()) { - epPatchStyle = false; - } else { - if (points[i - 1].x() < points[prev_i].x()) { - epPatchStyle = true; - } else if (points[i - 1].x() > points[prev_i].x()) { - epPatchStyle = false; - } else { - // if fully vertical, bpPatch left and epPatch right - epPatchStyle = true; - } - } - } else { - if (points[prev_i].y() < points[prev_i + 1].y()) { - bpPatchStyle = true; - } else if (points[prev_i].y() > points[prev_i + 1].y()) { - bpPatchStyle = false; - } else { - if (points[prev_i].y() < points[i - 1].y()) { - bpPatchStyle = true; - } else if (points[prev_i].y() > points[i - 1].y()) { - bpPatchStyle = false; - } else { - // if fully horizontal, bpPatch left and epPatch right - bpPatchStyle = false; - } - } - if (points[i - 1].y() < points[i - 2].y()) { - epPatchStyle = true; - } else if (points[i - 1].y() > points[i - 2].y()) { - epPatchStyle = false; - } else { - if (points[i - 1].y() < points[prev_i].y()) { - epPatchStyle = true; - } else if (points[i - 1].y() > points[prev_i].y()) { - epPatchStyle = false; - } else { - // if fully horizontal, bpPatch left and epPatch right - epPatchStyle = true; - } - } - } - } - auto patchWidth = getTech()->getLayer(layerNum)->getWidth(); - routeNet_postAstarAddPatchMetal( - net, bp, ep, gapArea, patchWidth, bpPatchStyle, epPatchStyle); + routeNet_postAstarPatchMinAreaVio_helper(net, + getTech()->getLayer(layerNum), + reqArea, + currArea, + startViaHalfEncArea, + endViaHalfEncArea, + points, + i, + prev_i); } // init for next path if (nextIdx.z() < currIdx.z()) { @@ -3496,10 +3424,10 @@ void FlexDRWorker::routeNet_postAstarPatchMinAreaVio( frArea reqArea = (minAreaConstraint) ? minAreaConstraint->getMinArea() : 0; auto pathWidth = getTech()->getLayer(layerNum)->getWidth(); - Point bp, ep; - gridGraph_.getPoint(bp, currIdx.x(), currIdx.y()); - gridGraph_.getPoint(ep, nextIdx.x(), nextIdx.y()); - frCoord pathLength = Point::manhattanDistance(bp, ep); + Point begin_point, end_point; + gridGraph_.getPoint(begin_point, currIdx.x(), currIdx.y()); + gridGraph_.getPoint(end_point, nextIdx.x(), nextIdx.y()); + frCoord pathLength = Point::manhattanDistance(begin_point, end_point); if (currArea < reqArea) { if (!prev_is_wire) { currArea /= 2; @@ -3523,87 +3451,75 @@ void FlexDRWorker::routeNet_postAstarPatchMinAreaVio( } endViaHalfEncArea = 0; if (currArea < reqArea) { - FlexMazeIdx bp, ep; - frArea gapArea = reqArea - - (currArea - startViaHalfEncArea - endViaHalfEncArea) - - std::min(startViaHalfEncArea, endViaHalfEncArea); - // new - bool bpPatchStyle = true; // style 1: left only; 0: right only - bool epPatchStyle = false; - // stack via - if (i - 1 == prev_i) { - bp = points[i - 1]; - ep = points[i - 1]; - bpPatchStyle = true; - epPatchStyle = false; - // planar - } else { - bp = points[prev_i]; - ep = points[i - 1]; - if (getTech()->getLayer(layerNum)->getDir() - == dbTechLayerDir::HORIZONTAL) { - if (points[prev_i].x() < points[prev_i + 1].x()) { - bpPatchStyle = true; - } else if (points[prev_i].x() > points[prev_i + 1].x()) { - bpPatchStyle = false; - } else { - if (points[prev_i].x() < points[i - 1].x()) { - bpPatchStyle = true; - } else if (points[prev_i].x() > points[i - 1].x()) { - bpPatchStyle = false; - } else { - bpPatchStyle = false; - } - } - if (points[i - 1].x() < points[i - 2].x()) { - epPatchStyle = true; - } else if (points[i - 1].x() > points[i - 2].x()) { - epPatchStyle = false; - } else { - if (points[i - 1].x() < points[prev_i].x()) { - epPatchStyle = true; - } else if (points[i - 1].x() > points[prev_i].x()) { - epPatchStyle = false; - } else { - epPatchStyle = true; - } - } - } else { - if (points[prev_i].y() < points[prev_i + 1].y()) { - bpPatchStyle = true; - } else if (points[prev_i].y() > points[prev_i + 1].y()) { - bpPatchStyle = false; - } else { - if (points[prev_i].y() < points[i - 1].y()) { - bpPatchStyle = true; - } else if (points[prev_i].y() > points[i - 1].y()) { - bpPatchStyle = false; - } else { - bpPatchStyle = false; - } - } - if (points[i - 1].y() < points[i - 2].y()) { - epPatchStyle = true; - } else if (points[i - 1].y() > points[i - 2].y()) { - epPatchStyle = false; - } else { - if (points[i - 1].y() < points[prev_i].y()) { - epPatchStyle = true; - } else if (points[i - 1].y() > points[prev_i].y()) { - epPatchStyle = false; - } else { - epPatchStyle = true; - } - } - } - } - auto patchWidth = getTech()->getLayer(layerNum)->getWidth(); - routeNet_postAstarAddPatchMetal( - net, bp, ep, gapArea, patchWidth, bpPatchStyle, epPatchStyle); + routeNet_postAstarPatchMinAreaVio_helper(net, + getTech()->getLayer(layerNum), + reqArea, + currArea, + startViaHalfEncArea, + endViaHalfEncArea, + points, + i, + prev_i); } } } +void FlexDRWorker::routeNet_postAstarPatchMinAreaVio_helper( + drNet* net, + drt::frLayer* curr_layer, + frArea reqArea, + frArea currArea, + frCoord startViaHalfEncArea, + frCoord endViaHalfEncArea, + std::vector& points, + int point_idx, + int prev_point_idx) +{ + FlexMazeIdx begin_point, end_point; + frArea gapArea = reqArea + - (currArea - startViaHalfEncArea - endViaHalfEncArea) + - std::min(startViaHalfEncArea, endViaHalfEncArea); + // new + bool bpPatchStyle = true; // style 1: left only; 0: right only + bool epPatchStyle = false; + // stack via + if (point_idx - 1 == prev_point_idx) { + begin_point = points[point_idx - 1]; + end_point = points[point_idx - 1]; + bpPatchStyle = true; + epPatchStyle = false; + // planar + } else { + begin_point = points[prev_point_idx]; + end_point = points[point_idx - 1]; + FlexMazeIdx begin_point_successor = points[prev_point_idx + 1], + end_point_predecessor = points[point_idx - 2]; + if (curr_layer->getDir() == dbTechLayerDir::HORIZONTAL) { + bpPatchStyle = (begin_point.x() == begin_point_successor.x()) + ? (begin_point.x() < end_point.x()) + : (begin_point.x() < begin_point_successor.x()); + epPatchStyle = (end_point.x() == end_point_predecessor.x()) + ? (end_point.x() <= begin_point.x()) + : (end_point.x() < end_point_predecessor.x()); + } else { + bpPatchStyle = (begin_point.y() == begin_point_successor.y()) + ? (begin_point.y() < end_point.y()) + : (begin_point.y() < begin_point_successor.y()); + epPatchStyle = (end_point.y() == end_point_predecessor.y()) + ? (end_point.y() <= begin_point.y()) + : (end_point.y() < end_point_predecessor.y()); + } + } + auto patchWidth = curr_layer->getWidth(); + routeNet_postAstarAddPatchMetal(net, + begin_point, + end_point, + gapArea, + patchWidth, + bpPatchStyle, + epPatchStyle); +} + frCoord FlexDRWorker::getHalfViaEncArea(frMIdx z, bool isLayer1, frNonDefaultRule* ndr) From cd640dbdcad6114faf2a45c5dcd61b21030fd4ef Mon Sep 17 00:00:00 2001 From: bernardo Date: Sat, 21 Dec 2024 02:27:01 +0000 Subject: [PATCH 2/2] drt: clarify variable names Signed-off-by: bernardo --- src/drt/src/dr/FlexDR_maze.cpp | 42 +++++++++++++++++++--------------- 1 file changed, 23 insertions(+), 19 deletions(-) diff --git a/src/drt/src/dr/FlexDR_maze.cpp b/src/drt/src/dr/FlexDR_maze.cpp index 04213ad6615..4e566fffb18 100644 --- a/src/drt/src/dr/FlexDR_maze.cpp +++ b/src/drt/src/dr/FlexDR_maze.cpp @@ -3479,15 +3479,15 @@ void FlexDRWorker::routeNet_postAstarPatchMinAreaVio_helper( frArea gapArea = reqArea - (currArea - startViaHalfEncArea - endViaHalfEncArea) - std::min(startViaHalfEncArea, endViaHalfEncArea); - // new - bool bpPatchStyle = true; // style 1: left only; 0: right only - bool epPatchStyle = false; + // bp = begin point, ep = endpoint + bool is_bp_patch_style_left = true; // style 1: left only; 0: right only + bool is_ep_patch_style_right = false; // stack via if (point_idx - 1 == prev_point_idx) { begin_point = points[point_idx - 1]; end_point = points[point_idx - 1]; - bpPatchStyle = true; - epPatchStyle = false; + is_bp_patch_style_left = true; + is_ep_patch_style_right = false; // planar } else { begin_point = points[prev_point_idx]; @@ -3495,19 +3495,23 @@ void FlexDRWorker::routeNet_postAstarPatchMinAreaVio_helper( FlexMazeIdx begin_point_successor = points[prev_point_idx + 1], end_point_predecessor = points[point_idx - 2]; if (curr_layer->getDir() == dbTechLayerDir::HORIZONTAL) { - bpPatchStyle = (begin_point.x() == begin_point_successor.x()) - ? (begin_point.x() < end_point.x()) - : (begin_point.x() < begin_point_successor.x()); - epPatchStyle = (end_point.x() == end_point_predecessor.x()) - ? (end_point.x() <= begin_point.x()) - : (end_point.x() < end_point_predecessor.x()); + is_bp_patch_style_left + = (begin_point.x() == begin_point_successor.x()) + ? (begin_point.x() < end_point.x()) + : (begin_point.x() < begin_point_successor.x()); + is_ep_patch_style_right + = (end_point.x() == end_point_predecessor.x()) + ? (end_point.x() <= begin_point.x()) + : (end_point.x() < end_point_predecessor.x()); } else { - bpPatchStyle = (begin_point.y() == begin_point_successor.y()) - ? (begin_point.y() < end_point.y()) - : (begin_point.y() < begin_point_successor.y()); - epPatchStyle = (end_point.y() == end_point_predecessor.y()) - ? (end_point.y() <= begin_point.y()) - : (end_point.y() < end_point_predecessor.y()); + is_bp_patch_style_left + = (begin_point.y() == begin_point_successor.y()) + ? (begin_point.y() < end_point.y()) + : (begin_point.y() < begin_point_successor.y()); + is_ep_patch_style_right + = (end_point.y() == end_point_predecessor.y()) + ? (end_point.y() <= begin_point.y()) + : (end_point.y() < end_point_predecessor.y()); } } auto patchWidth = curr_layer->getWidth(); @@ -3516,8 +3520,8 @@ void FlexDRWorker::routeNet_postAstarPatchMinAreaVio_helper( end_point, gapArea, patchWidth, - bpPatchStyle, - epPatchStyle); + is_bp_patch_style_left, + is_ep_patch_style_right); } frCoord FlexDRWorker::getHalfViaEncArea(frMIdx z,