< prev index next >

src/hotspot/cpu/x86/macroAssembler_x86.hpp

Print this page

  13  * accompanied this code).
  14  *
  15  * You should have received a copy of the GNU General Public License version
  16  * 2 along with this work; if not, write to the Free Software Foundation,
  17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18  *
  19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20  * or visit www.oracle.com if you need additional information or have any
  21  * questions.
  22  *
  23  */
  24 
  25 #ifndef CPU_X86_MACROASSEMBLER_X86_HPP
  26 #define CPU_X86_MACROASSEMBLER_X86_HPP
  27 
  28 #include "asm/assembler.hpp"
  29 #include "asm/register.hpp"
  30 #include "code/vmreg.inline.hpp"
  31 #include "compiler/oopMap.hpp"
  32 #include "utilities/macros.hpp"

  33 #include "runtime/vm_version.hpp"
  34 #include "utilities/checkedCast.hpp"
  35 


  36 // MacroAssembler extends Assembler by frequently used macros.
  37 //
  38 // Instructions for which a 'better' code sequence exists depending
  39 // on arguments should also go in here.
  40 
  41 class MacroAssembler: public Assembler {
  42   friend class LIR_Assembler;
  43   friend class Runtime1;      // as_Address()
  44 
  45  public:
  46   // Support for VM calls
  47   //
  48   // This is the base routine called by the different versions of call_VM_leaf. The interpreter
  49   // may customize this version by overriding it for its purposes (e.g., to save/restore
  50   // additional registers when doing a VM call).
  51 
  52   virtual void call_VM_leaf_base(
  53     address entry_point,               // the entry point
  54     int     number_of_arguments        // the number of arguments to pop after the call
  55   );

  77  // These routines should emit JVMTI PopFrame and ForceEarlyReturn handling code.
  78  // The implementation is only non-empty for the InterpreterMacroAssembler,
  79  // as only the interpreter handles PopFrame and ForceEarlyReturn requests.
  80  virtual void check_and_handle_popframe();
  81  virtual void check_and_handle_earlyret();
  82 
  83   Address as_Address(AddressLiteral adr);
  84   Address as_Address(ArrayAddress adr, Register rscratch);
  85 
  86   // Support for null-checks
  87   //
  88   // Generates code that causes a null OS exception if the content of reg is null.
  89   // If the accessed location is M[reg + offset] and the offset is known, provide the
  90   // offset. No explicit code generation is needed if the offset is within a certain
  91   // range (0 <= offset <= page_size).
  92 
  93   void null_check(Register reg, int offset = -1);
  94   static bool needs_explicit_null_check(intptr_t offset);
  95   static bool uses_implicit_null_check(void* address);
  96 






















  97   // Required platform-specific helpers for Label::patch_instructions.
  98   // They _shadow_ the declarations in AbstractAssembler, which are undefined.
  99   void pd_patch_instruction(address branch, address target, const char* file, int line) {
 100     unsigned char op = branch[0];
 101     assert(op == 0xE8 /* call */ ||
 102         op == 0xE9 /* jmp */ ||
 103         op == 0xEB /* short jmp */ ||
 104         (op & 0xF0) == 0x70 /* short jcc */ ||
 105         (op == 0x0F && (branch[1] & 0xF0) == 0x80) /* jcc */ ||
 106         (op == 0xC7 && branch[1] == 0xF8) /* xbegin */ ||
 107         (op == 0x8D) /* lea */,
 108         "Invalid opcode at patch point");
 109 
 110     if (op == 0xEB || (op & 0xF0) == 0x70) {
 111       // short offset operators (jmp and jcc)
 112       char* disp = (char*) &branch[1];
 113       int imm8 = checked_cast<int>(target - (address) &disp[1]);
 114       guarantee(this->is8bit(imm8), "Short forward jump exceeds 8-bit offset at %s:%d",
 115                 file == nullptr ? "<null>" : file, line);
 116       *disp = (char)imm8;

 332   void resolve_global_jobject(Register value, Register tmp);
 333 
 334   // C 'boolean' to Java boolean: x == 0 ? 0 : 1
 335   void c2bool(Register x);
 336 
 337   // C++ bool manipulation
 338 
 339   void movbool(Register dst, Address src);
 340   void movbool(Address dst, bool boolconst);
 341   void movbool(Address dst, Register src);
 342   void testbool(Register dst);
 343 
 344   void resolve_oop_handle(Register result, Register tmp);
 345   void resolve_weak_handle(Register result, Register tmp);
 346   void load_mirror(Register mirror, Register method, Register tmp);
 347   void load_method_holder_cld(Register rresult, Register rmethod);
 348 
 349   void load_method_holder(Register holder, Register method);
 350 
 351   // oop manipulations



 352   void load_narrow_klass_compact(Register dst, Register src);
 353   void load_klass(Register dst, Register src, Register tmp);
 354   void store_klass(Register dst, Register src, Register tmp);
 355 
 356   // Compares the narrow Klass pointer of an object to a given narrow Klass.
 357   void cmp_klass(Register klass, Register obj, Register tmp);
 358 
 359   // Compares the Klass pointer of two objects obj1 and obj2. Result is in the condition flags.
 360   // Uses tmp1 and tmp2 as temporary registers.
 361   void cmp_klasses_from_objects(Register obj1, Register obj2, Register tmp1, Register tmp2);
 362 
 363   void access_load_at(BasicType type, DecoratorSet decorators, Register dst, Address src,
 364                       Register tmp1);
 365   void access_store_at(BasicType type, DecoratorSet decorators, Address dst, Register val,
 366                        Register tmp1, Register tmp2, Register tmp3);
 367 









 368   void load_heap_oop(Register dst, Address src, Register tmp1 = noreg, DecoratorSet decorators = 0);
 369   void load_heap_oop_not_null(Register dst, Address src, Register tmp1 = noreg, DecoratorSet decorators = 0);
 370   void store_heap_oop(Address dst, Register val, Register tmp1 = noreg,
 371                       Register tmp2 = noreg, Register tmp3 = noreg, DecoratorSet decorators = 0);
 372 
 373   // Used for storing null. All other oop constants should be
 374   // stored using routines that take a jobject.
 375   void store_heap_oop_null(Address dst);
 376 


 377   void store_klass_gap(Register dst, Register src);
 378 
 379   // This dummy is to prevent a call to store_heap_oop from
 380   // converting a zero (like null) into a Register by giving
 381   // the compiler two choices it can't resolve
 382 
 383   void store_heap_oop(Address dst, void* dummy);
 384 
 385   void encode_heap_oop(Register r);
 386   void decode_heap_oop(Register r);
 387   void encode_heap_oop_not_null(Register r);
 388   void decode_heap_oop_not_null(Register r);
 389   void encode_heap_oop_not_null(Register dst, Register src);
 390   void decode_heap_oop_not_null(Register dst, Register src);
 391 
 392   void set_narrow_oop(Register dst, jobject obj);
 393   void set_narrow_oop(Address dst, jobject obj);
 394   void cmp_narrow_oop(Register dst, jobject obj);
 395   void cmp_narrow_oop(Address dst, jobject obj);
 396 

 491 
 492 public:
 493   void push_set(RegSet set, int offset = -1);
 494   void pop_set(RegSet set, int offset = -1);
 495 
 496   // Push and pop everything that might be clobbered by a native
 497   // runtime call.
 498   // Only save the lower 64 bits of each vector register.
 499   // Additional registers can be excluded in a passed RegSet.
 500   void push_call_clobbered_registers_except(RegSet exclude, bool save_fpu = true);
 501   void pop_call_clobbered_registers_except(RegSet exclude, bool restore_fpu = true);
 502 
 503   void push_call_clobbered_registers(bool save_fpu = true) {
 504     push_call_clobbered_registers_except(RegSet(), save_fpu);
 505   }
 506   void pop_call_clobbered_registers(bool restore_fpu = true) {
 507     pop_call_clobbered_registers_except(RegSet(), restore_fpu);
 508   }
 509 
 510   // allocation









 511   void tlab_allocate(
 512     Register obj,                      // result: pointer to object after successful allocation
 513     Register var_size_in_bytes,        // object size in bytes if unknown at compile time; invalid otherwise
 514     int      con_size_in_bytes,        // object size in bytes if   known at compile time
 515     Register t1,                       // temp register
 516     Register t2,                       // temp register
 517     Label&   slow_case                 // continuation point if fast allocation fails
 518   );
 519   void zero_memory(Register address, Register length_in_bytes, int offset_in_bytes, Register temp);
 520 


 521   void population_count(Register dst, Register src, Register scratch1, Register scratch2);
 522 
 523   // interface method calling
 524   void lookup_interface_method(Register recv_klass,
 525                                Register intf_klass,
 526                                RegisterOrConstant itable_index,
 527                                Register method_result,
 528                                Register scan_temp,
 529                                Label& no_such_interface,
 530                                bool return_method = true);
 531 
 532   void lookup_interface_method_stub(Register recv_klass,
 533                                     Register holder_klass,
 534                                     Register resolved_klass,
 535                                     Register method_result,
 536                                     Register scan_temp,
 537                                     Register temp_reg2,
 538                                     Register receiver,
 539                                     int itable_index,
 540                                     Label& L_no_such_interface);

 749   // operands. In general the names are modified to avoid hiding the instruction in Assembler
 750   // so that we don't need to implement all the varieties in the Assembler with trivial wrappers
 751   // here in MacroAssembler. The major exception to this rule is call
 752 
 753   // Arithmetics
 754 
 755 
 756   void addptr(Address dst, int32_t src) { addq(dst, src); }
 757   void addptr(Address dst, Register src);
 758 
 759   void addptr(Register dst, Address src) { addq(dst, src); }
 760   void addptr(Register dst, int32_t src);
 761   void addptr(Register dst, Register src);
 762   void addptr(Register dst, RegisterOrConstant src) {
 763     if (src.is_constant()) addptr(dst, checked_cast<int>(src.as_constant()));
 764     else                   addptr(dst, src.as_register());
 765   }
 766 
 767   void andptr(Register dst, int32_t src);
 768   void andptr(Register src1, Register src2) { andq(src1, src2); }

 769 
 770   using Assembler::andq;
 771   void andq(Register dst, AddressLiteral src, Register rscratch = noreg);
 772 
 773   void cmp8(AddressLiteral src1, int imm, Register rscratch = noreg);
 774 
 775   // renamed to drag out the casting of address to int32_t/intptr_t
 776   void cmp32(Register src1, int32_t imm);
 777 
 778   void cmp32(AddressLiteral src1, int32_t imm, Register rscratch = noreg);
 779   // compare reg - mem, or reg - &mem
 780   void cmp32(Register src1, AddressLiteral src2, Register rscratch = noreg);
 781 
 782   void cmp32(Register src1, Address src2);
 783 
 784   void cmpoop(Register src1, Register src2);
 785   void cmpoop(Register src1, Address src2);
 786   void cmpoop(Register dst, jobject obj, Register rscratch);
 787 
 788   // NOTE src2 must be the lval. This is NOT an mem-mem compare

1907   void movdl(XMMRegister dst, AddressLiteral src, Register rscratch = noreg);
1908 
1909   using Assembler::movq;
1910   void movq(XMMRegister dst, AddressLiteral src, Register rscratch = noreg);
1911 
1912   // Can push value or effective address
1913   void pushptr(AddressLiteral src, Register rscratch);
1914 
1915   void pushptr(Address src) { pushq(src); }
1916   void popptr(Address src) { popq(src); }
1917 
1918   void pushoop(jobject obj, Register rscratch);
1919   void pushklass(Metadata* obj, Register rscratch);
1920 
1921   // sign extend as need a l to ptr sized element
1922   void movl2ptr(Register dst, Address src) { movslq(dst, src); }
1923   void movl2ptr(Register dst, Register src) { movslq(dst, src); }
1924 
1925 
1926  public:















1927   // clear memory of size 'cnt' qwords, starting at 'base';
1928   // if 'is_large' is set, do not try to produce short loop
1929   void clear_mem(Register base, Register cnt, Register rtmp, XMMRegister xtmp, bool is_large, KRegister mask=knoreg);
1930 
1931   // clear memory initialization sequence for constant size;
1932   void clear_mem(Register base, int cnt, Register rtmp, XMMRegister xtmp, KRegister mask=knoreg);
1933 
1934   // clear memory of size 'cnt' qwords, starting at 'base' using XMM/YMM registers
1935   void xmm_clear_mem(Register base, Register cnt, Register rtmp, XMMRegister xtmp, KRegister mask=knoreg);
1936 
1937   // Fill primitive arrays
1938   void generate_fill(BasicType t, bool aligned,
1939                      Register to, Register value, Register count,
1940                      Register rtmp, XMMRegister xtmp);
1941 
1942   void encode_iso_array(Register src, Register dst, Register len,
1943                         XMMRegister tmp1, XMMRegister tmp2, XMMRegister tmp3,
1944                         XMMRegister tmp4, Register tmp5, Register result, bool ascii);
1945 
1946   void add2_with_carry(Register dest_hi, Register dest_lo, Register src1, Register src2);
1947   void multiply_64_x_64_loop(Register x, Register xstart, Register x_xstart,
1948                              Register y, Register y_idx, Register z,
1949                              Register carry, Register product,

  13  * accompanied this code).
  14  *
  15  * You should have received a copy of the GNU General Public License version
  16  * 2 along with this work; if not, write to the Free Software Foundation,
  17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18  *
  19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20  * or visit www.oracle.com if you need additional information or have any
  21  * questions.
  22  *
  23  */
  24 
  25 #ifndef CPU_X86_MACROASSEMBLER_X86_HPP
  26 #define CPU_X86_MACROASSEMBLER_X86_HPP
  27 
  28 #include "asm/assembler.hpp"
  29 #include "asm/register.hpp"
  30 #include "code/vmreg.inline.hpp"
  31 #include "compiler/oopMap.hpp"
  32 #include "utilities/macros.hpp"
  33 #include "runtime/signature.hpp"
  34 #include "runtime/vm_version.hpp"
  35 #include "utilities/checkedCast.hpp"
  36 
  37 class ciInlineKlass;
  38 
  39 // MacroAssembler extends Assembler by frequently used macros.
  40 //
  41 // Instructions for which a 'better' code sequence exists depending
  42 // on arguments should also go in here.
  43 
  44 class MacroAssembler: public Assembler {
  45   friend class LIR_Assembler;
  46   friend class Runtime1;      // as_Address()
  47 
  48  public:
  49   // Support for VM calls
  50   //
  51   // This is the base routine called by the different versions of call_VM_leaf. The interpreter
  52   // may customize this version by overriding it for its purposes (e.g., to save/restore
  53   // additional registers when doing a VM call).
  54 
  55   virtual void call_VM_leaf_base(
  56     address entry_point,               // the entry point
  57     int     number_of_arguments        // the number of arguments to pop after the call
  58   );

  80  // These routines should emit JVMTI PopFrame and ForceEarlyReturn handling code.
  81  // The implementation is only non-empty for the InterpreterMacroAssembler,
  82  // as only the interpreter handles PopFrame and ForceEarlyReturn requests.
  83  virtual void check_and_handle_popframe();
  84  virtual void check_and_handle_earlyret();
  85 
  86   Address as_Address(AddressLiteral adr);
  87   Address as_Address(ArrayAddress adr, Register rscratch);
  88 
  89   // Support for null-checks
  90   //
  91   // Generates code that causes a null OS exception if the content of reg is null.
  92   // If the accessed location is M[reg + offset] and the offset is known, provide the
  93   // offset. No explicit code generation is needed if the offset is within a certain
  94   // range (0 <= offset <= page_size).
  95 
  96   void null_check(Register reg, int offset = -1);
  97   static bool needs_explicit_null_check(intptr_t offset);
  98   static bool uses_implicit_null_check(void* address);
  99 
 100   // markWord tests, kills markWord reg
 101   void test_markword_is_inline_type(Register markword, Label& is_inline_type);
 102 
 103   // inlineKlass queries, kills temp_reg
 104   void test_oop_is_not_inline_type(Register object, Register tmp, Label& not_inline_type, bool can_be_null = true);
 105 
 106   void test_field_is_null_free_inline_type(Register flags, Register temp_reg, Label& is_null_free);
 107   void test_field_is_not_null_free_inline_type(Register flags, Register temp_reg, Label& not_null_free);
 108   void test_field_is_flat(Register flags, Register temp_reg, Label& is_flat);
 109   void test_field_has_null_marker(Register flags, Register temp_reg, Label& has_null_marker);
 110 
 111   // Check oops for special arrays, i.e. flat arrays and/or null-free arrays
 112   void test_oop_prototype_bit(Register oop, Register temp_reg, int32_t test_bit, bool jmp_set, Label& jmp_label);
 113   void test_flat_array_oop(Register oop, Register temp_reg, Label& is_flat_array);
 114   void test_non_flat_array_oop(Register oop, Register temp_reg, Label& is_non_flat_array);
 115   void test_null_free_array_oop(Register oop, Register temp_reg, Label& is_null_free_array);
 116   void test_non_null_free_array_oop(Register oop, Register temp_reg, Label& is_non_null_free_array);
 117 
 118   // Check array klass layout helper for flat or null-free arrays...
 119   void test_flat_array_layout(Register lh, Label& is_flat_array);
 120   void test_non_flat_array_layout(Register lh, Label& is_non_flat_array);
 121 
 122   // Required platform-specific helpers for Label::patch_instructions.
 123   // They _shadow_ the declarations in AbstractAssembler, which are undefined.
 124   void pd_patch_instruction(address branch, address target, const char* file, int line) {
 125     unsigned char op = branch[0];
 126     assert(op == 0xE8 /* call */ ||
 127         op == 0xE9 /* jmp */ ||
 128         op == 0xEB /* short jmp */ ||
 129         (op & 0xF0) == 0x70 /* short jcc */ ||
 130         (op == 0x0F && (branch[1] & 0xF0) == 0x80) /* jcc */ ||
 131         (op == 0xC7 && branch[1] == 0xF8) /* xbegin */ ||
 132         (op == 0x8D) /* lea */,
 133         "Invalid opcode at patch point");
 134 
 135     if (op == 0xEB || (op & 0xF0) == 0x70) {
 136       // short offset operators (jmp and jcc)
 137       char* disp = (char*) &branch[1];
 138       int imm8 = checked_cast<int>(target - (address) &disp[1]);
 139       guarantee(this->is8bit(imm8), "Short forward jump exceeds 8-bit offset at %s:%d",
 140                 file == nullptr ? "<null>" : file, line);
 141       *disp = (char)imm8;

 357   void resolve_global_jobject(Register value, Register tmp);
 358 
 359   // C 'boolean' to Java boolean: x == 0 ? 0 : 1
 360   void c2bool(Register x);
 361 
 362   // C++ bool manipulation
 363 
 364   void movbool(Register dst, Address src);
 365   void movbool(Address dst, bool boolconst);
 366   void movbool(Address dst, Register src);
 367   void testbool(Register dst);
 368 
 369   void resolve_oop_handle(Register result, Register tmp);
 370   void resolve_weak_handle(Register result, Register tmp);
 371   void load_mirror(Register mirror, Register method, Register tmp);
 372   void load_method_holder_cld(Register rresult, Register rmethod);
 373 
 374   void load_method_holder(Register holder, Register method);
 375 
 376   // oop manipulations
 377 
 378   // Load oopDesc._metadata without decode (useful for direct Klass* compare from oops)
 379   void load_metadata(Register dst, Register src);
 380   void load_narrow_klass_compact(Register dst, Register src);
 381   void load_klass(Register dst, Register src, Register tmp);
 382   void store_klass(Register dst, Register src, Register tmp);
 383 
 384   // Compares the narrow Klass pointer of an object to a given narrow Klass.
 385   void cmp_klass(Register klass, Register obj, Register tmp);
 386 
 387   // Compares the Klass pointer of two objects obj1 and obj2. Result is in the condition flags.
 388   // Uses tmp1 and tmp2 as temporary registers.
 389   void cmp_klasses_from_objects(Register obj1, Register obj2, Register tmp1, Register tmp2);
 390 
 391   void access_load_at(BasicType type, DecoratorSet decorators, Register dst, Address src,
 392                       Register tmp1);
 393   void access_store_at(BasicType type, DecoratorSet decorators, Address dst, Register val,
 394                        Register tmp1, Register tmp2, Register tmp3);
 395 
 396   void flat_field_copy(DecoratorSet decorators, Register src, Register dst, Register inline_layout_info);
 397 
 398   // inline type data payload offsets...
 399   void payload_offset(Register inline_klass, Register offset);
 400   void payload_addr(Register oop, Register data, Register inline_klass);
 401   // get data payload ptr a flat value array at index, kills rcx and index
 402   void data_for_value_array_index(Register array, Register array_klass,
 403                                   Register index, Register data);
 404 
 405   void load_heap_oop(Register dst, Address src, Register tmp1 = noreg, DecoratorSet decorators = 0);
 406   void load_heap_oop_not_null(Register dst, Address src, Register tmp1 = noreg, DecoratorSet decorators = 0);
 407   void store_heap_oop(Address dst, Register val, Register tmp1 = noreg,
 408                       Register tmp2 = noreg, Register tmp3 = noreg, DecoratorSet decorators = 0);
 409 
 410   // Used for storing null. All other oop constants should be
 411   // stored using routines that take a jobject.
 412   void store_heap_oop_null(Address dst);
 413 
 414   void load_prototype_header(Register dst, Register src, Register tmp);
 415 
 416   void store_klass_gap(Register dst, Register src);
 417 
 418   // This dummy is to prevent a call to store_heap_oop from
 419   // converting a zero (like null) into a Register by giving
 420   // the compiler two choices it can't resolve
 421 
 422   void store_heap_oop(Address dst, void* dummy);
 423 
 424   void encode_heap_oop(Register r);
 425   void decode_heap_oop(Register r);
 426   void encode_heap_oop_not_null(Register r);
 427   void decode_heap_oop_not_null(Register r);
 428   void encode_heap_oop_not_null(Register dst, Register src);
 429   void decode_heap_oop_not_null(Register dst, Register src);
 430 
 431   void set_narrow_oop(Register dst, jobject obj);
 432   void set_narrow_oop(Address dst, jobject obj);
 433   void cmp_narrow_oop(Register dst, jobject obj);
 434   void cmp_narrow_oop(Address dst, jobject obj);
 435 

 530 
 531 public:
 532   void push_set(RegSet set, int offset = -1);
 533   void pop_set(RegSet set, int offset = -1);
 534 
 535   // Push and pop everything that might be clobbered by a native
 536   // runtime call.
 537   // Only save the lower 64 bits of each vector register.
 538   // Additional registers can be excluded in a passed RegSet.
 539   void push_call_clobbered_registers_except(RegSet exclude, bool save_fpu = true);
 540   void pop_call_clobbered_registers_except(RegSet exclude, bool restore_fpu = true);
 541 
 542   void push_call_clobbered_registers(bool save_fpu = true) {
 543     push_call_clobbered_registers_except(RegSet(), save_fpu);
 544   }
 545   void pop_call_clobbered_registers(bool restore_fpu = true) {
 546     pop_call_clobbered_registers_except(RegSet(), restore_fpu);
 547   }
 548 
 549   // allocation
 550 
 551   // Object / value buffer allocation...
 552   // Allocate instance of klass, assumes klass initialized by caller
 553   // new_obj prefers to be rax
 554   // Kills t1 and t2, perserves klass, return allocation in new_obj (rsi on LP64)
 555   void allocate_instance(Register klass, Register new_obj,
 556                          Register t1, Register t2,
 557                          bool clear_fields, Label& alloc_failed);
 558 
 559   void tlab_allocate(
 560     Register obj,                      // result: pointer to object after successful allocation
 561     Register var_size_in_bytes,        // object size in bytes if unknown at compile time; invalid otherwise
 562     int      con_size_in_bytes,        // object size in bytes if   known at compile time
 563     Register t1,                       // temp register
 564     Register t2,                       // temp register
 565     Label&   slow_case                 // continuation point if fast allocation fails
 566   );
 567   void zero_memory(Register address, Register length_in_bytes, int offset_in_bytes, Register temp);
 568 
 569   void inline_layout_info(Register klass, Register index, Register layout_info);
 570 
 571   void population_count(Register dst, Register src, Register scratch1, Register scratch2);
 572 
 573   // interface method calling
 574   void lookup_interface_method(Register recv_klass,
 575                                Register intf_klass,
 576                                RegisterOrConstant itable_index,
 577                                Register method_result,
 578                                Register scan_temp,
 579                                Label& no_such_interface,
 580                                bool return_method = true);
 581 
 582   void lookup_interface_method_stub(Register recv_klass,
 583                                     Register holder_klass,
 584                                     Register resolved_klass,
 585                                     Register method_result,
 586                                     Register scan_temp,
 587                                     Register temp_reg2,
 588                                     Register receiver,
 589                                     int itable_index,
 590                                     Label& L_no_such_interface);

 799   // operands. In general the names are modified to avoid hiding the instruction in Assembler
 800   // so that we don't need to implement all the varieties in the Assembler with trivial wrappers
 801   // here in MacroAssembler. The major exception to this rule is call
 802 
 803   // Arithmetics
 804 
 805 
 806   void addptr(Address dst, int32_t src) { addq(dst, src); }
 807   void addptr(Address dst, Register src);
 808 
 809   void addptr(Register dst, Address src) { addq(dst, src); }
 810   void addptr(Register dst, int32_t src);
 811   void addptr(Register dst, Register src);
 812   void addptr(Register dst, RegisterOrConstant src) {
 813     if (src.is_constant()) addptr(dst, checked_cast<int>(src.as_constant()));
 814     else                   addptr(dst, src.as_register());
 815   }
 816 
 817   void andptr(Register dst, int32_t src);
 818   void andptr(Register src1, Register src2) { andq(src1, src2); }
 819   void andptr(Register dst, Address src) { andq(dst, src); }
 820 
 821   using Assembler::andq;
 822   void andq(Register dst, AddressLiteral src, Register rscratch = noreg);
 823 
 824   void cmp8(AddressLiteral src1, int imm, Register rscratch = noreg);
 825 
 826   // renamed to drag out the casting of address to int32_t/intptr_t
 827   void cmp32(Register src1, int32_t imm);
 828 
 829   void cmp32(AddressLiteral src1, int32_t imm, Register rscratch = noreg);
 830   // compare reg - mem, or reg - &mem
 831   void cmp32(Register src1, AddressLiteral src2, Register rscratch = noreg);
 832 
 833   void cmp32(Register src1, Address src2);
 834 
 835   void cmpoop(Register src1, Register src2);
 836   void cmpoop(Register src1, Address src2);
 837   void cmpoop(Register dst, jobject obj, Register rscratch);
 838 
 839   // NOTE src2 must be the lval. This is NOT an mem-mem compare

1958   void movdl(XMMRegister dst, AddressLiteral src, Register rscratch = noreg);
1959 
1960   using Assembler::movq;
1961   void movq(XMMRegister dst, AddressLiteral src, Register rscratch = noreg);
1962 
1963   // Can push value or effective address
1964   void pushptr(AddressLiteral src, Register rscratch);
1965 
1966   void pushptr(Address src) { pushq(src); }
1967   void popptr(Address src) { popq(src); }
1968 
1969   void pushoop(jobject obj, Register rscratch);
1970   void pushklass(Metadata* obj, Register rscratch);
1971 
1972   // sign extend as need a l to ptr sized element
1973   void movl2ptr(Register dst, Address src) { movslq(dst, src); }
1974   void movl2ptr(Register dst, Register src) { movslq(dst, src); }
1975 
1976 
1977  public:
1978   // Inline type specific methods
1979   #include "asm/macroAssembler_common.hpp"
1980 
1981   int store_inline_type_fields_to_buf(ciInlineKlass* vk, bool from_interpreter = true);
1982   bool move_helper(VMReg from, VMReg to, BasicType bt, RegState reg_state[]);
1983   bool unpack_inline_helper(const GrowableArray<SigEntry>* sig, int& sig_index,
1984                             VMReg from, int& from_index, VMRegPair* to, int to_count, int& to_index,
1985                             RegState reg_state[]);
1986   bool pack_inline_helper(const GrowableArray<SigEntry>* sig, int& sig_index, int vtarg_index,
1987                           VMRegPair* from, int from_count, int& from_index, VMReg to,
1988                           RegState reg_state[], Register val_array);
1989   int extend_stack_for_inline_args(int args_on_stack);
1990   void remove_frame(int initial_framesize, bool needs_stack_repair);
1991   VMReg spill_reg_for(VMReg reg);
1992 
1993   // clear memory of size 'cnt' qwords, starting at 'base';
1994   // if 'is_large' is set, do not try to produce short loop
1995   void clear_mem(Register base, Register cnt, Register val, XMMRegister xtmp, bool is_large, bool word_copy_only, KRegister mask=knoreg);
1996 
1997   // clear memory initialization sequence for constant size;
1998   void clear_mem(Register base, int cnt, Register rtmp, XMMRegister xtmp, KRegister mask=knoreg);
1999 
2000   // clear memory of size 'cnt' qwords, starting at 'base' using XMM/YMM registers
2001   void xmm_clear_mem(Register base, Register cnt, Register rtmp, XMMRegister xtmp, KRegister mask=knoreg);
2002 
2003   // Fill primitive arrays
2004   void generate_fill(BasicType t, bool aligned,
2005                      Register to, Register value, Register count,
2006                      Register rtmp, XMMRegister xtmp);
2007 
2008   void encode_iso_array(Register src, Register dst, Register len,
2009                         XMMRegister tmp1, XMMRegister tmp2, XMMRegister tmp3,
2010                         XMMRegister tmp4, Register tmp5, Register result, bool ascii);
2011 
2012   void add2_with_carry(Register dest_hi, Register dest_lo, Register src1, Register src2);
2013   void multiply_64_x_64_loop(Register x, Register xstart, Register x_xstart,
2014                              Register y, Register y_idx, Register z,
2015                              Register carry, Register product,
< prev index next >