Move32 should have an Imm, Tmp form
authorfpizlo@apple.com <fpizlo@apple.com@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Thu, 21 Jan 2016 20:15:04 +0000 (20:15 +0000)
committerfpizlo@apple.com <fpizlo@apple.com@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Thu, 21 Jan 2016 20:15:04 +0000 (20:15 +0000)
https://bugs.webkit.org/show_bug.cgi?id=153313

Reviewed by Mark Lam.

This enables some useful optimizations, like constant propagation in fixObviousSpills().

* assembler/MacroAssemblerX86Common.h:
(JSC::MacroAssemblerX86Common::zeroExtend32ToPtr):
(JSC::MacroAssemblerX86Common::move):
* b3/air/AirOpcode.opcodes:

git-svn-id: https://svn.webkit.org/repository/webkit/trunk@195418 268f45cc-cd09-0410-ab3c-d52691b4dbfc

Source/JavaScriptCore/ChangeLog
Source/JavaScriptCore/assembler/MacroAssemblerX86Common.h
Source/JavaScriptCore/b3/air/AirOpcode.opcodes
Source/JavaScriptCore/dfg/DFGCommon.h

index 553ecfa..5851bf1 100644 (file)
@@ -1,5 +1,19 @@
 2016-01-21  Filip Pizlo  <fpizlo@apple.com>
 
+        Move32 should have an Imm, Tmp form
+        https://bugs.webkit.org/show_bug.cgi?id=153313
+
+        Reviewed by Mark Lam.
+
+        This enables some useful optimizations, like constant propagation in fixObviousSpills().
+
+        * assembler/MacroAssemblerX86Common.h:
+        (JSC::MacroAssemblerX86Common::zeroExtend32ToPtr):
+        (JSC::MacroAssemblerX86Common::move):
+        * b3/air/AirOpcode.opcodes:
+
+2016-01-21  Filip Pizlo  <fpizlo@apple.com>
+
         B3 should have load elimination
         https://bugs.webkit.org/show_bug.cgi?id=153288
 
index 456c4fd..951c465 100644 (file)
@@ -1351,6 +1351,11 @@ public:
     {
         m_assembler.movl_rr(src, dest);
     }
+
+    void zeroExtend32ToPtr(TrustedImm32 src, RegisterID dest)
+    {
+        m_assembler.movl_i32r(src.m_value, dest);
+    }
 #else
     void move(RegisterID src, RegisterID dest)
     {
index fb8e01f..52e3e52 100644 (file)
@@ -431,6 +431,7 @@ Move32 U:G:32, ZD:G:32
     Index, Tmp as load32
     Tmp, Addr as store32
     Tmp, Index as store32
+    x86: Imm, Tmp as zeroExtend32ToPtr
     x86: Imm, Addr as store32
     x86: Imm, Index as store32
 
index b0143d6..1090cdc 100644 (file)
@@ -38,7 +38,7 @@ namespace JSC { namespace DFG {
 // We are in the middle of an experimental transition from LLVM to B3 as the backend for the FTL. We don't
 // yet know how it will turn out. For now, this flag will control whether FTL uses B3. Remember to set this
 // to 0 before committing!
-#define FTL_USES_B3 0
+#define FTL_USES_B3 1
 
 struct Node;