Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(810)

Unified Diff: runtime/vm/assembler_ia32.h

Issue 12207117: SSE Assembler and Disassembler support (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Review fixes Created 7 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « runtime/platform/globals.h ('k') | runtime/vm/assembler_ia32.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: runtime/vm/assembler_ia32.h
diff --git a/runtime/vm/assembler_ia32.h b/runtime/vm/assembler_ia32.h
index 5c0c1cbe98778953dd2dd4fdd01711109cf054a6..89999f9939d99dc4cdd83819648048876080e010 100644
--- a/runtime/vm/assembler_ia32.h
+++ b/runtime/vm/assembler_ia32.h
@@ -377,6 +377,9 @@ class Assembler : public ValueObject {
void movaps(XmmRegister dst, XmmRegister src);
+ void movups(XmmRegister dst, const Address& src);
+ void movups(const Address& dst, XmmRegister src);
+
void addsd(XmmRegister dst, XmmRegister src);
void addsd(XmmRegister dst, const Address& src);
void subsd(XmmRegister dst, XmmRegister src);
@@ -386,6 +389,33 @@ class Assembler : public ValueObject {
void divsd(XmmRegister dst, XmmRegister src);
void divsd(XmmRegister dst, const Address& src);
+
+ void addps(XmmRegister dst, XmmRegister src);
+ void subps(XmmRegister dst, XmmRegister src);
+ void divps(XmmRegister dst, XmmRegister src);
+ void mulps(XmmRegister dst, XmmRegister src);
+ void minps(XmmRegister dst, XmmRegister src);
+ void maxps(XmmRegister dst, XmmRegister src);
+ void andps(XmmRegister dst, XmmRegister src);
+ void andps(XmmRegister dst, const Address& src);
+ void orps(XmmRegister dst, XmmRegister src);
+ void notps(XmmRegister dst);
+ void negateps(XmmRegister dst);
+ void absps(XmmRegister dst);
+ void zerowps(XmmRegister dst);
+ void cmppseq(XmmRegister dst, XmmRegister src);
+ void cmppsneq(XmmRegister dst, XmmRegister src);
+ void cmppslt(XmmRegister dst, XmmRegister src);
+ void cmppsle(XmmRegister dst, XmmRegister src);
+ void cmppsnlt(XmmRegister dst, XmmRegister src);
+ void cmppsnle(XmmRegister dst, XmmRegister src);
+ void sqrtps(XmmRegister dst);
+ void rsqrtps(XmmRegister dst);
+ void reciprocalps(XmmRegister dst);
+
+ void set1ps(XmmRegister dst, Register tmp, const Immediate& imm);
+ void shufps(XmmRegister dst, XmmRegister src, const Immediate& mask);
+
void cvtsi2ss(XmmRegister dst, Register src);
void cvtsi2sd(XmmRegister dst, Register src);
@@ -404,6 +434,7 @@ class Assembler : public ValueObject {
void comisd(XmmRegister a, XmmRegister b);
void movmskpd(Register dst, XmmRegister src);
+ void movmskps(Register dst, XmmRegister src);
void sqrtsd(XmmRegister dst, XmmRegister src);
void sqrtss(XmmRegister dst, XmmRegister src);
« no previous file with comments | « runtime/platform/globals.h ('k') | runtime/vm/assembler_ia32.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698