26 #define SHARE_VM_CODE_PCDESC_HPP
27
28 #include "memory/allocation.hpp"
29
30 // PcDescs map a physical PC (given as offset from start of nmethod) to
31 // the corresponding source scope and byte code index.
32
33 class CompiledMethod;
34
35 class PcDesc VALUE_OBJ_CLASS_SPEC {
36 friend class VMStructs;
37 private:
38 int _pc_offset; // offset from start of nmethod
39 int _scope_decode_offset; // offset for scope in nmethod
40 int _obj_decode_offset;
41
42 enum {
43 PCDESC_reexecute = 1 << 0,
44 PCDESC_is_method_handle_invoke = 1 << 1,
45 PCDESC_return_oop = 1 << 2,
46 PCDESC_rethrow_exception = 1 << 3
47 };
48
49 int _flags;
50
51 void set_flag(int mask, bool z) {
52 _flags = z ? (_flags | mask) : (_flags & ~mask);
53 }
54
55 public:
56 int pc_offset() const { return _pc_offset; }
57 int scope_decode_offset() const { return _scope_decode_offset; }
58 int obj_decode_offset() const { return _obj_decode_offset; }
59
60 void set_pc_offset(int x) { _pc_offset = x; }
61 void set_scope_decode_offset(int x) { _scope_decode_offset = x; }
62 void set_obj_decode_offset(int x) { _obj_decode_offset = x; }
63
64 // Constructor (only used for static in nmethod.cpp)
65 // Also used by ScopeDesc::sender()]
66 PcDesc(int pc_offset, int scope_decode_offset, int obj_decode_offset);
72 };
73
74 // Flags
75 bool rethrow_exception() const { return (_flags & PCDESC_rethrow_exception) != 0; }
76 void set_rethrow_exception(bool z) { set_flag(PCDESC_rethrow_exception, z); }
77 bool should_reexecute() const { return (_flags & PCDESC_reexecute) != 0; }
78 void set_should_reexecute(bool z) { set_flag(PCDESC_reexecute, z); }
79
80 // Does pd refer to the same information as pd?
81 bool is_same_info(const PcDesc* pd) {
82 return _scope_decode_offset == pd->_scope_decode_offset &&
83 _obj_decode_offset == pd->_obj_decode_offset &&
84 _flags == pd->_flags;
85 }
86
87 bool is_method_handle_invoke() const { return (_flags & PCDESC_is_method_handle_invoke) != 0; }
88 void set_is_method_handle_invoke(bool z) { set_flag(PCDESC_is_method_handle_invoke, z); }
89
90 bool return_oop() const { return (_flags & PCDESC_return_oop) != 0; }
91 void set_return_oop(bool z) { set_flag(PCDESC_return_oop, z); }
92
93 // Returns the real pc
94 address real_pc(const CompiledMethod* code) const;
95
96 void print(CompiledMethod* code);
97 bool verify(CompiledMethod* code);
98 };
99
100 #endif // SHARE_VM_CODE_PCDESC_HPP
|
26 #define SHARE_VM_CODE_PCDESC_HPP
27
28 #include "memory/allocation.hpp"
29
30 // PcDescs map a physical PC (given as offset from start of nmethod) to
31 // the corresponding source scope and byte code index.
32
33 class CompiledMethod;
34
35 class PcDesc VALUE_OBJ_CLASS_SPEC {
36 friend class VMStructs;
37 private:
38 int _pc_offset; // offset from start of nmethod
39 int _scope_decode_offset; // offset for scope in nmethod
40 int _obj_decode_offset;
41
42 enum {
43 PCDESC_reexecute = 1 << 0,
44 PCDESC_is_method_handle_invoke = 1 << 1,
45 PCDESC_return_oop = 1 << 2,
46 PCDESC_rethrow_exception = 1 << 3,
47 PCDESC_return_vt = 1 << 4,
48 };
49
50 int _flags;
51
52 void set_flag(int mask, bool z) {
53 _flags = z ? (_flags | mask) : (_flags & ~mask);
54 }
55
56 public:
57 int pc_offset() const { return _pc_offset; }
58 int scope_decode_offset() const { return _scope_decode_offset; }
59 int obj_decode_offset() const { return _obj_decode_offset; }
60
61 void set_pc_offset(int x) { _pc_offset = x; }
62 void set_scope_decode_offset(int x) { _scope_decode_offset = x; }
63 void set_obj_decode_offset(int x) { _obj_decode_offset = x; }
64
65 // Constructor (only used for static in nmethod.cpp)
66 // Also used by ScopeDesc::sender()]
67 PcDesc(int pc_offset, int scope_decode_offset, int obj_decode_offset);
73 };
74
75 // Flags
76 bool rethrow_exception() const { return (_flags & PCDESC_rethrow_exception) != 0; }
77 void set_rethrow_exception(bool z) { set_flag(PCDESC_rethrow_exception, z); }
78 bool should_reexecute() const { return (_flags & PCDESC_reexecute) != 0; }
79 void set_should_reexecute(bool z) { set_flag(PCDESC_reexecute, z); }
80
81 // Does pd refer to the same information as pd?
82 bool is_same_info(const PcDesc* pd) {
83 return _scope_decode_offset == pd->_scope_decode_offset &&
84 _obj_decode_offset == pd->_obj_decode_offset &&
85 _flags == pd->_flags;
86 }
87
88 bool is_method_handle_invoke() const { return (_flags & PCDESC_is_method_handle_invoke) != 0; }
89 void set_is_method_handle_invoke(bool z) { set_flag(PCDESC_is_method_handle_invoke, z); }
90
91 bool return_oop() const { return (_flags & PCDESC_return_oop) != 0; }
92 void set_return_oop(bool z) { set_flag(PCDESC_return_oop, z); }
93
94 bool return_vt() const { return (_flags & PCDESC_return_vt) != 0; }
95 void set_return_vt(bool z) { set_flag(PCDESC_return_vt, z); }
96
97 // Returns the real pc
98 address real_pc(const CompiledMethod* code) const;
99
100 void print(CompiledMethod* code);
101 bool verify(CompiledMethod* code);
102 };
103
104 #endif // SHARE_VM_CODE_PCDESC_HPP
|