summaryrefslogtreecommitdiffstats
path: root/treemap/convert.xsl
blob: 080bd007f5039e808ad8b3f04f60a50100da039e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:output encoding="UTF-8"/>
<xsl:strip-space elements="*" />
<xsl:preserve-space elements="node" />

<xsl:template match="tree">

    <xsl:if test="@stringID='MAP_MODULE_HIERARCHY'">
        <xsl:apply-templates />
    </xsl:if>

</xsl:template>


<xsl:template match="node">
    
    <xsl:variable name="nodename">
        <xsl:value-of select="@value" />
    </xsl:variable>
    
    <xsl:variable name="nodeslices">
        <xsl:call-template name="slices" />
    </xsl:variable>

    <xsl:variable name="nodeslice_reg">
        <xsl:call-template name="slice_reg" />
    </xsl:variable>

    <xsl:variable name="nodeluts">
        <xsl:call-template name="luts" />
    </xsl:variable>

    <xsl:variable name="nodelutram">
        <xsl:call-template name="lutram" />
    </xsl:variable>

    <xsl:variable name="nodebrams">
        <xsl:call-template name="brams" />
    </xsl:variable>

    <xsl:variable name="nodemul_dsp">
        <xsl:call-template name="mul_dsp" />
    </xsl:variable>

<!--<node name="{$nodename}" size="{$nodeslices}" created="{substring(concat('0000',$nodebrams),1+string-length($nodebrams),4)}-01-01 00:00:00">-->
    <node name="{$nodename}" slices="{$nodeslices}" slice_reg="{$nodeslice_reg}" luts="{$nodeluts}" lutram="{$nodelutram}" brams="{$nodebrams}" mul_dsp="{$nodemul_dsp}">
        <xsl:apply-templates /> 
    </node>

</xsl:template>


<xsl:template name="slices">
    <xsl:for-each select="item">
            <xsl:if test="@stringID='MAP_SLICES'">
                <xsl:value-of select="@value" />
<!--                <xsl:value-of select="@ACCUMULATED" />-->
            </xsl:if>
    </xsl:for-each>
</xsl:template>


<xsl:template name="slice_reg">
    <xsl:for-each select="item">
            <xsl:if test="@stringID='MAP_SLICE_REG'">
                <xsl:value-of select="@value" />
            </xsl:if>
    </xsl:for-each>
</xsl:template>


<xsl:template name="luts">
    <xsl:for-each select="item">
            <xsl:if test="@label='LUTs'">
                <xsl:value-of select="@value" />
            </xsl:if>
    </xsl:for-each>
</xsl:template>


<xsl:template name="lutram">
    <xsl:for-each select="item">
            <xsl:if test="@label='LUTRAM'">
                <xsl:value-of select="@value" />
            </xsl:if>
    </xsl:for-each>
</xsl:template>


<xsl:template name="brams">
    <xsl:for-each select="item">
            <xsl:if test="@stringID='MAP_BRAM' or @stringID='MAP_BRAM_FIFO'">
                <xsl:value-of select="@value" />
            </xsl:if>
    </xsl:for-each>
</xsl:template>


<xsl:template name="mul_dsp">
    <xsl:for-each select="item">
            <xsl:if test="@stringID='MAP_MULT18X18' or @label='DSP48A1'">
                <xsl:value-of select="@value" />
            </xsl:if>
    </xsl:for-each>
</xsl:template>


</xsl:stylesheet>
OpenPOWER on IntegriCloud