remove "half" term from SkVM

fp16 is a more precise name, given that there are things like bfloat16,
and this may free up the word "half" for the same sort of more nebulous
format as we use it in SkSL.

Change-Id: I55c39f3670f2c300b9306c92a86c4ec7a2e7b5d7
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/339577
Reviewed-by: Brian Osman <brianosman@google.com>
Commit-Queue: Mike Klein <mtklein@google.com>
This commit is contained in:
Mike Klein 2020-12-01 10:14:55 -06:00 committed by Skia Commit-Bot
parent 356cef301b
commit 42d67a67f5
4 changed files with 23 additions and 23 deletions

View File

@ -287,8 +287,8 @@ namespace skvm {
case Op::ceil: write(o, V{id}, "=", op, V{x}); break; case Op::ceil: write(o, V{id}, "=", op, V{x}); break;
case Op::floor: write(o, V{id}, "=", op, V{x}); break; case Op::floor: write(o, V{id}, "=", op, V{x}); break;
case Op::to_f32: write(o, V{id}, "=", op, V{x}); break; case Op::to_f32: write(o, V{id}, "=", op, V{x}); break;
case Op::to_half: write(o, V{id}, "=", op, V{x}); break; case Op::to_fp16: write(o, V{id}, "=", op, V{x}); break;
case Op::from_half: write(o, V{id}, "=", op, V{x}); break; case Op::from_fp16: write(o, V{id}, "=", op, V{x}); break;
case Op::trunc: write(o, V{id}, "=", op, V{x}); break; case Op::trunc: write(o, V{id}, "=", op, V{x}); break;
case Op::round: write(o, V{id}, "=", op, V{x}); break; case Op::round: write(o, V{id}, "=", op, V{x}); break;
} }
@ -397,8 +397,8 @@ namespace skvm {
case Op::ceil: write(o, R{d}, "=", op, R{x}); break; case Op::ceil: write(o, R{d}, "=", op, R{x}); break;
case Op::floor: write(o, R{d}, "=", op, R{x}); break; case Op::floor: write(o, R{d}, "=", op, R{x}); break;
case Op::to_f32: write(o, R{d}, "=", op, R{x}); break; case Op::to_f32: write(o, R{d}, "=", op, R{x}); break;
case Op::to_half: write(o, R{d}, "=", op, R{x}); break; case Op::to_fp16: write(o, R{d}, "=", op, R{x}); break;
case Op::from_half: write(o, R{d}, "=", op, R{x}); break; case Op::from_fp16: write(o, R{d}, "=", op, R{x}); break;
case Op::trunc: write(o, R{d}, "=", op, R{x}); break; case Op::trunc: write(o, R{d}, "=", op, R{x}); break;
case Op::round: write(o, R{d}, "=", op, R{x}); break; case Op::round: write(o, R{d}, "=", op, R{x}); break;
} }
@ -1061,13 +1061,13 @@ namespace skvm {
return {this, this->push(Op::round, x.id)}; return {this, this->push(Op::round, x.id)};
} }
I32 Builder::to_half(F32 x) { I32 Builder::to_fp16(F32 x) {
if (float X; this->allImm(x.id,&X)) { return splat((int)SkFloatToHalf(X)); } if (float X; this->allImm(x.id,&X)) { return splat((int)SkFloatToHalf(X)); }
return {this, this->push(Op::to_half, x.id)}; return {this, this->push(Op::to_fp16, x.id)};
} }
F32 Builder::from_half(I32 x) { F32 Builder::from_fp16(I32 x) {
if (int X; this->allImm(x.id,&X)) { return splat(SkHalfToFloat(X)); } if (int X; this->allImm(x.id,&X)) { return splat(SkHalfToFloat(X)); }
return {this, this->push(Op::from_half, x.id)}; return {this, this->push(Op::from_fp16, x.id)};
} }
F32 Builder::from_unorm(int bits, I32 x) { F32 Builder::from_unorm(int bits, I32 x) {
@ -1132,7 +1132,7 @@ namespace skvm {
I32 channel = extract(x, shift, (1<<bits)-1); I32 channel = extract(x, shift, (1<<bits)-1);
switch (f.encoding) { switch (f.encoding) {
case PixelFormat::UNORM: return from_unorm(bits, channel); case PixelFormat::UNORM: return from_unorm(bits, channel);
case PixelFormat::FLOAT: return from_half ( channel); case PixelFormat::FLOAT: return from_fp16 ( channel);
} }
SkUNREACHABLE; SkUNREACHABLE;
}; };
@ -1254,7 +1254,7 @@ namespace skvm {
I32 encoded; I32 encoded;
switch (f.encoding) { switch (f.encoding) {
case PixelFormat::UNORM: encoded = to_unorm(bits, channel); break; case PixelFormat::UNORM: encoded = to_unorm(bits, channel); break;
case PixelFormat::FLOAT: encoded = to_half ( channel); break; case PixelFormat::FLOAT: encoded = to_fp16 ( channel); break;
} }
packed = pack(packed, encoded, shift); packed = pack(packed, encoded, shift);
}; };
@ -3704,12 +3704,12 @@ namespace skvm {
else { a->vcvtps2dq(dst(), any(x)); } else { a->vcvtps2dq(dst(), any(x)); }
break; break;
case Op::to_half: case Op::to_fp16:
a->vcvtps2ph(dst(x), r(x), A::CURRENT); // f32 ymm -> f16 xmm a->vcvtps2ph(dst(x), r(x), A::CURRENT); // f32 ymm -> f16 xmm
a->vpmovzxwd(dst(), dst()); // f16 xmm -> f16 ymm a->vpmovzxwd(dst(), dst()); // f16 xmm -> f16 ymm
break; break;
case Op::from_half: case Op::from_fp16:
a->vpackusdw(dst(x), r(x), r(x)); // f16 ymm -> f16 xmm a->vpackusdw(dst(x), r(x), r(x)); // f16 ymm -> f16 xmm
a->vpermq (dst(), dst(), 0xd8); // swap middle two 64-bit lanes a->vpermq (dst(), dst(), 0xd8); // swap middle two 64-bit lanes
a->vcvtph2ps(dst(), dst()); // f16 xmm -> f32 ymm a->vcvtph2ps(dst(), dst()); // f16 xmm -> f32 ymm
@ -3720,8 +3720,8 @@ namespace skvm {
case Op::store128: case Op::store128:
case Op::load64: case Op::load64:
case Op::load128: case Op::load128:
case Op::to_half: case Op::to_fp16:
case Op::from_half: case Op::from_fp16:
return false; // TODO return false; // TODO
case Op::assert_true: { case Op::assert_true: {

View File

@ -438,7 +438,7 @@ namespace skvm {
M(fma_f32) M(fms_f32) M(fnma_f32) \ M(fma_f32) M(fms_f32) M(fnma_f32) \
M(sqrt_f32) \ M(sqrt_f32) \
M(shl_i32) M(shr_i32) M(sra_i32) \ M(shl_i32) M(shr_i32) M(sra_i32) \
M(ceil) M(floor) M(trunc) M(round) M(to_half) M(from_half) \ M(ceil) M(floor) M(trunc) M(round) M(to_fp16) M(from_fp16) \
M(to_f32) \ M(to_f32) \
M(neq_f32) M(eq_f32) M(eq_i32) \ M(neq_f32) M(eq_f32) M(eq_i32) \
M(gte_f32) M(gt_f32) M(gt_i32) \ M(gte_f32) M(gt_f32) M(gt_i32) \
@ -715,8 +715,8 @@ namespace skvm {
I32 round(F32 x); // Round to int using current rounding mode (as if lrintf()). I32 round(F32 x); // Round to int using current rounding mode (as if lrintf()).
I32 bit_cast(F32 x) { return {x.builder, x.id}; } I32 bit_cast(F32 x) { return {x.builder, x.id}; }
I32 to_half(F32 x); I32 to_fp16(F32 x);
F32 from_half(I32 x); F32 from_fp16(I32 x);
F32 norm(F32 x, F32 y) { F32 norm(F32 x, F32 y) {
return sqrt(add(mul(x,x), return sqrt(add(mul(x,x),
@ -1050,8 +1050,8 @@ namespace skvm {
static inline I32 bit_cast(F32 x) { return x-> bit_cast(x); } static inline I32 bit_cast(F32 x) { return x-> bit_cast(x); }
static inline F32 bit_cast(I32 x) { return x-> bit_cast(x); } static inline F32 bit_cast(I32 x) { return x-> bit_cast(x); }
static inline F32 to_F32(I32 x) { return x-> to_F32(x); } static inline F32 to_F32(I32 x) { return x-> to_F32(x); }
static inline I32 to_half(F32 x) { return x-> to_half(x); } static inline I32 to_fp16(F32 x) { return x-> to_fp16(x); }
static inline F32 from_half(I32 x) { return x->from_half(x); } static inline F32 from_fp16(I32 x) { return x->from_fp16(x); }
static inline F32 lerp(F32 lo, F32a hi, F32a t) { return lo->lerp(lo,hi,t); } static inline F32 lerp(F32 lo, F32a hi, F32a t) { return lo->lerp(lo,hi,t); }
static inline F32 lerp(float lo, F32 hi, F32a t) { return hi->lerp(lo,hi,t); } static inline F32 lerp(float lo, F32 hi, F32a t) { return hi->lerp(lo,hi,t); }

View File

@ -259,10 +259,10 @@ namespace SK_OPTS_NS {
CASE(Op::trunc): r[d].i32 = skvx::cast<int> ( r[x].f32 ); break; CASE(Op::trunc): r[d].i32 = skvx::cast<int> ( r[x].f32 ); break;
CASE(Op::round): r[d].i32 = skvx::cast<int> (skvx::lrint(r[x].f32)); break; CASE(Op::round): r[d].i32 = skvx::cast<int> (skvx::lrint(r[x].f32)); break;
CASE(Op::to_half): CASE(Op::to_fp16):
r[d].i32 = skvx::cast<int>(skvx::to_half(r[x].f32)); r[d].i32 = skvx::cast<int>(skvx::to_half(r[x].f32));
break; break;
CASE(Op::from_half): CASE(Op::from_fp16):
r[d].f32 = skvx::from_half(skvx::cast<uint16_t>(r[x].i32)); r[d].f32 = skvx::from_half(skvx::cast<uint16_t>(r[x].i32));
break; break;

View File

@ -2273,7 +2273,7 @@ DEF_TEST(SkVM_halfs, r) {
skvm::Builder b; skvm::Builder b;
skvm::Arg src = b.varying<uint16_t>(), skvm::Arg src = b.varying<uint16_t>(),
dst = b.varying<float>(); dst = b.varying<float>();
b.storeF(dst, b.from_half(b.load16(src))); b.storeF(dst, b.from_fp16(b.load16(src)));
test_jit_and_interpreter(b.done(), [&](const skvm::Program& program){ test_jit_and_interpreter(b.done(), [&](const skvm::Program& program){
float dst[8]; float dst[8];
@ -2287,7 +2287,7 @@ DEF_TEST(SkVM_halfs, r) {
skvm::Builder b; skvm::Builder b;
skvm::Arg src = b.varying<float>(), skvm::Arg src = b.varying<float>(),
dst = b.varying<uint16_t>(); dst = b.varying<uint16_t>();
b.store16(dst, b.to_half(b.loadF(src))); b.store16(dst, b.to_fp16(b.loadF(src)));
test_jit_and_interpreter(b.done(), [&](const skvm::Program& program){ test_jit_and_interpreter(b.done(), [&](const skvm::Program& program){
uint16_t dst[8]; uint16_t dst[8];