blob: b91a5790e99da5cee16ba200899de99f23f98a3d [file] [log] [blame]
<?xml version="1.0" standalone="no"?>
<xsl:stylesheet version="1.0"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:math="http://exslt.org/math"
xmlns:exsl="http://exslt.org/common"
xmlns:xlink="http://www.w3.org/1999/xlink"
extension-element-prefixes="math">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"
doctype-public="-//W3C//DTD SVG 1.0//EN"
doctype-system="http://www.w3.org/TR/SVG/DTD/svg10.dtd"/>
<xsl:template name="F_Calc_Proc_Height">
<xsl:param name="iProcInst" select="_processor_"/>
<xsl:variable name="tot_bifs_h_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[(@INSTANCE = $iProcInst)]/@BIFS_H)">0</xsl:if>
<xsl:if test="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[(@INSTANCE = $iProcInst)]/@BIFS_H">
<xsl:variable name="bifs_h_" select="($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[(@INSTANCE = $iProcInst)]/@BIFS_H)"/>
<xsl:value-of select="(($BLKD_BIF_H + $BLKD_MOD_BIF_GAP_H) * $bifs_h_)"/>
</xsl:if>
</xsl:variable>
<xsl:value-of select="(($BLKD_MOD_LANE_H * 2) + $tot_bifs_h_ + ($BLKD_MOD_LABEL_H + $BLKD_MOD_BIF_GAP_H))"/>
</xsl:template>
<xsl:template name="F_Calc_Max_Proc_Height">
<!-- Store the heights in a variable -->
<xsl:variable name="proc_heights_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE)">
<PROC HEIGHT="0"/>
</xsl:if>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE">
<xsl:variable name="procInst_" select="@INSTANCE"/>
<xsl:variable name="proc_height_">
<xsl:call-template name="F_Calc_Proc_Height">
<xsl:with-param name="iProcInst" select="$procInst_"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Found Proc height as <xsl:value-of select="$proc_height_"/></xsl:message>
-->
<PROC HEIGHT="{$proc_height_}"/>
</xsl:for-each>
</xsl:variable>
<!-- Return the max of them -->
<!--
<xsl:message>Found Proc ax as <xsl:value-of select="math:max(exsl:node-set($proc_heights_)/PROC/@HEIGHT)"/></xsl:message>
-->
<xsl:value-of select="math:max(exsl:node-set($proc_heights_)/PROC/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_Proc_MemoryUnits_Height">
<xsl:param name="iProcInst" select="_processor_"/>
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@PROCESSOR = $iProcInst) and (@MODCLASS = 'MEMORY_UNIT'))])">0</xsl:if>
<xsl:if test="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@PROCESSOR = $iProcInst) and (@MODCLASS='MEMORY_UNIT'))]">
<xsl:variable name="peri_gap_">
<xsl:choose>
<xsl:when test="not(@CSTACK_INDEX)">
<xsl:value-of select="$BLKD_BIF_H"/>
</xsl:when>
<xsl:otherwise>0</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<!-- Store the all memory unit heights in a variable -->
<xsl:variable name="memU_heights_">
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@PROCESSOR = $iProcInst) and (@MODCLASS='MEMORY_UNIT'))]">
<!--
<xsl:variable name="unitId_" select="@PSTACK_MODS_Y"/>
-->
<xsl:variable name="unitHeight_">
<xsl:call-template name="F_Calc_MemoryUnit_Height">
<xsl:with-param name="iShapeId" select="@SHAPE_ID"/>
</xsl:call-template>
</xsl:variable>
<MEM_UNIT HEIGHT="{$unitHeight_ + $peri_gap_}"/>
</xsl:for-each>
</xsl:variable>
<xsl:value-of select="sum(exsl:node-set($memU_heights_)/MEM_UNIT/@HEIGHT)"/>
</xsl:if>
</xsl:template>
<xsl:template name="F_Calc_Proc_Peripherals_Height">
<xsl:param name="iProcInst" select="_processor_"/>
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@PROCESSOR = $iProcInst) and not(@MODCLASS = 'MEMORY_UNIT'))])">0</xsl:if>
<xsl:if test="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@PROCESSOR = $iProcInst) and not(@MODCLASS='MEMORY_UNIT'))]">
<xsl:variable name="peri_gap_">
<xsl:if test="@CSTACK_INDEX">
<xsl:value-of select="$BLKD_BIF_H"/>
</xsl:if>
<xsl:if test="not(@IS_CSTACK)">0</xsl:if>
</xsl:variable>
<!-- Store the all peripheral heights in a variable -->
<xsl:variable name="peri_heights_">
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@PROCESSOR = $iProcInst) and not(@MODCLASS='MEMORY_UNIT'))]">
<xsl:for-each select="MODULE">
<!--
<xsl:message><xsl:value-of select="@INSTANCE"/></xsl:message>
-->
<xsl:variable name="peri_height_">
<xsl:call-template name="F_Calc_PeriShape_Height">
<xsl:with-param name="iShapeInst" select="@INSTANCE"/>
</xsl:call-template>
</xsl:variable>
<PERI HEIGHT="{$peri_height_ + $peri_gap_}"/>
</xsl:for-each>
</xsl:for-each>
</xsl:variable>
<xsl:value-of select="sum(exsl:node-set($peri_heights_)/PERI/@HEIGHT)"/>
</xsl:if>
</xsl:template>
<xsl:template name="F_Calc_Space_AbvSbs_Height">
<xsl:param name="iStackToEast" select="'NONE'"/>
<xsl:param name="iStackToWest" select="'NONE'"/>
<xsl:variable name = "stackAbvSbs_West_H_">
<xsl:choose>
<xsl:when test="(($iStackToEast = '0') and ($iStackToWest = 'NONE'))">0</xsl:when>
<xsl:when test="(($iStackToEast = 'NONE') and not($iStackToWest = 'NONE'))">
<xsl:call-template name="F_Calc_Stack_AbvSbs_Height">
<xsl:with-param name="iStackIdx" select="$iStackToWest"/>
</xsl:call-template>
</xsl:when>
<xsl:when test="(not($iStackToEast = '0') and ($iStackToWest = 'NONE'))">
<xsl:call-template name="F_Calc_Stack_AbvSbs_Height">
<xsl:with-param name="iStackIdx" select="($iStackToEast - 1)"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>0</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:variable name = "stackAbvSbs_East_H_">
<xsl:call-template name="F_Calc_Stack_AbvSbs_Height">
<xsl:with-param name="iStackIdx" select="$iStackToEast"/>
</xsl:call-template>
</xsl:variable>
<xsl:variable name="stackAbvSbs_heights_">
<STACK HEIGHT="{$stackAbvSbs_East_H_}"/>
<STACK HEIGHT="{$stackAbvSbs_West_H_}"/>
</xsl:variable>
<xsl:value-of select="math:max(exsl:node-set($stackAbvSbs_heights_)/STACK/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_Space_BlwSbs_Height">
<xsl:param name="iStackToEast" select="'NONE'"/>
<xsl:param name="iStackToWest" select="'NONE'"/>
<xsl:variable name = "stackBlwSbs_West_H_">
<xsl:choose>
<xsl:when test="(($iStackToEast = '0') and ($iStackToWest = 'NONE'))">0</xsl:when>
<xsl:when test="(($iStackToEast = 'NONE') and not($iStackToWest = 'NONE'))">
<xsl:call-template name="F_Calc_Stack_BlwSbs_Height">
<xsl:with-param name="iStackIdx" select="$iStackToWest"/>
</xsl:call-template>
</xsl:when>
<xsl:when test="(not($iStackToEast = '0') and ($iStackToWest = 'NONE'))">
<xsl:call-template name="F_Calc_Stack_BlwSbs_Height">
<xsl:with-param name="iStackIdx" select="($iStackToEast - 1)"/>
</xsl:call-template>
</xsl:when>
</xsl:choose>
</xsl:variable>
<xsl:variable name = "stackBlwSbs_East_H_">
<xsl:call-template name="F_Calc_Stack_BlwSbs_Height">
<xsl:with-param name="iStackIdx" select="$iStackToEast"/>
</xsl:call-template>
</xsl:variable>
<xsl:variable name="stackBlwSbs_heights_">
<STACK HEIGHT="{$stackBlwSbs_East_H_}"/>
<STACK HEIGHT="{$stackBlwSbs_West_H_}"/>
</xsl:variable>
<xsl:value-of select="math:max(exsl:node-set($stackBlwSbs_heights_)/STACK/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_Stack_AbvSbs_Height">
<xsl:param name="iStackIdx" select="100"/>
<!--
<xsl:message>^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</xsl:message>
-->
<xsl:if test="(not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iStackIdx) and (@IS_ABVSBS))]) and
not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[(@STACK_HORIZ_INDEX = $iStackIdx)]))"><xsl:value-of select="$BLKD_PROC2SBS_GAP"/></xsl:if>
<xsl:if test="(($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iStackIdx) and (@IS_ABVSBS))]) or
($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[ (@STACK_HORIZ_INDEX = $iStackIdx)]))">
<!--
<xsl:variable name="peri_gap_">
<xsl:value-of select="$BLKD_BIF_H"/>
<xsl:choose>
<xsl:when test="(@SHAPE_VERTI_INDEX)">
</xsl:when>
<xsl:otherwise>0</xsl:otherwise>
</xsl:choose>
</xsl:variable>
-->
<!--
<xsl:message>The gap is <xsl:value-of select="$peri_gap_"/></xsl:message>
<xsl:message>The gap is <xsl:value-of select="$peri_gap_"/></xsl:message>
<xsl:message>================================</xsl:message>
<xsl:message>================================</xsl:message>
<xsl:message>This is above <xsl:value-of select="@INSTANCE"/></xsl:message>
<xsl:message><xsl:value-of select="@INSTANCE"/> : <xsl:value-of select="$peri_height_"/></xsl:message>
-->
<!-- Store the all peripheral heights in a variable -->
<xsl:variable name="peri_heights_">
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iStackIdx) and not(@MODCLASS = 'MEMORY_UNIT') and (@IS_ABVSBS))]">
<xsl:for-each select="MODULE">
<!--
<xsl:message>This is above <xsl:value-of select="@INSTANCE"/></xsl:message>
-->
<xsl:variable name="peri_height_">
<!--
<xsl:call-template name="F_Calc_Shape_Height">
<xsl:with-param name="shapeId" select="@SHAPE_ID"/>
</xsl:call-template>
-->
<xsl:call-template name="F_Calc_PeriShape_Height">
<xsl:with-param name="iShapeInst" select="@INSTANCE"/>
</xsl:call-template>
</xsl:variable>
<PERI HEIGHT="{$peri_height_ + $BLKD_BIF_H}"/>
</xsl:for-each>
</xsl:for-each>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iStackIdx) and (@MODCLASS = 'MEMORY_UNIT') and (@IS_ABVSBS))]">
<xsl:variable name="memu_height_">
<xsl:call-template name="F_Calc_MemoryUnit_Height">
<xsl:with-param name="iShapeId" select="@SHAPE_ID"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Mem_Unit : <xsl:value-of select="@SHAPE_ID"/> : <xsl:value-of select="$memu_height_ + $peri_gap_"/></xsl:message>
-->
<PERI HEIGHT="{$memu_height_ + $BLKD_BIF_H}"/>
</xsl:for-each>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[((@STACK_HORIZ_INDEX = $iStackIdx) and (@IS_ABVSBS))]">
<xsl:variable name="proc_height_">
<xsl:call-template name="F_Calc_PeriShape_Height">
<xsl:with-param name="iShapeInst" select="@INSTANCE"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>===================================</xsl:message>
<xsl:message>Processor : <xsl:value-of select="@INSTANCE"/> : <xsl:value-of select="$peri_height_ + $peri_gap_"/></xsl:message>
<PERI HEIGHT="{$proc_height_ + $BLKD_PROC2SBS_GAP }"/>
-->
<PERI HEIGHT="{$proc_height_ + $BLKD_BIF_H}"/>
</xsl:for-each>
</xsl:variable>
<!--
<xsl:message><xsl:value-of select="@INSTANCE"/> : <xsl:value-of select="$peri_height_ + $peri_gap_"/></xsl:message>
<xsl:message>================================</xsl:message>
-->
<!--
<xsl:message>^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</xsl:message>
-->
<xsl:value-of select="sum(exsl:node-set($peri_heights_)/PERI/@HEIGHT)"/>
</xsl:if>
</xsl:template>
<xsl:template name="F_Calc_Stack_BlwSbs_Height">
<xsl:param name="iStackIdx" select="100"/>
<!-- Store the all peripheral heights in a variable -->
<xsl:variable name="stack_heights_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iStackIdx) and (@IS_BLWSBS))])">
<STACKSHAPE HEIGHT="0"/>
</xsl:if>
<xsl:if test="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iStackIdx) and (@IS_BLWSBS))]">
<xsl:variable name="peri_gap_">
<xsl:choose>
<xsl:when test="(@SHAPE_VERTI_INDEX)">
<xsl:value-of select="$BLKD_BIF_H"/>
</xsl:when>
<xsl:otherwise>0</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iStackIdx) and not(@MODCLASS = 'MEMORY_UNIT') and (@IS_BLWSBS))]">
<xsl:for-each select="MODULE">
<!--
<xsl:message>This is below <xsl:value-of select="@INSTANCE"/></xsl:message>
-->
<xsl:variable name="peri_height_">
<xsl:call-template name="F_Calc_PeriShape_Height">
<xsl:with-param name="iShapeInst" select="@INSTANCE"/>
</xsl:call-template>
</xsl:variable>
<STACKSHAPE HEIGHT="{$peri_height_ + $peri_gap_}"/>
</xsl:for-each>
</xsl:for-each>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iStackIdx) and (@MODCLASS = 'MEMORY_UNIT') and (@IS_BLWSBS))]">
<xsl:variable name="memu_height_">
<xsl:call-template name="F_Calc_MemoryUnit_Height">
<xsl:with-param name="iShapeId" select="@SHAPE_ID"/>
</xsl:call-template>
</xsl:variable>
<STACKSHAPE HEIGHT="{$memu_height_ + $peri_gap_}"/>
<!--
<xsl:message>Mem_Unit : <xsl:value-of select="@SHAPE_ID"/> : <xsl:value-of select="$memu_height_ + $peri_gap_"/></xsl:message>
-->
</xsl:for-each>
</xsl:if>
<xsl:variable name="sbsBuckets_H_">
<xsl:call-template name="F_Calc_Stack_SbsBuckets_Height">
<xsl:with-param name="iStackIdx" select="$iStackIdx"/>
</xsl:call-template>
</xsl:variable>
<STACKSHAPE HEIGHT="{$sbsBuckets_H_}"/>
<!--
<xsl:message>Sbs Bucket H : <xsl:value-of select="$sbsBuckets_H_"/></xsl:message>
-->
</xsl:variable>
<!--
<xsl:message>vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv</xsl:message>
-->
<xsl:value-of select="sum(exsl:node-set($stack_heights_)/STACKSHAPE/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_Stack_SbsBuckets_Height">
<xsl:param name="iStackIdx" select="1000"/>
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSBUCKETS/SBSBUCKET[(@STACK_HORIZ_INDEX = $iStackIdx)])">0</xsl:if>
<xsl:if test="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSBUCKETS/SBSBUCKET[(@STACK_HORIZ_INDEX = $iStackIdx)]">
<!-- Store the all buckets heights in a variable -->
<xsl:variable name="bkt_heights_">
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSBUCKETS/SBSBUCKET[(@STACK_HORIZ_INDEX = $iStackIdx)]">
<xsl:variable name="bkt_height_">
<xsl:call-template name="F_Calc_SbsBucket_Height">
<xsl:with-param name="iBucketId" select="@BUS_INDEX"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Found shared buckets height as <xsl:value-of select="$bkt_height_"/></xsl:message>
-->
<BKT HEIGHT="{$bkt_height_ + $BLKD_BIF_H}"/>
</xsl:for-each>
</xsl:variable>
<xsl:value-of select="sum(exsl:node-set($bkt_heights_)/BKT/@HEIGHT)"/>
</xsl:if>
</xsl:template>
<xsl:template name="F_Calc_Max_Stack_BlwSbs_Height">
<!-- Store the heights in a variable -->
<xsl:variable name="blwSbs_heights_">
<!-- Default, in case there are no modules or ports -->
<BLW HEIGHT="0"/>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/BCLANESPACES/BCLANESPACE[(@EAST &lt; $G_ROOT/EDKSYSTEM/BLKDIAGRAM/@STACK_HORIZ_WIDTH)]">
<!--
<xsl:message>Found a space of index <xsl:value-of select="@EAST"/></xsl:message>
-->
<xsl:variable name="stack_height_">
<xsl:call-template name="F_Calc_Stack_BlwSbs_Height">
<xsl:with-param name="iStackIdx" select="@EAST"/>
</xsl:call-template>
</xsl:variable>
<BLW HEIGHT="{$stack_height_}"/>
</xsl:for-each>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/BCLANESPACES/BCLANESPACE[(@WEST = ($G_ROOT/EDKSYSTEM/BLKDIAGRAM/@STACK_HORIZ_WIDTH -1))]">
<!--
<xsl:message>Last stack of index <xsl:value-of select="@WEST"/></xsl:message>
-->
<xsl:variable name="stack_height_">
<xsl:call-template name="F_Calc_Stack_BlwSbs_Height">
<xsl:with-param name="iStackIdx" select="@WEST"/>
</xsl:call-template>
</xsl:variable>
<BLW HEIGHT="{$stack_height_}"/>
</xsl:for-each>
</xsl:variable>
<!--
<xsl:message>Found Blw Sbs max as <xsl:value-of select="math:max(exsl:node-set($blwSbs_heights_)/BLW/@HEIGHT)"/></xsl:message>
-->
<!-- Return the max of them -->
<xsl:value-of select="math:max(exsl:node-set($blwSbs_heights_)/BLW/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_Max_Stack_AbvSbs_Height">
<!-- Store the heights in a variable -->
<xsl:variable name="abvSbs_heights_">
<!-- Default, in case there are no modules or ports -->
<ABV HEIGHT="0"/>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/BCLANESPACES/BCLANESPACE[(@EAST &lt; $G_ROOT/EDKSYSTEM/BLKDIAGRAM/@STACK_HORIZ_WIDTH)]">
<!--
<xsl:message>Found a space of index <xsl:value-of select="@EAST"/></xsl:message>
-->
<xsl:variable name="stack_height_">
<xsl:call-template name="F_Calc_Stack_AbvSbs_Height">
<xsl:with-param name="iStackIdx" select="@EAST"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Found stack of width <xsl:value-of select="$stack_width_"/></xsl:message>
<xsl:message>==============================</xsl:message>
-->
<ABV HEIGHT="{$stack_height_}"/>
</xsl:for-each>
</xsl:variable>
<!--
<xsl:message>Found Blw Sbs max as <xsl:value-of select="math:max(exsl:node-set($blwSbs_heights_)/BLW/@HEIGHT)"/></xsl:message>
-->
<!-- Return the max of them -->
<xsl:value-of select="math:max(exsl:node-set($abvSbs_heights_)/ABV/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_MultiProc_Stack_Height">
<xsl:param name="iMPStack_Blkd_X" select="100"/>
<xsl:variable name="mpStk_ShpHeights_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@HAS_MULTIPROCCONNS) and (@PSTACK_BLKD_X = $iMPStack_Blkd_X))])">
<MPSHAPE HEIGHT="0"/>
</xsl:if>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@HAS_MULTIPROCCONNS) and (@PSTACK_BLKD_X = $iMPStack_Blkd_X))]">
<xsl:variable name="shpClass_" select="@MODCLASS"/>
<xsl:variable name="shpHeight_">
<xsl:choose>
<xsl:when test="$shpClass_ = 'PERIPHERAL'">
<!--
<xsl:message>Found Multi Proc Peripheral</xsl:message>
-->
<xsl:call-template name="F_Calc_PeriShape_Height">
<xsl:with-param name="iShapeInst" select="MODULE/@INSTANCE"/>
</xsl:call-template>
</xsl:when>
<xsl:when test="$shpClass_ = 'MEMORY_UNIT'">
<!--
<xsl:message>Found Multi Proc Memory Unit</xsl:message>
-->
<xsl:call-template name="F_Calc_MemoryUnit_Height">
<xsl:with-param name="iShapeIndex" select="@CSHAPE_INDEX"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>0</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<!--
<xsl:message>Found <xsl:value-of select="$shpHeight_"/></xsl:message>
-->
<MPSHAPE HEIGHT="{$shpHeight_}"/>
</xsl:for-each>
</xsl:variable>
<!--
<xsl:message>Found stack of height <xsl:value-of select="sum(exsl:node-set($mpStk_ShpHeights_)/MPSHAPE/@HEIGHT)"/></xsl:message>
-->
<xsl:value-of select="sum(exsl:node-set($mpStk_ShpHeights_)/MPSHAPE/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_Max_MultiProc_Stack_Height">
<!-- Store the heights in a variable -->
<xsl:variable name="mpStks_Heights_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE)">
<MPSTK HEIGHT="0"/>
</xsl:if>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[(@PSTACK_BLKD_X)]">
<xsl:variable name="mpstack_height_">
<xsl:call-template name="F_Calc_MultiProc_Stack_Height">
<xsl:with-param name="iMPStack_Blkd_X" select="(@PSTACK_BLKD_X + 1)"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Found <xsl:value-of select="$mpstack_height_"/></xsl:message>
-->
<MPSTK HEIGHT="{$mpstack_height_}"/>
</xsl:for-each>
</xsl:variable>
<!-- Return the max of them -->
<xsl:value-of select="math:max(exsl:node-set($mpStks_Heights_)/MPSTK/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_Stack_Shape_Y">
<xsl:param name="iHorizIdx" select="100"/>
<xsl:param name="iVertiIdx" select="100"/>
<!--
<xsl:param name="sbsGap" select="0"/>
<xsl:variable name="numSBSs_" select="count($G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSSHAPES/MODULE)"/>
<xsl:variable name="sbs_LANE_H_" select="($numSBSs_ * $BLKD_SBS_LANE_H)"/>
<xsl:variable name="sbsGap_" select="($BLKD_PROC2SBS_GAP + $sbs_LANE_H_)"/>
-->
<xsl:variable name="sbsGap_" select="((count($G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSSHAPES/MODULE) * $BLKD_SBS_LANE_H) + $BLKD_PROC2SBS_GAP)"/>
<xsl:if test="(not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iHorizIdx) and ((@SHAPE_VERTI_INDEX = $iVertiIdx) or ($iVertiIdx = 100)))]) and
not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSBUCKETS/SBSBUCKET[( (@STACK_HORIZ_INDEX = $iHorizIdx) and ((@SHAPE_VERTI_INDEX = $iVertiIdx) or ($iVertiIdx = 100)))]) and
not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[( (@STACK_HORIZ_INDEX = $iHorizIdx) and ((@SHAPE_VERTI_INDEX = $iVertiIdx) or ($iVertiIdx = 100)))]))">0</xsl:if>
<!--
<xsl:if test="(not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iHorizIdx) and ((@SHAPE_VERTI_INDEX = $iVertiIdx) or ($iVertiIdx = 100)))]) and
not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSBUCKETS/SBSBUCKET[( (@STACK_HORIZ_INDEX = $iHorizIdx) and ((@SHAPE_VERTI_INDEX = $iVertiIdx) or ($iVertiIdx = 100)))]) and
not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[( (@STACK_HORIZ_INDEX = $iHorizIdx) and ((@SHAPE_VERTI_INDEX = $iVertiIdx) or ($iVertiIdx = 100)))]))">
<xsl:message>Something is missing </xsl:message>
</xsl:if>
-->
<xsl:if test="(($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iHorizIdx) and ((@SHAPE_VERTI_INDEX = $iVertiIdx) or ($iVertiIdx = 100)))]) or
($G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSBUCKETS/SBSBUCKET[( (@STACK_HORIZ_INDEX = $iHorizIdx) and ((@SHAPE_VERTI_INDEX = $iVertiIdx) or ($iVertiIdx = 100)))]) or
($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[( (@STACK_HORIZ_INDEX = $iHorizIdx) and ((@SHAPE_VERTI_INDEX = $iVertiIdx) or ($iVertiIdx = 100)))]))">
<!-- Store the spaces above this one in a variable -->
<xsl:variable name="spaces_above_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iHorizIdx) and (@SHAPE_VERTI_INDEX &lt; $iVertiIdx))])">
<SPACE HEIGHT="0"/>
</xsl:if>
<!-- Store the height of all peripherals and memory units above this one-->
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iHorizIdx) and (@SHAPE_VERTI_INDEX &lt; $iVertiIdx))]">
<xsl:if test="not(@MODCLASS='MEMORY_UNIT')">
<xsl:variable name="peri_height_">
<xsl:call-template name="F_Calc_Shape_Height">
<xsl:with-param name="iShapeId" select="@SHAPE_ID"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Found peri height <xsl:value-of select="$peri_height_"/></xsl:message>
-->
<SPACE HEIGHT="{$peri_height_ + $BLKD_BIF_H}"/>
</xsl:if>
<xsl:if test="(@MODCLASS='MEMORY_UNIT')">
<xsl:variable name="memu_height_">
<xsl:call-template name="F_Calc_MemoryUnit_Height">
<xsl:with-param name="iShapeId" select="@SHAPE_ID"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Found unit height <xsl:value-of select="$memu_height_"/></xsl:message>
-->
<SPACE HEIGHT="{$memu_height_ + $BLKD_BIF_H}"/>
</xsl:if>
</xsl:for-each>
<!-- Store the height of all the processors above this one-->
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[((@STACK_HORIZ_INDEX = $iHorizIdx) and (@SHAPE_VERTI_INDEX &lt; $iVertiIdx))]">
<xsl:variable name="proc_height_">
<xsl:call-template name="F_Calc_PeriShape_Height">
<xsl:with-param name="iShapeInst" select="@INSTANCE"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Found Proc height <xsl:value-of select="$proc_height_ + $BLKD_BIF_H"/></xsl:message>
-->
<SPACE HEIGHT="{$proc_height_ + $BLKD_BIF_H}"/>
</xsl:for-each>
<!-- If its a peripheral that is below the shared busses, or its a shared bus bucket -->
<!-- add the height of the shared busses and the processor. -->
<xsl:if test="($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[((@STACK_HORIZ_INDEX = $iHorizIdx) and (@SHAPE_VERTI_INDEX = $iVertiIdx))]/@IS_BLWSBS)">
<SPACE HEIGHT="{$sbsGap_}"/>
</xsl:if>
<xsl:if test="($G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSBUCKETS/SBSBUCKET[((@STACK_HORIZ_INDEX = $iHorizIdx) and (@SHAPE_VERTI_INDEX = $iVertiIdx))])">
<SPACE HEIGHT="{$sbsGap_}"/>
</xsl:if>
<!-- Store the height of all shared bus buckets above this one-->
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSBUCKETS/SBSBUCKET[((@STACK_HORIZ_INDEX = $iHorizIdx) and (@SHAPE_VERTI_INDEX &lt; $iVertiIdx))]">
<xsl:variable name="bkt_height_">
<xsl:call-template name="F_Calc_SbsBucket_Height">
<xsl:with-param name="iBucketId" select="@BUS_INDEX"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Found bucket height <xsl:value-of select="$bkt_height_ + $BLKD_BIF_H"/></xsl:message>
-->
<SPACE HEIGHT="{$bkt_height_ + $BLKD_BIF_H}"/>
</xsl:for-each>
</xsl:variable>
<xsl:value-of select="sum(exsl:node-set($spaces_above_)/SPACE/@HEIGHT)"/>
</xsl:if>
</xsl:template>
<xsl:template name="F_Calc_Max_BusConnLane_BifY">
<xsl:param name="iBusName" select="'_busname_'"/>
<!-- Store the heights in a variable -->
<xsl:variable name="busConnYs_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE/BUSCONNS/BUSCONNLANE/BUSCONN)">
<BUSCONNY HEIGHT="0"/>
</xsl:if>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE/BUSCONNS/BUSCONNLANE[(@BUSNAME = $iBusName)]/BUSCONN">
<xsl:variable name="peri_cstk_y_">
<xsl:call-template name="F_Calc_CStackShapesAbv_Height">
<xsl:with-param name="iCStackIndex" select="../@CSTACK_INDEX"/>
<xsl:with-param name="ICStackModY" select="@CSTACK_MODS_Y"/>
</xsl:call-template>
</xsl:variable>
<xsl:variable name="peri_bif_dy_">
<xsl:value-of select="(($BLKD_BIF_H + $BLKD_MOD_BIF_GAP_H) * @BIF_Y)"/>
</xsl:variable>
<xsl:variable name="peri_bc_y_">
<xsl:value-of select="($BLKD_MOD_LANE_H + $BLKD_MOD_LABEL_H + $BLKD_MOD_BIF_GAP_H + $peri_bif_dy_ + ceiling($BLKD_BIF_H div 2)) - ceiling($BLKD_BIFC_H div 2)"/>
</xsl:variable>
<!--
<xsl:message>Found a busconn lane</xsl:message>
-->
<BUSCONNY HEIGHT="{$peri_cstk_y_ + $peri_bif_dy_ + $peri_bc_y_}"/>
</xsl:for-each>
</xsl:variable>
<!-- Return the max of them -->
<xsl:value-of select="math:max(exsl:node-set($busConnYs_)/BUSCONNY/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_Min_BusConnLane_BifY">
<xsl:param name="iBusName" select="'_busname_'"/>
<!-- Store the heights in a variable -->
<xsl:variable name="busConnYs_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE/BUSCONNS/BUSCONNLANE/BUSCONN)">
<BUSCONNY HEIGHT="0"/>
</xsl:if>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE/BUSCONNS/BUSCONNLANE[(@BUSNAME = $iBusName)]/BUSCONN">
<xsl:variable name="peri_cstk_y_">
<xsl:call-template name="F_Calc_CStackShapesAbv_Height">
<xsl:with-param name="iCStackIndex" select="../@CSTACK_INDEX"/>
<xsl:with-param name="iCStackModY" select="@CSTACK_MODS_Y"/>
</xsl:call-template>
</xsl:variable>
<xsl:variable name="peri_bif_dy_">
<xsl:value-of select="(($BLKD_BIF_H + $BLKD_MOD_BIF_GAP_H) * @BIF_Y)"/>
</xsl:variable>
<xsl:variable name="peri_bc_y_">
<xsl:value-of select="($BLKD_MOD_LANE_H + $BLKD_MOD_LABEL_H + $BLKD_MOD_BIF_GAP_H + $peri_bif_dy_ + ceiling($BLKD_BIF_H div 2)) - ceiling($BLKD_BIFC_H div 2)"/>
</xsl:variable>
<!--
<xsl:message>Found a busconn lane</xsl:message>
-->
<BUSCONNY HEIGHT="{$peri_cstk_y_ + $peri_bc_y_}"/>
</xsl:for-each>
</xsl:variable>
<!-- Return the min of them -->
<xsl:value-of select="math:min(exsl:node-set($busConnYs_)/BUSCONNY/@HEIGHT)"/>
</xsl:template>
<xsl:template name="F_Calc_Stack_Height">
<xsl:param name="iStackIdx" select="100"/>
<!--
<xsl:message>Calculating height for Stack Index <xsl:value-of select="$iStackIdx"/></xsl:message>
-->
<xsl:variable name="stack_height_">
<!-- if this is called with no vert index of a shape
it defaults to the total height of the stack -->
<xsl:call-template name="F_Calc_Stack_Shape_Y">
<xsl:with-param name="iHorizIdx" select="$iStackIdx"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Calculated height for Stack as <xsl:value-of select="$stack_height_"/></xsl:message>
-->
<xsl:value-of select="$stack_height_"/>
</xsl:template>
<!--
-->
<xsl:template name="F_Calc_Stack_Width">
<xsl:param name="iStackIdx" select="100"/>
<!--
<xsl:message>=============Stack Idx <xsl:value-of select="$iStackIdx"/>====</xsl:message>
-->
<xsl:variable name="shape_widths_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[@STACK_HORIZ_INDEX = $iStackIdx])">
<SHAPE WIDTH="0"/>
</xsl:if>
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[@STACK_HORIZ_INDEX = $iStackIdx])">
<SHAPE WIDTH="0"/>
</xsl:if>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES/MODULE[(@STACK_HORIZ_INDEX = $iStackIdx)]">
<!--
<xsl:variable name="proc_w_">
<xsl:value-of select="$BLKD_MOD_W"/>
</xsl:variable>
<xsl:message>Found processor of width <xsl:value-of select="$proc_w_"/></xsl:message>
-->
<SHAPE WIDTH="{$BLKD_MOD_W}"/>
</xsl:for-each>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES/CMPLXSHAPE[(@STACK_HORIZ_INDEX = $iStackIdx)]">
<xsl:variable name="shpClass_" select="@MODCLASS"/>
<xsl:variable name="shape_w_">
<xsl:choose>
<xsl:when test="$shpClass_ = 'PERIPHERAL'">
<xsl:value-of select="$BLKD_MOD_W"/>
</xsl:when>
<xsl:when test="$shpClass_ = 'MEMORY_UNIT'">
<xsl:value-of select="($BLKD_MOD_W * @MODS_W)"/>
</xsl:when>
<xsl:otherwise>0</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<!--
<xsl:message>Found shape width <xsl:value-of select="$shape_w_"/></xsl:message>
-->
<SHAPE WIDTH="{$shape_w_}"/>
</xsl:for-each>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/SBSBUCKETS/SBSBUCKET[(@STACK_HORIZ_INDEX = $iStackIdx)]">
<xsl:variable name="bucket_w_">
<xsl:value-of select="(($BLKD_MOD_BKTLANE_W * 2) + (($BLKD_MOD_W * @MODS_W) + ($BLKD_MOD_BUCKET_G * (@MODS_W - 1))))"/>
</xsl:variable>
<!--
<xsl:message>Found bucket of width <xsl:value-of select="$bucket_w_"/></xsl:message>
-->
<SHAPE WIDTH="{$bucket_w_}"/>
</xsl:for-each>
</xsl:variable>
<xsl:value-of select="math:max(exsl:node-set($shape_widths_)/SHAPE/@WIDTH)"/>
</xsl:template>
<xsl:template name="F_Calc_Stack_X">
<xsl:param name="iStackIdx" select="0"/>
<!--
<xsl:message>Looking for stack indexes less than <xsl:value-of select="$iStackIdx"/></xsl:message>
-->
<!-- Store the stack widths in a variable -->
<xsl:variable name="stackspace_widths_">
<xsl:if test="($G_ROOT/EDKSYSTEM/BLKDIAGRAM/@STACK_HORIZ_WIDTH = $iStackIdx)">
<STACKSPACE WIDTH="{$BLKD_BUS_LANE_W}"/>
</xsl:if>
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES[(@STACK_HORIZ_INDEX &lt; $iStackIdx)])">
<STACKSPACE WIDTH="0"/>
</xsl:if>
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES[(@STACK_HORIZ_INDEX &lt; $iStackIdx)])">
<STACKSPACE WIDTH="0"/>
</xsl:if>
<xsl:if test="not($G_ROOT/EDKSYSTEM/SBSBUCKETS/SBSBUCKET[(@STACK_HORIZ_INDEX &lt; $iStackIdx)])">
<STACKSPACE WIDTH="0"/>
</xsl:if>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/BCLANESPACES/BCLANESPACE[(@EAST &lt;= $iStackIdx)]">
<!--
<xsl:message>==============================</xsl:message>
<xsl:message>Found a space of index <xsl:value-of select="@EAST"/></xsl:message>
<xsl:message>Bus lane space width <xsl:value-of select="@BUSLANES_W"/></xsl:message>
<xsl:message>Bus lane space is <xsl:value-of select="$space_width_"/></xsl:message>
<xsl:variable name="space_width_" select="($BLKD_BUS_LANE_W * @BUSLANES_W)"/>
-->
<xsl:variable name="East_">
<xsl:choose>
<xsl:when test="@EAST"><xsl:value-of select="@EAST"/></xsl:when>
<xsl:otherwise>'NONE'</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:variable name="West_">
<xsl:choose>
<xsl:when test="@WEST"><xsl:value-of select="@WEST"/></xsl:when>
<xsl:otherwise>NONE</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<!--
<xsl:message>1 - West_ <xsl:value-of select="$West_"/></xsl:message>
<xsl:message>1 - East_ <xsl:value-of select="$East_"/></xsl:message>
-->
<xsl:variable name="space_width_">
<xsl:call-template name="F_Calc_Space_Width">
<xsl:with-param name="iStackToWest" select="$West_"/>
<xsl:with-param name="iStackToEast" select="$East_"/>
</xsl:call-template>
</xsl:variable>
<xsl:variable name="stack_width_">
<xsl:if test="not(@EAST = $iStackIdx)">
<xsl:call-template name="F_Calc_Stack_Width">
<xsl:with-param name="iStackIdx" select="@EAST"/>
</xsl:call-template>
</xsl:if>
<xsl:if test="(@EAST = $iStackIdx)">0</xsl:if>
</xsl:variable>
<!--
<xsl:message>Found stack of width <xsl:value-of select="$stack_width_"/></xsl:message>
<xsl:message>==============================</xsl:message>
-->
<STACKSPACE WIDTH="{$stack_width_ + $space_width_}"/>
</xsl:for-each>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/BCLANESPACES/BCLANESPACE[(not(@EAST) and (@WEST = ($iStackIdx -1)))]">
<xsl:variable name="space_width_" select="($BLKD_BUS_LANE_W * @BUSLANES_W)"/>
<!--
<xsl:message>Found end space of <xsl:value-of select="$space_width_"/></xsl:message>
-->
<STACKSPACE WIDTH="{$space_width_}"/>
</xsl:for-each>
</xsl:variable>
<xsl:value-of select="sum(exsl:node-set($stackspace_widths_)/STACKSPACE/@WIDTH)"/>
</xsl:template>
<xsl:template name="F_Calc_Space_Width">
<xsl:param name="iStackToWest" select="'NONE'"/>
<xsl:param name="iStackToEast" select="'NONE'"/>
<!--
<xsl:message>Stack to West <xsl:value-of select="$stackToWest"/></xsl:message>
<xsl:message>Stack to East <xsl:value-of select="$stackToEast"/></xsl:message>
-->
<xsl:variable name="spaceWidth_">
<xsl:choose>
<xsl:when test="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/BCLANESPACES/BCLANESPACE[((@EAST = $iStackToEast) or (not($iStackToWest = 'NONE') and (@WEST = $iStackToWest)))]">
<xsl:value-of select="((($G_ROOT/EDKSYSTEM/BLKDIAGRAM/BCLANESPACES/BCLANESPACE[((@EAST = $iStackToEast) or (not($iStackToWest = 'NONE') and (@WEST = $iStackToWest)))]/@BUSLANES_W) + 1) * $BLKD_BUS_LANE_W)"/>
</xsl:when>
<xsl:otherwise>0</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<!--
<xsl:message>Space width <xsl:value-of select="$spaceWidth_"/></xsl:message>
-->
<xsl:value-of select="$spaceWidth_"/>
</xsl:template>
<xsl:template name="F_Calc_Space_X">
<xsl:param name="iStackToWest" select="'NONE'"/>
<xsl:param name="iStackToEast" select="'NONE'"/>
<!--
<xsl:message>Stack East <xsl:value-of select="$stackToEast"/></xsl:message>
<xsl:message>Stack West <xsl:value-of select="$stackToWest"/></xsl:message>
-->
<!-- Store the stack widths in a variable -->
<!--
<xsl:message>Looking for stack indexes less than <xsl:value-of select="$stackIdx"/></xsl:message>
-->
<xsl:variable name="stackspace_widths_">
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/CMPLXSHAPES[(@STACK_HORIZ_INDEX &lt; $iStackToEast)])">
<STACKSPACE WIDTH="0"/>
</xsl:if>
<xsl:if test="not($G_ROOT/EDKSYSTEM/BLKDIAGRAM/PROCSHAPES[(@STACK_HORIZ_INDEX &lt; $iStackToEast)])">
<STACKSPACE WIDTH="0"/>
</xsl:if>
<xsl:if test="not($G_ROOT/EDKSYSTEM/SBSBUCKETS/SBSBUCKET[(@STACK_HORIZ_INDEX &lt; $iStackToEast)])">
<STACKSPACE WIDTH="0"/>
</xsl:if>
<xsl:for-each select="$G_ROOT/EDKSYSTEM/BLKDIAGRAM/BCLANESPACES/BCLANESPACE[((@EAST &lt; $iStackToEast) or (not($iStackToWest = 'NONE') and (@EAST &lt;= $iStackToWest)))]">
<!--
<xsl:message>==============================</xsl:message>
<xsl:message>Found a space of index <xsl:value-of select="@EAST"/></xsl:message>
-->
<xsl:variable name="East_">
<xsl:choose>
<xsl:when test="@EAST"><xsl:value-of select="@EAST"/></xsl:when>
<xsl:otherwise>'NONE'</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:variable name="West_">
<xsl:choose>
<xsl:when test="@WEST"><xsl:value-of select="@WEST"/></xsl:when>
<xsl:otherwise>NONE</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<!--
<xsl:message>2 - West_ <xsl:value-of select="$West_"/></xsl:message>
<xsl:message>2 - East_ <xsl:value-of select="$East_"/></xsl:message>
-->
<xsl:variable name="space_width_">
<xsl:call-template name="F_Calc_Space_Width">
<xsl:with-param name="iStackToWest" select="$West_"/>
<xsl:with-param name="iStackToEast" select="$East_"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:variable name="space_width_" select="($BLKD_BUS_LANE_W * @BUSLANES_W)"/>
<xsl:message>Bus lane space width <xsl:value-of select="@BUSLANES_W"/></xsl:message>
<xsl:message>Bus lane space is <xsl:value-of select="$space_width_"/></xsl:message>
-->
<xsl:variable name="stack_width_">
<xsl:call-template name="F_Calc_Stack_Width">
<xsl:with-param name="iStackIdx" select="@EAST"/>
</xsl:call-template>
</xsl:variable>
<!--
<xsl:message>Found stack of width <xsl:value-of select="$stack_width_"/></xsl:message>
<xsl:message>==============================</xsl:message>
-->
<STACKSPACE WIDTH="{$stack_width_ + $space_width_}"/>
</xsl:for-each>
</xsl:variable>
<xsl:variable name = "stackToWest_W_">
<xsl:choose>
<xsl:when test="(($iStackToEast = '0') and ($iStackToWest = 'NONE'))">0</xsl:when>
<xsl:when test="(($iStackToEast = 'NONE') and not($iStackToWest = 'NONE'))">
<xsl:call-template name="F_Calc_Stack_Width">
<xsl:with-param name="iStackIdx" select="$iStackToWest"/>
</xsl:call-template>
</xsl:when>
<xsl:when test="(not($iStackToEast = '0') and ($iStackToWest = 'NONE'))">
<xsl:call-template name="F_Calc_Stack_Width">
<xsl:with-param name="iStackIdx" select="($iStackToEast - 1)"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>0</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<!--
<xsl:variable name = "stackToEast_W_">
<xsl:call-template name="F_Calc_Stack_Width">
<xsl:with-param name="stackIdx" select="$stackToEast"/>
</xsl:call-template>
</xsl:variable>
<xsl:variable name ="extSpaceEast_W_" select="ceiling($stackToEast_W_ div 2)"/>
-->
<xsl:variable name ="extSpaceWest_W_" select="ceiling($stackToWest_W_ div 2)"/>
<xsl:value-of select="sum(exsl:node-set($stackspace_widths_)/STACKSPACE/@WIDTH) - $extSpaceWest_W_"/>
</xsl:template>
</xsl:stylesheet>