summaryrefslogtreecommitdiffstats
path: root/zpu/sw/simulator/com/zylin/zpu/stats/Instruction.java
blob: 252dd7f062fcbf62573ef9617ef5fbdc42d73f9e (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
package com.zylin.zpu.stats;

public class Instruction 
{
	public class DumpCycles implements DumpIt
	{
		public int dumpIt(int i)
		{
			return insn[i].cycles;
		}
	}



	public Instruction[] insn=new Instruction[256];
	public int count;
	public int cycles;

	public Instruction addInstruction(int i)
	{
		if (insn[i]==null)
		{
			insn[i]=new Instruction();
		}
		return insn[i];
	}

	/**
	 * Recursive print of statistics
	 */
	public void printStats()
	{
		System.out.println("Count dump");
		DumpIt cDump = new DumpCount();
		printCount("", cDump);
	}

	/**
	 * Recursive print of counts
	 * @param string
	 * @param dumpIt TODO
	 */
	private void printCount(String string, DumpIt dumpIt)
	{
		for (int i=0; i<insn.length; i++)
		{
			if (insn[i]!=null)
			{
				insn[i].printCount(string + ", " + i, dumpIt);
				System.out.println("Count: " + insn[i].count + string + ", " + i);
			}
		}
	}

	class DumpCount implements DumpIt
	{
		public int dumpIt(int i)
		{
			return insn[i].count;
		}
	}
}
OpenPOWER on IntegriCloud