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

Unified Diff: src/harmony-simd.js

Issue 1160443009: Add SIMD.Float32x4 functions. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Tests working. Created 5 years, 6 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 | « src/globals.h ('k') | src/heap-snapshot-generator.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/harmony-simd.js
diff --git a/src/harmony-simd.js b/src/harmony-simd.js
new file mode 100644
index 0000000000000000000000000000000000000000..65005a6b8fe0a7a691bff8a07583b88c94325807
--- /dev/null
+++ b/src/harmony-simd.js
@@ -0,0 +1,171 @@
+// Copyright 2015 the V8 project authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+var $float32x4ToString;
+
+(function(global, utils) {
+
+"use strict";
+
+%CheckIsBootstrapping();
+
+// -------------------------------------------------------------------
+// Imports
+
+var GlobalSIMD = global.SIMD;
+var GlobalFloat32x4 = GlobalSIMD.Float32x4;
+
+//-------------------------------------------------------------------
+
+function Float32x4Constructor(x, y, z, w) {
+ if (%_IsConstructCall()) throw MakeTypeError(kNotConstructor, "Float32x4");
+ if (!IS_NUMBER(x) || !IS_NUMBER(y) || !IS_NUMBER(z) || !IS_NUMBER(w)) {
+ throw MakeTypeError(kInvalidArgument);
+ }
+ return %CreateFloat32x4(x, y, z, w);
+}
+
+function Float32x4SplatConstructor(s) {
+ return %CreateFloat32x4(s, s, s, s);
+}
+
+function Float32x4CheckJS(a) {
+ return %Float32x4Check(a);
+}
+
+function Float32x4ToString() {
+ if (!(IS_FLOAT32X4(this) || IS_FLOAT32X4_WRAPPER(this))) {
+ throw MakeTypeError(kIncompatibleMethodReceiver,
+ "Float32x4.prototype.toString", this);
+ }
+ var value = %_ValueOf(this);
+ var w = GlobalFloat32x4.extractLane(value, 0),
+ x = GlobalFloat32x4.extractLane(value, 1),
+ y = GlobalFloat32x4.extractLane(value, 2),
+ z = GlobalFloat32x4.extractLane(value, 3);
+ return "Float32x4(" + w + ", " + x + ", " + y + ", " + z + ")";
+}
+
+function Float32x4ValueOf() {
+ if (!(IS_FLOAT32X4(this) || IS_FLOAT32X4_WRAPPER(this))) {
+ throw MakeTypeError(kIncompatibleMethodReceiver,
+ "Float32x4.prototype.valueOf", this);
+ }
+ return %_ValueOf(this);
+}
+
+//-------------------------------------------------------------------
+
+function Float32x4ExtractLaneJS(value, lane) {
+ return %Float32x4ExtractLane(value, lane);
+}
+
+function Float32x4ReplaceLaneJS(value, lane, replacement) {
+ return %Float32x4ReplaceLane(value, lane, replacement);
+}
+
+//-------------------------------------------------------------------
+
+function Float32x4AbsJS(a) {
+ return %Float32x4Abs(a);
+}
+
+function Float32x4NegJS(a) {
+ return %Float32x4Neg(a);
+}
+
+function Float32x4SqrtJS(a) {
+ return %Float32x4Sqrt(a);
+}
+
+function Float32x4RecipApproxJS(a) {
+ return %Float32x4RecipApprox(a);
+}
+
+function Float32x4RecipSqrtApproxJS(a) {
+ return %Float32x4RecipSqrtApprox(a);
+}
+
+function Float32x4AddJS(a, b) {
+ return %Float32x4Add(a, b);
+}
+
+function Float32x4SubJS(a, b) {
+ return %Float32x4Sub(a, b);
+}
+
+function Float32x4MulJS(a, b) {
+ return %Float32x4Mul(a, b);
+}
+
+function Float32x4DivJS(a, b) {
+ return %Float32x4Div(a, b);
+}
+
+function Float32x4MinJS(a, b) {
+ return %Float32x4Min(a, b);
+}
+
+function Float32x4MaxJS(a, b) {
+ return %Float32x4Max(a, b);
+}
+
+function Float32x4MinNumJS(a, b) {
+ return %Float32x4MinNum(a, b);
+}
+
+function Float32x4MaxNumJS(a, b) {
+ return %Float32x4MaxNum(a, b);
+}
+
+function Float32x4SwizzleJS(a, w, x, y, z) {
+ return %Float32x4Swizzle(a, w, x, y, z);
+}
+
+function Float32x4ShuffleJS(a, b, w, x, y, z) {
+ return %Float32x4Shuffle(a, b, w, x, y, z);
+}
+
+// -------------------------------------------------------------------
+
+%AddNamedProperty(GlobalSIMD, symbolToStringTag, 'SIMD', READ_ONLY | DONT_ENUM);
+%AddNamedProperty(GlobalSIMD, 'float32x4', GlobalFloat32x4, DONT_ENUM);
+
+%SetCode(GlobalFloat32x4, Float32x4Constructor);
+%FunctionSetPrototype(GlobalFloat32x4, {});
+%AddNamedProperty(
+ GlobalFloat32x4.prototype, 'constructor', GlobalFloat32x4, DONT_ENUM);
+%AddNamedProperty(
+ GlobalFloat32x4, symbolToStringTag, 'Float32x4', DONT_ENUM | READ_ONLY);
+
+utils.InstallFunctions(GlobalFloat32x4.prototype, DONT_ENUM, [
+ 'valueOf', Float32x4ValueOf,
+ 'toString', Float32x4ToString,
+]);
+
+utils.InstallFunctions(GlobalFloat32x4, DONT_ENUM, [
+ 'splat', Float32x4SplatConstructor,
+ 'check', Float32x4CheckJS,
+ 'extractLane', Float32x4ExtractLaneJS,
+ 'replaceLane', Float32x4ReplaceLaneJS,
+ 'abs', Float32x4AbsJS,
+ 'neg', Float32x4NegJS,
+ 'sqrt', Float32x4SqrtJS,
+ 'reciprocalApproximation', Float32x4RecipApproxJS,
+ 'reciprocalSqrtApproximation', Float32x4RecipSqrtApproxJS,
+ 'add', Float32x4AddJS,
+ 'sub', Float32x4SubJS,
+ 'mul', Float32x4MulJS,
+ 'div', Float32x4DivJS,
+ 'min', Float32x4MinJS,
+ 'max', Float32x4MaxJS,
+ 'minNum', Float32x4MinNumJS,
+ 'maxNum', Float32x4MaxNumJS,
+ 'swizzle', Float32x4SwizzleJS,
+ 'shuffle', Float32x4ShuffleJS,
+]);
+
+$float32x4ToString = Float32x4ToString;
+
+})
« no previous file with comments | « src/globals.h ('k') | src/heap-snapshot-generator.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698