Add texture format range functions with correct types
authorMika Isojärvi <misojarvi@google.com>
Mon, 17 Aug 2015 22:54:12 +0000 (15:54 -0700)
committerPyry Haulos <phaulos@google.com>
Thu, 20 Aug 2015 22:04:31 +0000 (22:04 +0000)
Change-Id: I1a6891659406d5a4913de3bab6494f858cd68e19
(cherry picked from commit b0efcb495999162fadf75e9630a712ed1643a244)

framework/common/tcuTextureUtil.cpp
framework/common/tcuTextureUtil.hpp

index 2591f10fda8e4875a1766299f5e14d2f66b079aa..3fdfc0b1e53e8b61a26e9a63f79666e3c51e994b 100644 (file)
@@ -234,7 +234,7 @@ ConstPixelBufferAccess flipYAccess (const ConstPixelBufferAccess& access)
        return ConstPixelBufferAccess(access.getFormat(), access.getSize(), pitch, (deUint8*)access.getDataPtr() + offsetToLast);
 }
 
-static Vec2 getChannelValueRange (TextureFormat::ChannelType channelType)
+static Vec2 getFloatChannelValueRange (TextureFormat::ChannelType channelType)
 {
        // make sure this table is updated if format table is updated
        DE_STATIC_ASSERT(TextureFormat::CHANNELTYPE_LAST == 27);
@@ -306,7 +306,7 @@ TextureFormatInfo getTextureFormatInfo (const TextureFormat& format)
                                                                 Vec4(1.0f, 1.0f, 1.0f, 1.0f),
                                                                 Vec4(0.0f, 0.0f, 0.0f, 0.0f));
 
-       const Vec2                                              cRange          = getChannelValueRange(format.type);
+       const Vec2                                              cRange          = getFloatChannelValueRange(format.type);
        const TextureSwizzle::Channel*  map                     = getChannelReadSwizzle(format.order).components;
        const BVec4                                             chnMask         = BVec4(deInRange32(map[0], TextureSwizzle::CHANNEL_0, TextureSwizzle::CHANNEL_3) == DE_TRUE,
                                                                                                                deInRange32(map[1], TextureSwizzle::CHANNEL_0, TextureSwizzle::CHANNEL_3) == DE_TRUE,
@@ -321,6 +321,58 @@ TextureFormatInfo getTextureFormatInfo (const TextureFormat& format)
                                                         select(bias,           0.0f, chnMask));
 }
 
+IVec4 getFormatMinIntValue (const TextureFormat& format)
+{
+       DE_ASSERT(getTextureChannelClass(format.type) == TEXTURECHANNELCLASS_SIGNED_INTEGER);
+
+       switch (format.type)
+       {
+               case TextureFormat::SIGNED_INT8:        return IVec4(-128);
+               case TextureFormat::SIGNED_INT16:       return IVec4(-32768);
+               case TextureFormat::SIGNED_INT32:       return IVec4(-2147483648);
+
+               default:
+                       DE_FATAL("Invalid channel type");
+                       return IVec4(0);
+       }
+}
+
+IVec4 getFormatMaxIntValue (const TextureFormat& format)
+{
+       DE_ASSERT(getTextureChannelClass(format.type) == TEXTURECHANNELCLASS_SIGNED_INTEGER);
+
+       switch (format.type)
+       {
+               case TextureFormat::SIGNED_INT8:        return IVec4(127);
+               case TextureFormat::SIGNED_INT16:       return IVec4(32767);
+               case TextureFormat::SIGNED_INT32:       return IVec4(2147483647);
+
+               default:
+                       DE_FATAL("Invalid channel type");
+                       return IVec4(0);
+       }
+}
+
+UVec4 getFormatMaxUintValue (const TextureFormat& format)
+{
+       DE_ASSERT(getTextureChannelClass(format.type) == TEXTURECHANNELCLASS_UNSIGNED_INTEGER);
+
+       if (format == TextureFormat(TextureFormat::RGBA, TextureFormat::UNSIGNED_INT_1010102_REV))
+               return UVec4(1023u, 1023u, 1023u, 3u);
+
+       switch (format.type)
+       {
+               case TextureFormat::UNSIGNED_INT8:      return UVec4(255u);
+               case TextureFormat::UNSIGNED_INT16:     return UVec4(65535u);
+               case TextureFormat::UNSIGNED_INT24:     return UVec4(16777215u);
+               case TextureFormat::UNSIGNED_INT32:     return UVec4(4294967295u);
+
+               default:
+                       DE_FATAL("Invalid channel type");
+                       return UVec4(0);
+       }
+}
+
 static IVec4 getChannelBitDepth (TextureFormat::ChannelType channelType)
 {
        // make sure this table is updated if format table is updated
index c51e303938d6d42f28399afba38495d175b81ba7..b714a70a4ff788a409676c55ff7aa16ed6f777a7 100644 (file)
@@ -86,6 +86,11 @@ IVec4                                getTextureFormatBitDepth                        (const TextureFormat& format);
 IVec4                          getTextureFormatMantissaBitDepth        (const TextureFormat& format);
 BVec4                          getTextureFormatChannelMask                     (const TextureFormat& format);
 
+IVec4                          getFormatMinIntValue                            (const TextureFormat& format);
+IVec4                          getFormatMaxIntValue                            (const TextureFormat& format);
+
+UVec4                          getFormatMaxUintValue                           (const TextureFormat& format);
+
 // Texture fill.
 void   clear                                                   (const PixelBufferAccess& access, const Vec4& color);
 void   clear                                                   (const PixelBufferAccess& access, const IVec4& color);