< prev index next >

src/hotspot/share/ci/ciField.hpp

Print this page

 27 
 28 #include "ci/ciClassList.hpp"
 29 #include "ci/ciConstant.hpp"
 30 #include "ci/ciFlags.hpp"
 31 #include "ci/ciInstance.hpp"
 32 #include "ci/ciUtilities.hpp"
 33 
 34 // ciField
 35 //
 36 // This class represents the result of a field lookup in the VM.
 37 // The lookup may not succeed, in which case the information in
 38 // the ciField will be incomplete.
 39 class ciField : public ArenaObj {
 40   CI_PACKAGE_ACCESS
 41   friend class ciEnv;
 42   friend class ciInstanceKlass;
 43 
 44 private:
 45   ciFlags          _flags;
 46   ciInstanceKlass* _holder;

 47   ciSymbol*        _name;
 48   ciSymbol*        _signature;
 49   ciType*          _type;
 50   int              _offset;
 51   bool             _is_constant;


 52   ciMethod*        _known_to_link_with_put;
 53   ciInstanceKlass* _known_to_link_with_get;
 54   ciConstant       _constant_value;
 55 
 56   ciType* compute_type();
 57   ciType* compute_type_impl();
 58 
 59   ciField(ciInstanceKlass* klass, int index, Bytecodes::Code bc);
 60   ciField(fieldDescriptor* fd);

 61 
 62   // shared constructor code
 63   void initialize_from(fieldDescriptor* fd);
 64 
 65 public:
 66   ciFlags flags() const { return _flags; }
 67 
 68   // Of which klass is this field a member?
 69   //
 70   // Usage note: the declared holder of a field is the class
 71   // referenced by name in the bytecodes.  The canonical holder
 72   // is the most general class which holds the field.  This
 73   // method returns the canonical holder.  The declared holder
 74   // can be accessed via a method in ciBytecodeStream.
 75   //
 76   // Ex.
 77   //     class A {
 78   //       public int f = 7;
 79   //     }
 80   //     class B extends A {

152   // Check for link time errors.  Accessing a field from a
153   // certain method via a certain bytecode may or may not be legal.
154   // This call checks to see if an exception may be raised by
155   // an access of this field.
156   //
157   // Usage note: if the same field is accessed multiple times
158   // in the same compilation, will_link will need to be checked
159   // at each point of access.
160   bool will_link(ciMethod* accessing_method,
161                  Bytecodes::Code bc);
162 
163   // Java access flags
164   bool is_public               () const { return flags().is_public(); }
165   bool is_private              () const { return flags().is_private(); }
166   bool is_protected            () const { return flags().is_protected(); }
167   bool is_static               () const { return flags().is_static(); }
168   bool is_final                () const { return flags().is_final(); }
169   bool is_stable               () const { return flags().is_stable(); }
170   bool is_volatile             () const { return flags().is_volatile(); }
171   bool is_transient            () const { return flags().is_transient(); }



172   // The field is modified outside of instance initializer methods
173   // (or class/initializer methods if the field is static).
174   bool has_initialized_final_update() const { return flags().has_initialized_final_update(); }
175 
176   bool is_call_site_target();
177 
178   bool is_autobox_cache();
179 
180   // Debugging output
181   void print();
182   void print_name_on(outputStream* st);
183 };
184 
185 #endif // SHARE_CI_CIFIELD_HPP

 27 
 28 #include "ci/ciClassList.hpp"
 29 #include "ci/ciConstant.hpp"
 30 #include "ci/ciFlags.hpp"
 31 #include "ci/ciInstance.hpp"
 32 #include "ci/ciUtilities.hpp"
 33 
 34 // ciField
 35 //
 36 // This class represents the result of a field lookup in the VM.
 37 // The lookup may not succeed, in which case the information in
 38 // the ciField will be incomplete.
 39 class ciField : public ArenaObj {
 40   CI_PACKAGE_ACCESS
 41   friend class ciEnv;
 42   friend class ciInstanceKlass;
 43 
 44 private:
 45   ciFlags          _flags;
 46   ciInstanceKlass* _holder;
 47   ciInstanceKlass* _original_holder; // For fields nested in flat fields
 48   ciSymbol*        _name;
 49   ciSymbol*        _signature;
 50   ciType*          _type;
 51   int              _offset;
 52   bool             _is_constant;
 53   bool             _is_flat;
 54   bool             _is_null_free;
 55   ciMethod*        _known_to_link_with_put;
 56   ciInstanceKlass* _known_to_link_with_get;
 57   ciConstant       _constant_value;
 58 
 59   ciType* compute_type();
 60   ciType* compute_type_impl();
 61 
 62   ciField(ciInstanceKlass* klass, int index, Bytecodes::Code bc);
 63   ciField(fieldDescriptor* fd);
 64   ciField(ciField* field, ciInstanceKlass* holder, int offset, bool is_final);
 65 
 66   // shared constructor code
 67   void initialize_from(fieldDescriptor* fd);
 68 
 69 public:
 70   ciFlags flags() const { return _flags; }
 71 
 72   // Of which klass is this field a member?
 73   //
 74   // Usage note: the declared holder of a field is the class
 75   // referenced by name in the bytecodes.  The canonical holder
 76   // is the most general class which holds the field.  This
 77   // method returns the canonical holder.  The declared holder
 78   // can be accessed via a method in ciBytecodeStream.
 79   //
 80   // Ex.
 81   //     class A {
 82   //       public int f = 7;
 83   //     }
 84   //     class B extends A {

156   // Check for link time errors.  Accessing a field from a
157   // certain method via a certain bytecode may or may not be legal.
158   // This call checks to see if an exception may be raised by
159   // an access of this field.
160   //
161   // Usage note: if the same field is accessed multiple times
162   // in the same compilation, will_link will need to be checked
163   // at each point of access.
164   bool will_link(ciMethod* accessing_method,
165                  Bytecodes::Code bc);
166 
167   // Java access flags
168   bool is_public               () const { return flags().is_public(); }
169   bool is_private              () const { return flags().is_private(); }
170   bool is_protected            () const { return flags().is_protected(); }
171   bool is_static               () const { return flags().is_static(); }
172   bool is_final                () const { return flags().is_final(); }
173   bool is_stable               () const { return flags().is_stable(); }
174   bool is_volatile             () const { return flags().is_volatile(); }
175   bool is_transient            () const { return flags().is_transient(); }
176   bool is_flat                 () const { return _is_flat; }
177   bool is_null_free            () const { return _is_null_free; }
178 
179   // The field is modified outside of instance initializer methods
180   // (or class/initializer methods if the field is static).
181   bool has_initialized_final_update() const { return flags().has_initialized_final_update(); }
182 
183   bool is_call_site_target();
184 
185   bool is_autobox_cache();
186 
187   // Debugging output
188   void print();
189   void print_name_on(outputStream* st);
190 };
191 
192 #endif // SHARE_CI_CIFIELD_HPP
< prev index next >