< prev index next >

src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ByteVector.java

Print this page
rev 58165 : Fix the issue that unslice modifies the argument vector
Summary: Change the name of getElements() to vec() and clone argument value to
avoid it being modified

@@ -86,11 +86,11 @@
     // and lazy version of C++ templates.
 
     // Virtualized getter
 
     /*package-private*/
-    abstract byte[] getElements();
+    abstract byte[] vec();
 
     // Virtualized constructors
 
     /**
      * Build a vector directly using my own constructor.

@@ -150,11 +150,11 @@
     abstract
     ByteVector uOp(FUnOp f);
     @ForceInline
     final
     ByteVector uOpTemplate(FUnOp f) {
-        byte[] vec = getElements();
+        byte[] vec = vec();
         byte[] res = new byte[length()];
         for (int i = 0; i < res.length; i++) {
             res[i] = f.apply(i, vec[i]);
         }
         return vectorFactory(res);

@@ -166,11 +166,11 @@
                              FUnOp f);
     @ForceInline
     final
     ByteVector uOpTemplate(VectorMask<Byte> m,
                                      FUnOp f) {
-        byte[] vec = getElements();
+        byte[] vec = vec();
         byte[] res = new byte[length()];
         boolean[] mbits = ((AbstractMask<Byte>)m).getBits();
         for (int i = 0; i < res.length; i++) {
             res[i] = mbits[i] ? f.apply(i, vec[i]) : vec[i];
         }

@@ -191,12 +191,12 @@
     @ForceInline
     final
     ByteVector bOpTemplate(Vector<Byte> o,
                                      FBinOp f) {
         byte[] res = new byte[length()];
-        byte[] vec1 = this.getElements();
-        byte[] vec2 = ((ByteVector)o).getElements();
+        byte[] vec1 = this.vec();
+        byte[] vec2 = ((ByteVector)o).vec();
         for (int i = 0; i < res.length; i++) {
             res[i] = f.apply(i, vec1[i], vec2[i]);
         }
         return vectorFactory(res);
     }

@@ -210,12 +210,12 @@
     final
     ByteVector bOpTemplate(Vector<Byte> o,
                                      VectorMask<Byte> m,
                                      FBinOp f) {
         byte[] res = new byte[length()];
-        byte[] vec1 = this.getElements();
-        byte[] vec2 = ((ByteVector)o).getElements();
+        byte[] vec1 = this.vec();
+        byte[] vec2 = ((ByteVector)o).vec();
         boolean[] mbits = ((AbstractMask<Byte>)m).getBits();
         for (int i = 0; i < res.length; i++) {
             res[i] = mbits[i] ? f.apply(i, vec1[i], vec2[i]) : vec1[i];
         }
         return vectorFactory(res);

@@ -237,13 +237,13 @@
     final
     ByteVector tOpTemplate(Vector<Byte> o1,
                                      Vector<Byte> o2,
                                      FTriOp f) {
         byte[] res = new byte[length()];
-        byte[] vec1 = this.getElements();
-        byte[] vec2 = ((ByteVector)o1).getElements();
-        byte[] vec3 = ((ByteVector)o2).getElements();
+        byte[] vec1 = this.vec();
+        byte[] vec2 = ((ByteVector)o1).vec();
+        byte[] vec3 = ((ByteVector)o2).vec();
         for (int i = 0; i < res.length; i++) {
             res[i] = f.apply(i, vec1[i], vec2[i], vec3[i]);
         }
         return vectorFactory(res);
     }

@@ -259,13 +259,13 @@
     ByteVector tOpTemplate(Vector<Byte> o1,
                                      Vector<Byte> o2,
                                      VectorMask<Byte> m,
                                      FTriOp f) {
         byte[] res = new byte[length()];
-        byte[] vec1 = this.getElements();
-        byte[] vec2 = ((ByteVector)o1).getElements();
-        byte[] vec3 = ((ByteVector)o2).getElements();
+        byte[] vec1 = this.vec();
+        byte[] vec2 = ((ByteVector)o1).vec();
+        byte[] vec3 = ((ByteVector)o2).vec();
         boolean[] mbits = ((AbstractMask<Byte>)m).getBits();
         for (int i = 0; i < res.length; i++) {
             res[i] = mbits[i] ? f.apply(i, vec1[i], vec2[i], vec3[i]) : vec1[i];
         }
         return vectorFactory(res);

@@ -277,11 +277,11 @@
     abstract
     byte rOp(byte v, FBinOp f);
     @ForceInline
     final
     byte rOpTemplate(byte v, FBinOp f) {
-        byte[] vec = getElements();
+        byte[] vec = vec();
         for (int i = 0; i < vec.length; i++) {
             v = f.apply(i, v, vec[i]);
         }
         return v;
     }

@@ -296,11 +296,11 @@
     /*package-private*/
     @ForceInline
     final
     <M> ByteVector ldOp(M memory, int offset,
                                   FLdOp<M> f) {
-        //dummy; no vec = getElements();
+        //dummy; no vec = vec();
         byte[] res = new byte[length()];
         for (int i = 0; i < res.length; i++) {
             res[i] = f.apply(memory, offset, i);
         }
         return vectorFactory(res);

@@ -310,11 +310,11 @@
     @ForceInline
     final
     <M> ByteVector ldOp(M memory, int offset,
                                   VectorMask<Byte> m,
                                   FLdOp<M> f) {
-        //byte[] vec = getElements();
+        //byte[] vec = vec();
         byte[] res = new byte[length()];
         boolean[] mbits = ((AbstractMask<Byte>)m).getBits();
         for (int i = 0; i < res.length; i++) {
             if (mbits[i]) {
                 res[i] = f.apply(memory, offset, i);

@@ -330,11 +330,11 @@
     /*package-private*/
     @ForceInline
     final
     <M> void stOp(M memory, int offset,
                   FStOp<M> f) {
-        byte[] vec = getElements();
+        byte[] vec = vec();
         for (int i = 0; i < vec.length; i++) {
             f.apply(memory, offset, i, vec[i]);
         }
     }
 

@@ -342,11 +342,11 @@
     @ForceInline
     final
     <M> void stOp(M memory, int offset,
                   VectorMask<Byte> m,
                   FStOp<M> f) {
-        byte[] vec = getElements();
+        byte[] vec = vec();
         boolean[] mbits = ((AbstractMask<Byte>)m).getBits();
         for (int i = 0; i < vec.length; i++) {
             if (mbits[i]) {
                 f.apply(memory, offset, i, vec[i]);
             }

@@ -364,12 +364,12 @@
     @ForceInline
     final
     AbstractMask<Byte> bTest(int cond,
                                   Vector<Byte> o,
                                   FBinTest f) {
-        byte[] vec1 = getElements();
-        byte[] vec2 = ((ByteVector)o).getElements();
+        byte[] vec1 = vec();
+        byte[] vec2 = ((ByteVector)o).vec();
         boolean[] bits = new boolean[length()];
         for (int i = 0; i < length(); i++){
             bits[i] = f.apply(cond, i, vec1[i], vec2[i]);
         }
         return maskFactory(bits);

@@ -2044,12 +2044,12 @@
     final
     @ForceInline
     ByteVector sliceTemplate(int origin, Vector<Byte> v1) {
         ByteVector that = (ByteVector) v1;
         that.check(this);
-        byte[] a0 = this.getElements();
-        byte[] a1 = that.getElements();
+        byte[] a0 = this.vec();
+        byte[] a1 = that.vec();
         byte[] res = new byte[a0.length];
         int vlen = res.length;
         int firstPart = vlen - origin;
         System.arraycopy(a0, origin, res, 0, firstPart);
         System.arraycopy(a1, 0, res, firstPart, origin);

@@ -2087,12 +2087,12 @@
     @ForceInline
     ByteVector
     unsliceTemplate(int origin, Vector<Byte> w, int part) {
         ByteVector that = (ByteVector) w;
         that.check(this);
-        byte[] slice = this.getElements();
-        byte[] res = that.getElements();
+        byte[] slice = this.vec();
+        byte[] res = that.vec().clone();
         int vlen = res.length;
         int firstPart = vlen - origin;
         switch (part) {
         case 0:
             System.arraycopy(slice, 0, res, origin, firstPart);
< prev index next >