File: UsedRegs.h

package info (click to toggle)
storm-lang 0.7.4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 52,004 kB
  • sloc: ansic: 261,462; cpp: 140,405; sh: 14,891; perl: 9,846; python: 2,525; lisp: 2,504; asm: 860; makefile: 678; pascal: 70; java: 52; xml: 37; awk: 12
file content (59 lines) | stat: -rw-r--r-- 1,287 bytes parent folder | download | duplicates (3)
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
#pragma once
#include "Core/Object.h"
#include "Core/Array.h"
#include "Reg.h"
#include "Listing.h"

namespace code {
	STORM_PKG(core.asm);

	class Arena;

	/**
	 * Computes and tracks the register usage for instructions in a listing. Each entry tracks the
	 * registers that need to be preserved before each instruction. Ignores ptrStack and ptrFrame.
	 */

	class UsedRegs {
		STORM_VALUE;
	public:
		STORM_CTOR UsedRegs(Array<RegSet *> *used, RegSet *all);

		Array<RegSet *> *used;
		RegSet *all;
	};

	// Computes the used registers which needs to be preserved before each instruction in a
	// listing. Ignores ptrStack and ptrFrame.
	UsedRegs STORM_FN usedRegs(MAYBE(const Arena *) arena, const Listing *src);

	// Computes all used registers, without bothering about per-line representations.
	RegSet *STORM_FN allUsedRegs(const Listing *src);


	namespace impl {

		/**
		 * Work-list used internally when computing used registers.
		 */
		class WorkItem : public Object {
			STORM_CLASS;
		public:
			WorkItem(Nat line);
			WorkItem(Nat line, WorkItem *nextDep);

			// Line to start at.
			Nat line;

			// Inside the work-list?
			Bool inWork;

			// Next item in the dependency list.
			WorkItem *nextDep;

			// Next item in the work list.
			WorkItem *nextWork;
		};

	}
}