Commit 5270fb39 by Alexis Hetu Committed by Alexis Hétu

Fixed default alpha value for integer types

The default alpha value for integer types is 1 and not the largest representable value for that type, as it was previously implemented. A value of 1 still means that the texture is opaque. This fixes ~60 fragment output tests. Change-Id: I96650fc8ba4812dcb8a2787979c6829f14f0960e Reviewed-on: https://swiftshader-review.googlesource.com/7190Tested-by: 's avatarAlexis Hétu <sugoi@google.com> Reviewed-by: 's avatarNicolas Capens <capn@google.com>
parent 98a16665
...@@ -697,7 +697,7 @@ namespace sw ...@@ -697,7 +697,7 @@ namespace sw
bool Blitter::read(Int4 &c, Pointer<Byte> element, Format format) bool Blitter::read(Int4 &c, Pointer<Byte> element, Format format)
{ {
c = Int4(0, 0, 0, 0xFFFFFFFF); c = Int4(0, 0, 0, 1);
switch(format) switch(format)
{ {
...@@ -709,10 +709,6 @@ namespace sw ...@@ -709,10 +709,6 @@ namespace sw
c = Insert(c, Int(*Pointer<SByte>(element + 1)), 1); c = Insert(c, Int(*Pointer<SByte>(element + 1)), 1);
case FORMAT_R8I: case FORMAT_R8I:
c = Insert(c, Int(*Pointer<SByte>(element)), 0); c = Insert(c, Int(*Pointer<SByte>(element)), 0);
if(format != FORMAT_A8B8G8R8I)
{
c = Insert(c, Int(0x7F), 3); // Set alpha
}
break; break;
case FORMAT_A8B8G8R8UI: case FORMAT_A8B8G8R8UI:
c = Insert(c, Int(*Pointer<Byte>(element + 3)), 3); c = Insert(c, Int(*Pointer<Byte>(element + 3)), 3);
...@@ -722,10 +718,6 @@ namespace sw ...@@ -722,10 +718,6 @@ namespace sw
c = Insert(c, Int(*Pointer<Byte>(element + 1)), 1); c = Insert(c, Int(*Pointer<Byte>(element + 1)), 1);
case FORMAT_R8UI: case FORMAT_R8UI:
c = Insert(c, Int(*Pointer<Byte>(element)), 0); c = Insert(c, Int(*Pointer<Byte>(element)), 0);
if(format != FORMAT_A8B8G8R8UI)
{
c = Insert(c, Int(0xFF), 3); // Set alpha
}
break; break;
case FORMAT_A16B16G16R16I: case FORMAT_A16B16G16R16I:
c = Insert(c, Int(*Pointer<Short>(element + 6)), 3); c = Insert(c, Int(*Pointer<Short>(element + 6)), 3);
...@@ -735,10 +727,6 @@ namespace sw ...@@ -735,10 +727,6 @@ namespace sw
c = Insert(c, Int(*Pointer<Short>(element + 2)), 1); c = Insert(c, Int(*Pointer<Short>(element + 2)), 1);
case FORMAT_R16I: case FORMAT_R16I:
c = Insert(c, Int(*Pointer<Short>(element)), 0); c = Insert(c, Int(*Pointer<Short>(element)), 0);
if(format != FORMAT_A16B16G16R16I)
{
c = Insert(c, Int(0x7FFF), 3); // Set alpha
}
break; break;
case FORMAT_A16B16G16R16UI: case FORMAT_A16B16G16R16UI:
c = Insert(c, Int(*Pointer<UShort>(element + 6)), 3); c = Insert(c, Int(*Pointer<UShort>(element + 6)), 3);
...@@ -748,10 +736,6 @@ namespace sw ...@@ -748,10 +736,6 @@ namespace sw
c = Insert(c, Int(*Pointer<UShort>(element + 2)), 1); c = Insert(c, Int(*Pointer<UShort>(element + 2)), 1);
case FORMAT_R16UI: case FORMAT_R16UI:
c = Insert(c, Int(*Pointer<UShort>(element)), 0); c = Insert(c, Int(*Pointer<UShort>(element)), 0);
if(format != FORMAT_A16B16G16R16UI)
{
c = Insert(c, Int(0xFFFF), 3); // Set alpha
}
break; break;
case FORMAT_A32B32G32R32I: case FORMAT_A32B32G32R32I:
c = *Pointer<Int4>(element); c = *Pointer<Int4>(element);
...@@ -762,7 +746,6 @@ namespace sw ...@@ -762,7 +746,6 @@ namespace sw
c = Insert(c, *Pointer<Int>(element + 4), 1); c = Insert(c, *Pointer<Int>(element + 4), 1);
case FORMAT_R32I: case FORMAT_R32I:
c = Insert(c, *Pointer<Int>(element), 0); c = Insert(c, *Pointer<Int>(element), 0);
c = Insert(c, Int(0x7FFFFFFF), 3); // Set alpha
break; break;
case FORMAT_A32B32G32R32UI: case FORMAT_A32B32G32R32UI:
c = *Pointer<UInt4>(element); c = *Pointer<UInt4>(element);
...@@ -773,7 +756,6 @@ namespace sw ...@@ -773,7 +756,6 @@ namespace sw
c = Insert(c, Int(*Pointer<UInt>(element + 4)), 1); c = Insert(c, Int(*Pointer<UInt>(element + 4)), 1);
case FORMAT_R32UI: case FORMAT_R32UI:
c = Insert(c, Int(*Pointer<UInt>(element)), 0); c = Insert(c, Int(*Pointer<UInt>(element)), 0);
c = Insert(c, Int(UInt(0xFFFFFFFFU)), 3); // Set alpha
break; break;
default: default:
return false; return false;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment