diff options
Diffstat (limited to 'progs/gallium')
| -rwxr-xr-x | progs/gallium/python/retrace/interpreter.py | 1 | ||||
| -rw-r--r-- | progs/gallium/python/samples/tri.py | 21 | ||||
| -rwxr-xr-x | progs/gallium/python/tests/base.py | 91 | ||||
| -rwxr-xr-x | progs/gallium/python/tests/surface_copy.py | 130 | ||||
| -rwxr-xr-x | progs/gallium/python/tests/texture_blit.py (renamed from progs/gallium/python/tests/texture_sample.py) | 203 | ||||
| -rwxr-xr-x | progs/gallium/python/tests/texture_render.py | 4 | ||||
| -rwxr-xr-x | progs/gallium/python/tests/texture_transfer.py | 115 | ||||
| -rw-r--r-- | progs/gallium/raw/SConscript | 17 | ||||
| -rw-r--r-- | progs/gallium/raw/clear.c | 95 | ||||
| -rw-r--r-- | progs/gallium/trivial/.gitignore | 3 | ||||
| -rw-r--r-- | progs/gallium/trivial/Makefile | 44 | ||||
| -rw-r--r-- | progs/gallium/trivial/quad-tex.c | 346 | ||||
| -rw-r--r-- | progs/gallium/trivial/tri.c | 278 | ||||
| -rw-r--r-- | progs/gallium/unit/Makefile | 44 | ||||
| -rw-r--r-- | progs/gallium/unit/SConscript | 5 | ||||
| -rw-r--r-- | progs/gallium/unit/u_format_test.c | 1034 | ||||
| -rw-r--r-- | progs/gallium/unit/u_half_test.c | 32 | 
17 files changed, 1688 insertions, 775 deletions
| diff --git a/progs/gallium/python/retrace/interpreter.py b/progs/gallium/python/retrace/interpreter.py index b30469dfae..1a96181255 100755 --- a/progs/gallium/python/retrace/interpreter.py +++ b/progs/gallium/python/retrace/interpreter.py @@ -551,7 +551,6 @@ class Context(Object):                  data = vbuf.buffer.read()                  values = unpack_from(format, data, offset)                  sys.stdout.write('\t\t{' + ', '.join(map(str, values)) + '},\n') -                assert len(values) == velem.nr_components              sys.stdout.write('\t},\n')          sys.stdout.flush() diff --git a/progs/gallium/python/samples/tri.py b/progs/gallium/python/samples/tri.py index d7fbdb10ac..8cc272db81 100644 --- a/progs/gallium/python/samples/tri.py +++ b/progs/gallium/python/samples/tri.py @@ -30,19 +30,19 @@  from gallium import * -def make_image(surface): -    data = surface.get_tile_rgba8(0, 0, surface.width, surface.height) +def make_image(ctx, surface): +    data = ctx.surface_read_rgba8(surface, 0, 0, surface.width, surface.height)      import Image      outimage = Image.fromstring('RGBA', (surface.width, surface.height), data, "raw", 'RGBA', 0, 1)      return outimage -def save_image(filename, surface): -    outimage = make_image(surface) +def save_image(ctx, surface, filename): +    outimage = make_image(ctx, surface)      outimage.save(filename, "PNG") -def show_image(surface): -    outimage = make_image(surface) +def show_image(ctx, surface): +    outimage = make_image(ctx, surface)      import Tkinter as tk      from PIL import Image, ImageTk @@ -128,6 +128,7 @@ def test(dev):      scissor.maxy = height      ctx.set_scissor(scissor) +    # clip      clip = Clip()      clip.nr = 0      ctx.set_clip(clip) @@ -216,10 +217,10 @@ def test(dev):      ctx.flush() -    show_image(cbuf) -    #show_image(zbuf) -    #save_image('cbuf.png', cbuf) -    #save_image('zbuf.png', zbuf) +    show_image(ctx, cbuf) +    show_image(ctx, zbuf) +    save_image(ctx, cbuf, 'cbuf.png') +    save_image(ctx, zbuf, 'zbuf.png') diff --git a/progs/gallium/python/tests/base.py b/progs/gallium/python/tests/base.py index bd82f50811..d8cf84db36 100755 --- a/progs/gallium/python/tests/base.py +++ b/progs/gallium/python/tests/base.py @@ -43,18 +43,9 @@ from gallium import *  # Enumerate all pixel formats  formats = {}  for name, value in globals().items(): -    if name.startswith("PIPE_FORMAT_") and isinstance(value, int): +    if name.startswith("PIPE_FORMAT_") and isinstance(value, int) and name not in ("PIPE_FORMAT_NONE", "PIPE_FORMAT_COUNT"):          formats[value] = name -def is_depth_stencil_format(format): -    # FIXME: make and use binding to util_format_is_depth_or_stencil -    return format in ( -        PIPE_FORMAT_Z32_UNORM, -        PIPE_FORMAT_S8Z24_UNORM, -        PIPE_FORMAT_X8Z24_UNORM, -        PIPE_FORMAT_Z16_UNORM, -    ) -  def make_image(width, height, rgba):      import Image      outimage = Image.new( @@ -125,18 +116,18 @@ class Test:      def run(self):          result = TestResult()          self._run(result) -        result.summary() +        result.report() -    def assert_rgba(self, surface, x, y, w, h, expected_rgba, pixel_tol=4.0/256, surface_tol=0.85): +    def assert_rgba(self, ctx, surface, x, y, w, h, expected_rgba, pixel_tol=4.0/256, surface_tol=0.85):          total = h*w -        different = surface.compare_tile_rgba(x, y, w, h, expected_rgba, tol=pixel_tol) +        different = ctx.surface_compare_rgba(surface, x, y, w, h, expected_rgba, tol=pixel_tol)          if different:              sys.stderr.write("%u out of %u pixels differ\n" % (different, total))          if float(total - different)/float(total) < surface_tol:              if 0:                  rgba = FloatArray(h*w*4) -                surface.get_tile_rgba(x, y, w, h, rgba) +                ctx.surface_read_rgba(surface, x, y, w, h, rgba)                  show_image(w, h, Result=rgba, Expected=expected_rgba)                  save_image(w, h, rgba, "result.png")                  save_image(w, h, expected_rgba, "expected.png") @@ -259,7 +250,7 @@ class TestResult:          sys.stdout.write("SKIP\n")          sys.stdout.flush()          self.skipped += 1 -        #self.log_result(test, 'skip') +        self.log_result(test, 'skip')      def test_failed(self, test):          sys.stdout.write("FAIL\n") @@ -305,11 +296,16 @@ class TestResult:          self.rows.append(row) -    def summary(self): +    def report(self):          sys.stdout.write("%u tests, %u passed, %u skipped, %u failed\n\n" % (self.tests, self.passed, self.skipped, self.failed))          sys.stdout.flush()          name, ext = os.path.splitext(os.path.basename(sys.argv[0])) + +        tree = self.report_tree(name) +        self.report_junit(name, stdout=tree) + +    def report_tree(self, name):          filename = name + '.tsv'          stream = file(filename, 'wt') @@ -320,6 +316,8 @@ class TestResult:          # rows          for row in self.rows: +            if row[0] == 'skip': +                continue              row += ['']*(len(self.names) - len(row))              stream.write('\t'.join(row) + '\n') @@ -331,7 +329,7 @@ class TestResult:              import orngTree          except ImportError:              sys.stderr.write('Install Orange from http://www.ailab.si/orange/ for a classification tree.\n') -            return +            return None          data = orange.ExampleTable(filename) @@ -339,6 +337,63 @@ class TestResult:          orngTree.printTxt(tree, maxDepth=4) -        file(name+'.txt', 'wt').write(orngTree.dumpTree(tree)) +        text_tree = orngTree.dumpTree(tree) + +        file(name + '.txt', 'wt').write(text_tree)          orngTree.printDot(tree, fileName=name+'.dot', nodeShape='ellipse', leafShape='box') + +        return text_tree +     +    def report_junit(self, name, stdout=None, stderr=None): +        """Write test results in ANT's junit XML format, to use with Hudson CI. + +        See also: +        - http://fisheye.hudson-ci.org/browse/Hudson/trunk/hudson/main/core/src/test/resources/hudson/tasks/junit +        - http://www.junit.org/node/399 +        - http://wiki.apache.org/ant/Proposals/EnhancedTestReports +        """ + +        stream = file(name + '.xml', 'wt') + +        stream.write('<?xml version="1.0" encoding="UTF-8" ?>\n') +        stream.write('<testsuite name="%s">\n' % self.escape_xml(name)) +        stream.write('  <properties>\n') +        stream.write('  </properties>\n') + +        names = self.names[1:] + +        for row in self.rows: + +            test_name = ' '.join(['%s=%s' % pair for pair in zip(self.names[1:], row[1:])]) + +            stream.write('  <testcase name="%s">\n' % (self.escape_xml(test_name))) + +            result = row[0] +            if result == 'pass': +                pass +            elif result == 'skip': +                stream.write('    <skipped/>\n') +            else: +                stream.write('    <failure/>\n') +             +            stream.write('  </testcase>\n') + +        if stdout: +            stream.write('  <system-out>%s</system-out>\n' % self.escape_xml(stdout)) +        if stderr: +            stream.write('  <system-err>%s</system-err>\n' % self.escape_xml(stderr)) + +        stream.write('</testsuite>\n') + +        stream.close() + +    def escape_xml(self, s): +        '''Escape a XML string.''' +        s = s.replace('&', '&') +        s = s.replace('<', '<') +        s = s.replace('>', '>') +        s = s.replace('"', '"') +        s = s.replace("'", ''') +        return s + diff --git a/progs/gallium/python/tests/surface_copy.py b/progs/gallium/python/tests/surface_copy.py index a3f1b3e130..3eefa690bd 100755 --- a/progs/gallium/python/tests/surface_copy.py +++ b/progs/gallium/python/tests/surface_copy.py @@ -27,6 +27,9 @@  ########################################################################## +import os +import random +  from gallium import *  from base import * @@ -56,6 +59,7 @@ class TextureTest(TestCase):      def test(self):          dev = self.dev +        ctx = self.ctx          target = self.target          format = self.format @@ -67,6 +71,14 @@ class TextureTest(TestCase):          level = self.level          zslice = self.zslice +        tex_usage = PIPE_TEXTURE_USAGE_SAMPLER +        geom_flags = 0 +        if not dev.is_format_supported(format, target, tex_usage, geom_flags): +            raise TestSkip + +        if not dev.is_format_supported(format, target, tex_usage, geom_flags): +            raise TestSkip +          #  textures          dst_texture = dev.texture_create(              target = target, @@ -75,10 +87,8 @@ class TextureTest(TestCase):              height = height,              depth = depth,               last_level = last_level, -            tex_usage = PIPE_TEXTURE_USAGE_RENDER_TARGET, +            tex_usage = tex_usage,          ) -        if dst_texture is None: -            raise TestSkip          dst_surface = dst_texture.get_surface(face = face, level = level, zslice = zslice) @@ -94,60 +104,33 @@ class TextureTest(TestCase):          src_surface = src_texture.get_surface() -        x = 0 -        y = 0          w = dst_surface.width          h = dst_surface.height -        # ??? -        stride = pf_get_stride(texture->format, w) -        size = pf_get_nblocksy(texture->format) * stride +        stride = util_format_get_stride(format, w) +        size = util_format_get_nblocksy(format, h) * stride          src_raw = os.urandom(size) -        src_surface.put_tile_raw(0, 0, w, h, src_raw, stride) +        ctx.surface_write_raw(src_surface, 0, 0, w, h, src_raw, stride) -        ctx = self.dev.context_create() -              ctx.surface_copy(dst_surface, 0, 0,                            src_surface, 0, 0, w, h) -        ctx.flush() - -        dst_raw = dst_surface.get_tile_raw(0, 0, w, h) +        dst_raw = ctx.surface_read_raw(dst_surface, 0, 0, w, h)          if dst_raw != src_raw:              raise TestFailure -          def main():      dev = Device() +    ctx = dev.context_create()      suite = TestSuite()      targets = [          PIPE_TEXTURE_2D,          PIPE_TEXTURE_CUBE, -        #PIPE_TEXTURE_3D, -    ] -     -    formats = [ -        PIPE_FORMAT_B8G8R8A8_UNORM, -        PIPE_FORMAT_B8G8R8X8_UNORM, -        PIPE_FORMAT_B8G8R8A8_SRGB, -        PIPE_FORMAT_B5G6R5_UNORM, -        PIPE_FORMAT_B5G5R5A1_UNORM, -        PIPE_FORMAT_B4G4R4A4_UNORM, -        PIPE_FORMAT_Z32_UNORM, -        PIPE_FORMAT_S8Z24_UNORM, -        PIPE_FORMAT_X8Z24_UNORM, -        PIPE_FORMAT_Z16_UNORM, -        PIPE_FORMAT_S8_UNORM, -        PIPE_FORMAT_A8_UNORM, -        PIPE_FORMAT_L8_UNORM, -        PIPE_FORMAT_DXT1_RGB, -        PIPE_FORMAT_DXT1_RGBA, -        PIPE_FORMAT_DXT3_RGBA, -        PIPE_FORMAT_DXT5_RGBA, +        PIPE_TEXTURE_3D,      ]      sizes = [64, 32, 16, 8, 4, 2, 1] @@ -164,35 +147,52 @@ def main():          PIPE_TEX_FACE_NEG_Z,      ] -    for target in targets: -        for format in formats: -            for size in sizes: -                if target == PIPE_TEXTURE_3D: -                    depth = size -                else: -                    depth = 1 -                for face in faces: -                    if target != PIPE_TEXTURE_CUBE and face: -                        continue -                    levels = lods(size) -                    for last_level in range(levels): -                        for level in range(0, last_level + 1): -                            zslice = 0 -                            while zslice < depth >> level: -                                test = TextureTest( -                                    dev = dev, -                                    target = target, -                                    format = format,  -                                    width = size, -                                    height = size, -                                    depth = depth, -                                    last_level = last_level, -                                    face = face, -                                    level = level, -                                    zslice = zslice, -                                ) -                                suite.add_test(test) -                                zslice = (zslice + 1)*2 - 1 +    try: +        n = int(sys.argv[1]) +    except: +        n = 10000 +     +    for i in range(n): +        format = random.choice(formats.keys()) +        if not util_format_is_depth_or_stencil(format): +            is_depth_or_stencil = util_format_is_depth_or_stencil(format) + +            if is_depth_or_stencil: +                target = PIPE_TEXTURE_2D +            else: +                target = random.choice(targets) +             +            size = random.choice(sizes) + +            if target == PIPE_TEXTURE_3D: +                depth = size +            else: +                depth = 1 + +            if target == PIPE_TEXTURE_CUBE: +                face = random.choice(faces) +            else: +                face = PIPE_TEX_FACE_POS_X + +            levels = lods(size) +            last_level = random.randint(0, levels - 1) +            level = random.randint(0, last_level) +            zslice = random.randint(0, max(depth >> level, 1) - 1) + +            test = TextureTest( +                dev = dev, +                ctx = ctx, +                target = target, +                format = format,  +                width = size, +                height = size, +                depth = depth, +                last_level = last_level, +                face = face, +                level = level, +                zslice = zslice, +            ) +            suite.add_test(test)      suite.run() diff --git a/progs/gallium/python/tests/texture_sample.py b/progs/gallium/python/tests/texture_blit.py index 49545c2e07..a68c081931 100755 --- a/progs/gallium/python/tests/texture_sample.py +++ b/progs/gallium/python/tests/texture_blit.py @@ -28,6 +28,8 @@  ########################################################################## +import random +  from gallium import *  from base import * @@ -115,6 +117,7 @@ class TextureColorSampleTest(TestCase):      def test(self):          dev = self.dev +        ctx = self.ctx          target = self.target          format = self.format @@ -125,6 +128,8 @@ class TextureColorSampleTest(TestCase):          face = self.face          level = self.level          zslice = self.zslice +        minz = 0.0 +        maxz = 1.0          tex_usage = PIPE_TEXTURE_USAGE_SAMPLER          geom_flags = 0 @@ -136,8 +141,6 @@ class TextureColorSampleTest(TestCase):          if not dev.is_format_supported(format, target, tex_usage, geom_flags):              raise TestSkip -        ctx = self.dev.context_create() -              # disabled blending/masking          blend = Blend()          blend.rt[0].rgb_src_factor = PIPE_BLENDFACTOR_ONE @@ -155,7 +158,6 @@ class TextureColorSampleTest(TestCase):          rasterizer = Rasterizer()          rasterizer.front_winding = PIPE_WINDING_CW          rasterizer.cull_mode = PIPE_WINDING_NONE -        rasterizer.bypass_vs_clip_and_viewport = 1          ctx.set_rasterizer(rasterizer)          # samplers @@ -183,14 +185,45 @@ class TextureColorSampleTest(TestCase):          )          expected_rgba = FloatArray(height*width*4)  -        texture.get_surface( +        surface = texture.get_surface(              face = face,              level = level,              zslice = zslice, -        ).sample_rgba(expected_rgba) +        ) +         +        ctx.surface_sample_rgba(surface, expected_rgba, True)          ctx.set_fragment_sampler_texture(0, texture) +        # viewport +        viewport = Viewport() +        scale = FloatArray(4) +        scale[0] = width +        scale[1] = height +        scale[2] = (maxz - minz) / 2.0 +        scale[3] = 1.0 +        viewport.scale = scale +        translate = FloatArray(4) +        translate[0] = 0.0 +        translate[1] = 0.0 +        translate[2] = (maxz - minz) / 2.0 +        translate[3] = 0.0 +        viewport.translate = translate +        ctx.set_viewport(viewport) + +        # scissor +        scissor = Scissor() +        scissor.minx = 0 +        scissor.miny = 0 +        scissor.maxx = width +        scissor.maxy = height +        ctx.set_scissor(scissor) + +        # clip +        clip = Clip() +        clip.nr = 0 +        ctx.set_clip(clip) +          #  framebuffer           cbuf_tex = dev.texture_create(              PIPE_FORMAT_B8G8R8A8_UNORM,  @@ -265,8 +298,8 @@ class TextureColorSampleTest(TestCase):          for i in range(0, 4):              j = 8*i -            verts[j + 0] = pos[i][0] # x -            verts[j + 1] = pos[i][1] # y +            verts[j + 0] = pos[i][0]/float(width) # x +            verts[j + 1] = pos[i][1]/float(height) # y              verts[j + 2] = 0.0 # z              verts[j + 3] = 1.0 # w              verts[j + 4] = tex[i][0] # s @@ -283,7 +316,7 @@ class TextureColorSampleTest(TestCase):          cbuf = cbuf_tex.get_surface() -        self.assert_rgba(cbuf, x, y, w, h, expected_rgba, 4.0/256, 0.85) +        self.assert_rgba(ctx, cbuf, x, y, w, h, expected_rgba, 4.0/256, 0.85)  class TextureDepthSampleTest(TestCase): @@ -302,6 +335,7 @@ class TextureDepthSampleTest(TestCase):      def test(self):          dev = self.dev +        ctx = self.ctx          target = self.target          format = self.format @@ -312,6 +346,8 @@ class TextureDepthSampleTest(TestCase):          face = self.face          level = self.level          zslice = self.zslice +        minz = 0.0 +        maxz = 1.0          tex_usage = PIPE_TEXTURE_USAGE_SAMPLER          geom_flags = 0 @@ -323,8 +359,6 @@ class TextureDepthSampleTest(TestCase):          if not dev.is_format_supported(format, target, tex_usage, geom_flags):              raise TestSkip -        ctx = self.dev.context_create() -              # disabled blending/masking          blend = Blend()          blend.rt[0].rgb_src_factor = PIPE_BLENDFACTOR_ONE @@ -345,9 +379,24 @@ class TextureDepthSampleTest(TestCase):          rasterizer = Rasterizer()          rasterizer.front_winding = PIPE_WINDING_CW          rasterizer.cull_mode = PIPE_WINDING_NONE -        rasterizer.bypass_vs_clip_and_viewport = 1          ctx.set_rasterizer(rasterizer) +        # viewport +        viewport = Viewport() +        scale = FloatArray(4) +        scale[0] = width +        scale[1] = height +        scale[2] = (maxz - minz) / 2.0 +        scale[3] = 1.0 +        viewport.scale = scale +        translate = FloatArray(4) +        translate[0] = 0.0 +        translate[1] = 0.0 +        translate[2] = (maxz - minz) / 2.0 +        translate[3] = 0.0 +        viewport.translate = translate +        ctx.set_viewport(viewport) +          # samplers          sampler = Sampler()          sampler.wrap_s = PIPE_TEX_WRAP_CLAMP_TO_EDGE @@ -373,14 +422,29 @@ class TextureDepthSampleTest(TestCase):          )          expected_rgba = FloatArray(height*width*4)  -        texture.get_surface( +        surface = texture.get_surface(              face = face,              level = level,              zslice = zslice, -        ).sample_rgba(expected_rgba) +        ) + +        ctx.surface_sample_rgba(surface, expected_rgba, True)          ctx.set_fragment_sampler_texture(0, texture) +        # scissor +        scissor = Scissor() +        scissor.minx = 0 +        scissor.miny = 0 +        scissor.maxx = width +        scissor.maxy = height +        ctx.set_scissor(scissor) + +        # clip +        clip = Clip() +        clip.nr = 0 +        ctx.set_clip(clip) +          #  framebuffer           cbuf_tex = dev.texture_create(              PIPE_FORMAT_B8G8R8A8_UNORM,  @@ -464,8 +528,8 @@ class TextureDepthSampleTest(TestCase):          for i in range(0, 4):              j = 8*i -            verts[j + 0] = pos[i][0] # x -            verts[j + 1] = pos[i][1] # y +            verts[j + 0] = pos[i][0]/float(width) # x +            verts[j + 1] = pos[i][1]/float(height) # y              verts[j + 2] = 0.0 # z              verts[j + 3] = 1.0 # w              verts[j + 4] = tex[i][0] # s @@ -482,13 +546,16 @@ class TextureDepthSampleTest(TestCase):          zsbuf = zsbuf_tex.get_surface() -        self.assert_rgba(zsbuf, x, y, w, h, expected_rgba, 4.0/256, 0.85) +        self.assert_rgba(ctx, zsbuf, x, y, w, h, expected_rgba, 4.0/256, 0.85)  def main(): +    random.seed(0xdead3eef) +      dev = Device() +    ctx = dev.context_create()      suite = TestSuite()      targets = [ @@ -497,32 +564,9 @@ def main():          PIPE_TEXTURE_3D,      ] -    color_formats = [ -        PIPE_FORMAT_B8G8R8A8_UNORM, -        PIPE_FORMAT_B8G8R8X8_UNORM, -        #PIPE_FORMAT_B8G8R8A8_SRGB, -        PIPE_FORMAT_B5G6R5_UNORM, -        PIPE_FORMAT_B5G5R5A1_UNORM, -        PIPE_FORMAT_B4G4R4A4_UNORM, -        PIPE_FORMAT_A8_UNORM, -        PIPE_FORMAT_L8_UNORM, -        PIPE_FORMAT_UYVY, -        PIPE_FORMAT_DXT1_RGB, -        #PIPE_FORMAT_DXT1_RGBA, -        #PIPE_FORMAT_DXT3_RGBA, -        #PIPE_FORMAT_DXT5_RGBA, -    ] -     -    depth_formats = [ -        PIPE_FORMAT_Z32_UNORM, -        PIPE_FORMAT_S8Z24_UNORM, -        PIPE_FORMAT_X8Z24_UNORM, -        PIPE_FORMAT_Z16_UNORM, -    ] -     -    sizes = [64, 32, 16, 8, 4, 2, 1] +    #sizes = [64, 32, 16, 8, 4, 2, 1]      #sizes = [1020, 508, 252, 62, 30, 14, 6, 3] -    #sizes = [64] +    sizes = [64]      #sizes = [63]      faces = [ @@ -534,45 +578,46 @@ def main():          PIPE_TEX_FACE_NEG_Z,      ] -    for format in color_formats: -        for target in targets: -            for size in sizes: -                if target == PIPE_TEXTURE_3D: -                    depth = size -                else: -                    depth = 1 -                for face in faces: -                    if target != PIPE_TEXTURE_CUBE and face: -                        continue -                    levels = lods(size) -                    for last_level in range(levels): -                        for level in range(0, last_level + 1): -                            zslice = 0 -                            while zslice < depth >> level: -                                test = TextureColorSampleTest( -                                    dev = dev, -                                    target = target, -                                    format = format,  -                                    width = size, -                                    height = size, -                                    depth = depth, -                                    last_level = last_level, -                                    face = face, -                                    level = level, -                                    zslice = zslice, -                                ) -                                suite.add_test(test) -                                zslice = (zslice + 1)*2 - 1 -    for format in depth_formats: -        target = PIPE_TEXTURE_2D -        depth = 1 -        face = 0 -        last_level = 0 -        level = 0 -        zslice = 0 -        for size in sizes: -            test = TextureDepthSampleTest( +    try: +        n = int(sys.argv[1]) +    except: +        n = 10000 +     +    for i in range(n): +        format = random.choice(formats.keys()) +        if not util_format_is_depth_or_stencil(format): +            is_depth_or_stencil = util_format_is_depth_or_stencil(format) + +            if is_depth_or_stencil: +                target = PIPE_TEXTURE_2D +            else: +                target = random.choice(targets) +             +            size = random.choice(sizes) + +            if target == PIPE_TEXTURE_3D: +                depth = size +            else: +                depth = 1 + +            if target == PIPE_TEXTURE_CUBE: +                face = random.choice(faces) +            else: +                face = PIPE_TEX_FACE_POS_X + +            levels = lods(size) +            last_level = random.randint(0, levels - 1) +            level = random.randint(0, last_level) +            zslice = random.randint(0, max(depth >> level, 1) - 1) + +            if is_depth_or_stencil: +                klass = TextureDepthSampleTest +            else: +                klass = TextureColorSampleTest + +            test = klass(                  dev = dev, +                ctx = ctx,                  target = target,                  format = format,                   width = size, diff --git a/progs/gallium/python/tests/texture_render.py b/progs/gallium/python/tests/texture_render.py index 1e26639db6..12def7ec72 100755 --- a/progs/gallium/python/tests/texture_render.py +++ b/progs/gallium/python/tests/texture_render.py @@ -258,10 +258,10 @@ def main():          PIPE_FORMAT_B5G5R5A1_UNORM,          PIPE_FORMAT_B4G4R4A4_UNORM,          #PIPE_FORMAT_Z32_UNORM, -        #PIPE_FORMAT_S8Z24_UNORM, +        #PIPE_FORMAT_S8_USCALED_Z24_UNORM,          #PIPE_FORMAT_X8Z24_UNORM,          #PIPE_FORMAT_Z16_UNORM, -        #PIPE_FORMAT_S8_UNORM, +        #PIPE_FORMAT_S8_USCALED,          PIPE_FORMAT_A8_UNORM,          PIPE_FORMAT_L8_UNORM,          #PIPE_FORMAT_DXT1_RGB, diff --git a/progs/gallium/python/tests/texture_transfer.py b/progs/gallium/python/tests/texture_transfer.py index 7da00e4255..639d3d362c 100755 --- a/progs/gallium/python/tests/texture_transfer.py +++ b/progs/gallium/python/tests/texture_transfer.py @@ -29,6 +29,7 @@  import os +import random  from gallium import *  from base import * @@ -59,6 +60,7 @@ class TextureTest(TestCase):      def test(self):          dev = self.dev +        ctx = self.ctx          target = self.target          format = self.format @@ -70,8 +72,12 @@ class TextureTest(TestCase):          level = self.level          zslice = self.zslice -        tex_usage = 0 +        tex_usage = PIPE_TEXTURE_USAGE_SAMPLER +        geom_flags = 0 +        if not dev.is_format_supported(format, target, tex_usage, geom_flags): +            raise TestSkip +        #  textures          texture = dev.texture_create(              target = target,              format = format,  @@ -81,20 +87,17 @@ class TextureTest(TestCase):              last_level = last_level,              tex_usage = tex_usage,          ) -        if texture is None: -            raise TestSkip          surface = texture.get_surface(face, level, zslice) -        # ??? -        stride = pf_get_stride(texture->format, w) -        size = pf_get_nblocksy(texture->format) * stride +        stride = util_format_get_stride(format, surface.width) +        size = util_format_get_nblocksy(format, surface.height) * stride          in_raw = os.urandom(size) -        surface.put_tile_raw(0, 0, surface.width, surface.height, in_raw, stride) +        ctx.surface_write_raw(surface, 0, 0, surface.width, surface.height, in_raw, stride) -        out_raw = surface.get_tile_raw(0, 0, surface.width, surface.height) +        out_raw = ctx.surface_read_raw(surface, 0, 0, surface.width, surface.height)          if in_raw != out_raw:              raise TestFailure @@ -102,6 +105,7 @@ class TextureTest(TestCase):  def main():      dev = Device() +    ctx = dev.context_create()      suite = TestSuite()      targets = [ @@ -110,26 +114,6 @@ def main():          PIPE_TEXTURE_3D,      ] -    formats = [ -        PIPE_FORMAT_B8G8R8A8_UNORM, -        PIPE_FORMAT_B8G8R8X8_UNORM, -        PIPE_FORMAT_B8G8R8A8_SRGB, -        PIPE_FORMAT_B5G6R5_UNORM, -        PIPE_FORMAT_B5G5R5A1_UNORM, -        PIPE_FORMAT_B4G4R4A4_UNORM, -        PIPE_FORMAT_Z32_UNORM, -        PIPE_FORMAT_S8Z24_UNORM, -        PIPE_FORMAT_X8Z24_UNORM, -        PIPE_FORMAT_Z16_UNORM, -        PIPE_FORMAT_S8_UNORM, -        PIPE_FORMAT_A8_UNORM, -        PIPE_FORMAT_L8_UNORM, -        PIPE_FORMAT_DXT1_RGB, -        PIPE_FORMAT_DXT1_RGBA, -        PIPE_FORMAT_DXT3_RGBA, -        PIPE_FORMAT_DXT5_RGBA, -    ] -          sizes = [64, 32, 16, 8, 4, 2, 1]      #sizes = [1020, 508, 252, 62, 30, 14, 6, 3]      #sizes = [64] @@ -144,35 +128,52 @@ def main():          PIPE_TEX_FACE_NEG_Z,      ] -    for target in targets: -        for format in formats: -            for size in sizes: -                if target == PIPE_TEXTURE_3D: -                    depth = size -                else: -                    depth = 1 -                for face in faces: -                    if target != PIPE_TEXTURE_CUBE and face: -                        continue -                    levels = lods(size) -                    for last_level in range(levels): -                        for level in range(0, last_level + 1): -                            zslice = 0 -                            while zslice < depth >> level: -                                test = TextureTest( -                                    dev = dev, -                                    target = target, -                                    format = format,  -                                    width = size, -                                    height = size, -                                    depth = depth, -                                    last_level = last_level, -                                    face = face, -                                    level = level, -                                    zslice = zslice, -                                ) -                                suite.add_test(test) -                                zslice = (zslice + 1)*2 - 1 +    try: +        n = int(sys.argv[1]) +    except: +        n = 10000 +     +    for i in range(n): +        format = random.choice(formats.keys()) +        if not util_format_is_depth_or_stencil(format): +            is_depth_or_stencil = util_format_is_depth_or_stencil(format) + +            if is_depth_or_stencil: +                target = PIPE_TEXTURE_2D +            else: +                target = random.choice(targets) +             +            size = random.choice(sizes) + +            if target == PIPE_TEXTURE_3D: +                depth = size +            else: +                depth = 1 + +            if target == PIPE_TEXTURE_CUBE: +                face = random.choice(faces) +            else: +                face = PIPE_TEX_FACE_POS_X + +            levels = lods(size) +            last_level = random.randint(0, levels - 1) +            level = random.randint(0, last_level) +            zslice = random.randint(0, max(depth >> level, 1) - 1) + +            test = TextureTest( +                dev = dev, +                ctx = ctx, +                target = target, +                format = format,  +                width = size, +                height = size, +                depth = depth, +                last_level = last_level, +                face = face, +                level = level, +                zslice = zslice, +            ) +            suite.add_test(test)      suite.run() diff --git a/progs/gallium/raw/SConscript b/progs/gallium/raw/SConscript new file mode 100644 index 0000000000..073b97951e --- /dev/null +++ b/progs/gallium/raw/SConscript @@ -0,0 +1,17 @@ +Import('*') + +env = env.Clone() + +env.Prepend(LIBPATH = [graw.dir]) +env.Prepend(LIBS = [graw.name]) + +progs = [ +    'clear' +] + +for prog in progs: +    env.Program( +        target = prog, +        source = prog + '.c', +    ) + diff --git a/progs/gallium/raw/clear.c b/progs/gallium/raw/clear.c new file mode 100644 index 0000000000..5ef5254edc --- /dev/null +++ b/progs/gallium/raw/clear.c @@ -0,0 +1,95 @@ +/* Display a cleared blue window.  This demo has no dependencies on + * any utility code, just the graw interface and gallium. + */ + +#include "state_tracker/graw.h" +#include "pipe/p_screen.h" +#include "pipe/p_context.h" +#include "pipe/p_state.h" +#include "pipe/p_defines.h" +#include <unistd.h>             /* for sleep() */ + +#include "util/u_debug.h"       /* debug_dump_surface_bmp() */ + +enum pipe_format formats[] = { +   PIPE_FORMAT_R8G8B8A8_UNORM, +   PIPE_FORMAT_B8G8R8A8_UNORM, +   PIPE_FORMAT_NONE +}; + +static const int WIDTH = 300; +static const int HEIGHT = 300; + +int main( int argc, char *argv[] ) +{ +   struct pipe_screen *screen; +   struct pipe_context *pipe; +   struct pipe_surface *surf; +   struct pipe_framebuffer_state fb; +   struct pipe_texture *tex, templat; +   void *window = NULL; +   float clear_color[4] = {1,0,1,1}; +   int i; + +   screen = graw_init(); +   if (screen == NULL) +      exit(1); + +   for (i = 0;  +        window == NULL && formats[i] != PIPE_FORMAT_NONE; +        i++) { +       +      window = graw_create_window(0,0,300,300, formats[i]); +   } +    +   if (window == NULL) +      exit(2); +    +   pipe = screen->context_create(screen, NULL); +   if (pipe == NULL) +      exit(3); + +   templat.target = PIPE_TEXTURE_2D; +   templat.format = formats[i]; +   templat.width0 = WIDTH; +   templat.height0 = HEIGHT; +   templat.depth0 = 1; +   templat.last_level = 0; +   templat.nr_samples = 1; +   templat.tex_usage = (PIPE_TEXTURE_USAGE_RENDER_TARGET | +                        PIPE_TEXTURE_USAGE_DISPLAY_TARGET); +    +   tex = screen->texture_create(screen, +                                &templat); +   if (tex == NULL) +      exit(4); + +   surf = screen->get_tex_surface(screen, tex, 0, 0, 0, +                                  PIPE_TEXTURE_USAGE_RENDER_TARGET | +                                  PIPE_TEXTURE_USAGE_DISPLAY_TARGET); +   if (surf == NULL) +      exit(5); + +   memset(&fb, 0, sizeof fb); +   fb.nr_cbufs = 1; +   fb.width = WIDTH; +   fb.height = HEIGHT; +   fb.cbufs[0] = surf; + +   pipe->set_framebuffer_state(pipe, &fb); +   pipe->clear(pipe, PIPE_CLEAR_COLOR, clear_color, 0, 0); +   pipe->flush(pipe, PIPE_FLUSH_RENDER_CACHE, NULL); + +   /* At the moment, libgraw includes/makes available all the symbols +    * from gallium/auxiliary, including these debug helpers.  Will +    * eventually want to bless some of these paths, and lock the +    * others down so they aren't accessible from test programs. +    */ +   if (0) +      debug_dump_surface_bmp(pipe, "result.bmp", surf); + +   screen->flush_frontbuffer(screen, surf, window); + +   sleep(100); +   return 0; +} diff --git a/progs/gallium/trivial/.gitignore b/progs/gallium/trivial/.gitignore new file mode 100644 index 0000000000..af6cdedbeb --- /dev/null +++ b/progs/gallium/trivial/.gitignore @@ -0,0 +1,3 @@ +tri +quad-tex +result.bmp diff --git a/progs/gallium/trivial/Makefile b/progs/gallium/trivial/Makefile new file mode 100644 index 0000000000..2b8af1ac06 --- /dev/null +++ b/progs/gallium/trivial/Makefile @@ -0,0 +1,44 @@ +# progs/gallium/simple/Makefile + +TOP = ../../.. +include $(TOP)/configs/current + +INCLUDES = \ +	-I. \ +	-I$(TOP)/src/gallium/include \ +	-I$(TOP)/src/gallium/auxiliary \ +	-I$(TOP)/src/gallium/drivers \ +	-I$(TOP)/src/gallium/winsys \ +	$(PROG_INCLUDES) + +LINKS = \ +	$(TOP)/src/gallium/drivers/trace/libtrace.a \ +	$(TOP)/src/gallium/winsys/sw/null/libws_null.a \ +	$(TOP)/src/gallium/drivers/softpipe/libsoftpipe.a \ +	$(GALLIUM_AUXILIARIES) \ +	$(PROG_LINKS) + +SOURCES = \ +	tri.c \ +	quad-tex.c + +OBJECTS = $(SOURCES:.c=.o) + +PROGS = $(OBJECTS:.o=) + +##### TARGETS ##### + +default: $(PROGS) + +clean: +	-rm -f $(PROGS) +	-rm -f *.o +	-rm -f result.bmp + +##### RULES ##### + +$(OBJECTS): %.o: %.c +	$(CC) -c $(INCLUDES) $(CFLAGS) $(DEFINES) $(PROG_DEFINES) $< -o $@ + +$(PROGS): %: %.o +	$(CC) $(LDFLAGS) $< $(LINKS) -lm -lpthread -o $@ diff --git a/progs/gallium/trivial/quad-tex.c b/progs/gallium/trivial/quad-tex.c new file mode 100644 index 0000000000..553f5582e7 --- /dev/null +++ b/progs/gallium/trivial/quad-tex.c @@ -0,0 +1,346 @@ +/************************************************************************** + * + * Copyright © 2010 Jakob Bornecrantz + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice (including the next + * paragraph) shall be included in all copies or substantial portions of the + * Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + * + **************************************************************************/ + + +#define USE_TRACE 0 +#define WIDTH 300 +#define HEIGHT 300 +#define NEAR 30 +#define FAR 1000 +#define FLIP 0 + +/* pipe_*_state structs */ +#include "pipe/p_state.h" +/* pipe_context */ +#include "pipe/p_context.h" +/* pipe_screen */ +#include "pipe/p_screen.h" +/* PIPE_* */ +#include "pipe/p_defines.h" +/* TGSI_SEMANTIC_{POSITION|GENERIC} */ +#include "pipe/p_shader_tokens.h" +/* pipe_buffer_* helpers */ +#include "util/u_inlines.h" + +/* constant state object helper */ +#include "cso_cache/cso_context.h" + +/* u_sampler_view_default_template */ +#include "util/u_sampler.h" +/* debug_dump_surface_bmp */ +#include "util/u_debug.h" +/* util_draw_vertex_buffer helper */ +#include "util/u_draw_quad.h" +/* FREE & CALLOC_STRUCT */ +#include "util/u_memory.h" +/* util_make_[fragment|vertex]_passthrough_shader */ +#include "util/u_simple_shaders.h" + +/* softpipe software driver */ +#include "softpipe/sp_public.h" + +/* null software winsys */ +#include "sw/null/null_sw_winsys.h" + +/* traceing support see src/gallium/drivers/trace/README for more info. */ +#if USE_TRACE +#include "trace/tr_screen.h" +#include "trace/tr_context.h" +#endif + +struct program +{ +	struct pipe_screen *screen; +	struct pipe_context *pipe; +	struct cso_context *cso; + +	struct pipe_blend_state blend; +	struct pipe_depth_stencil_alpha_state depthstencil; +	struct pipe_rasterizer_state rasterizer; +	struct pipe_sampler_state sampler; +	struct pipe_viewport_state viewport; +	struct pipe_framebuffer_state framebuffer; +	struct pipe_vertex_element velem[2]; + +	void *vs; +	void *fs; + +	float clear_color[4]; + +	struct pipe_buffer *vbuf; +	struct pipe_texture *target; +	struct pipe_texture *tex; +	struct pipe_sampler_view *view; +}; + +static void init_prog(struct program *p) +{ +	/* create the software rasterizer */ +	p->screen = softpipe_create_screen(null_sw_create()); +#if USE_TRACE +	p->screen = trace_screen_create(p->screen); +#endif +	p->pipe = p->screen->context_create(p->screen, NULL); +	p->cso = cso_create_context(p->pipe); + +	/* set clear color */ +	p->clear_color[0] = 0.3; +	p->clear_color[1] = 0.1; +	p->clear_color[2] = 0.3; +	p->clear_color[3] = 1.0; + +	/* vertex buffer */ +	{ +		float vertices[4][2][4] = { +			{ +				{ 0.9f, 0.9f, 0.0f, 1.0f }, +				{ 1.0f, 1.0f, 0.0f, 1.0f } +			}, +			{ +				{ -0.9f, 0.9f, 0.0f, 1.0f }, +				{  0.0f, 1.0f, 0.0f, 1.0f } +			}, +			{ +				{ -0.9f, -0.9f, 0.0f, 1.0f }, +				{  0.0f,  0.0f, 1.0f, 1.0f } +			}, +			{ +				{ 0.9f, -0.9f, 0.0f, 1.0f }, +				{ 1.0f,  0.0f, 1.0f, 1.0f } +			} +		}; + +		p->vbuf = pipe_buffer_create(p->screen, 16, PIPE_BUFFER_USAGE_VERTEX, sizeof(vertices)); +		pipe_buffer_write(p->screen, p->vbuf, 0, sizeof(vertices), vertices); +	} + +	/* render target texture */ +	{ +		struct pipe_texture tmplt; +		memset(&tmplt, 0, sizeof(tmplt)); +		tmplt.target = PIPE_TEXTURE_2D; +		tmplt.format = PIPE_FORMAT_B8G8R8A8_UNORM; /* All drivers support this */ +		tmplt.width0 = WIDTH; +		tmplt.height0 = HEIGHT; +		tmplt.depth0 = 1; +		tmplt.last_level = 0; +		tmplt.tex_usage = PIPE_TEXTURE_USAGE_RENDER_TARGET; + +		p->target = p->screen->texture_create(p->screen, &tmplt); +	} + +	/* sampler texture */ +	{ +		uint32_t *ptr; +		struct pipe_transfer *t; +		struct pipe_texture t_tmplt; +		struct pipe_sampler_view v_tmplt; + +		memset(&t_tmplt, 0, sizeof(t_tmplt)); +		t_tmplt.target = PIPE_TEXTURE_2D; +		t_tmplt.format = PIPE_FORMAT_B8G8R8A8_UNORM; /* All drivers support this */ +		t_tmplt.width0 = 2; +		t_tmplt.height0 = 2; +		t_tmplt.depth0 = 1; +		t_tmplt.last_level = 0; +		t_tmplt.tex_usage = PIPE_TEXTURE_USAGE_RENDER_TARGET; + +		p->tex = p->screen->texture_create(p->screen, &t_tmplt); + +		t = p->pipe->get_tex_transfer(p->pipe, p->tex, +		                              0, 0, 0, /* face, level, zslice */ +		                              PIPE_TRANSFER_WRITE, +		                              0, 0, 2, 2); /* x, y, width, height */ + +		ptr = p->pipe->transfer_map(p->pipe, t); +		ptr[0] = 0xffff0000; +		ptr[1] = 0xff0000ff; +		ptr[2] = 0xff00ff00; +		ptr[3] = 0xffffff00; +		p->pipe->transfer_unmap(p->pipe, t); + +		p->pipe->tex_transfer_destroy(p->pipe, t); + +		u_sampler_view_default_template(&v_tmplt, p->tex, p->tex->format); + +		p->view = p->pipe->create_sampler_view(p->pipe, p->tex, &v_tmplt); +	} + +	/* disabled blending/masking */ +	memset(&p->blend, 0, sizeof(p->blend)); +	p->blend.rt[0].colormask = PIPE_MASK_RGBA; + +	/* no-op depth/stencil/alpha */ +	memset(&p->depthstencil, 0, sizeof(p->depthstencil)); + +	/* rasterizer */ +	memset(&p->rasterizer, 0, sizeof(p->rasterizer)); +	p->rasterizer.front_winding = PIPE_WINDING_CW; +	p->rasterizer.cull_mode = PIPE_WINDING_NONE; +	p->rasterizer.gl_rasterization_rules = 1; + +	/* sampler */ +	memset(&p->sampler, 0, sizeof(p->sampler)); +	p->sampler.wrap_s = PIPE_TEX_WRAP_CLAMP_TO_EDGE; +	p->sampler.wrap_t = PIPE_TEX_WRAP_CLAMP_TO_EDGE; +	p->sampler.wrap_r = PIPE_TEX_WRAP_CLAMP_TO_EDGE; +	p->sampler.min_mip_filter = PIPE_TEX_MIPFILTER_NONE; +	p->sampler.min_img_filter = PIPE_TEX_MIPFILTER_LINEAR; +	p->sampler.mag_img_filter = PIPE_TEX_MIPFILTER_LINEAR; +	p->sampler.normalized_coords = 1; + +	/* drawing destination */ +	memset(&p->framebuffer, 0, sizeof(p->framebuffer)); +	p->framebuffer.width = WIDTH; +	p->framebuffer.height = HEIGHT; +	p->framebuffer.nr_cbufs = 1; +	p->framebuffer.cbufs[0] = p->screen->get_tex_surface(p->screen, p->target, 0, 0, 0, PIPE_BUFFER_USAGE_GPU_WRITE); + +	/* viewport, depth isn't really needed */ +	{ +		float x = 0; +		float y = 0; +		float z = FAR; +		float half_width = (float)WIDTH / 2.0f; +		float half_height = (float)HEIGHT / 2.0f; +		float half_depth = ((float)FAR - (float)NEAR) / 2.0f; +		float scale, bias; + +		if (FLIP) { +			scale = -1.0f; +			bias = (float)HEIGHT; +		} else { +			scale = 1.0f; +			bias = 0.0f; +		} + +		p->viewport.scale[0] = half_width; +		p->viewport.scale[1] = half_height * scale; +		p->viewport.scale[2] = half_depth; +		p->viewport.scale[3] = 1.0f; + +		p->viewport.translate[0] = half_width + x; +		p->viewport.translate[1] = (half_height + y) * scale + bias; +		p->viewport.translate[2] = half_depth + z; +		p->viewport.translate[3] = 0.0f; +	} + +	/* vertex elements state */ +	memset(p->velem, 0, sizeof(p->velem)); +	p->velem[0].src_offset = 0 * 4 * sizeof(float); /* offset 0, first element */ +	p->velem[0].instance_divisor = 0; +	p->velem[0].vertex_buffer_index = 0; +	p->velem[0].src_format = PIPE_FORMAT_R32G32B32A32_FLOAT; + +	p->velem[1].src_offset = 1 * 4 * sizeof(float); /* offset 16, second element */ +	p->velem[1].instance_divisor = 0; +	p->velem[1].vertex_buffer_index = 0; +	p->velem[1].src_format = PIPE_FORMAT_R32G32B32A32_FLOAT; + +	/* vertex shader */ +	{ +		const uint semantic_names[] = { TGSI_SEMANTIC_POSITION, +		                                TGSI_SEMANTIC_GENERIC }; +		const uint semantic_indexes[] = { 0, 0 }; +		p->vs = util_make_vertex_passthrough_shader(p->pipe, 2, semantic_names, semantic_indexes); +	} + +	/* fragment shader */ +	p->fs = util_make_fragment_tex_shader(p->pipe, TGSI_TEXTURE_2D); +} + +static void close_prog(struct program *p) +{ +	/* unset bound textures as well */ +	cso_set_fragment_sampler_views(p->cso, 0, NULL); + +	/* unset all state */ +	cso_release_all(p->cso); + +	p->pipe->delete_vs_state(p->pipe, p->vs); +	p->pipe->delete_fs_state(p->pipe, p->fs); + +	pipe_surface_reference(&p->framebuffer.cbufs[0], NULL); +	pipe_sampler_view_reference(&p->view, NULL); +	pipe_texture_reference(&p->target, NULL); +	pipe_texture_reference(&p->tex, NULL); +	pipe_buffer_reference(&p->vbuf, NULL); + +	cso_destroy_context(p->cso); +	p->pipe->destroy(p->pipe); +	p->screen->destroy(p->screen); + +	FREE(p); +} + +static void draw(struct program *p) +{ +	/* set the render target */ +	cso_set_framebuffer(p->cso, &p->framebuffer); + +	/* clear the render target */ +	p->pipe->clear(p->pipe, PIPE_CLEAR_COLOR, p->clear_color, 0, 0); + +	/* set misc state we care about */ +	cso_set_blend(p->cso, &p->blend); +	cso_set_depth_stencil_alpha(p->cso, &p->depthstencil); +	cso_set_rasterizer(p->cso, &p->rasterizer); +	cso_set_viewport(p->cso, &p->viewport); + +	/* sampler */ +	cso_single_sampler(p->cso, 0, &p->sampler); +	cso_single_sampler_done(p->cso); + +	/* texture sampler view */ +	cso_set_fragment_sampler_views(p->cso, 1, &p->view); + +	/* shaders */ +	cso_set_fragment_shader_handle(p->cso, p->fs); +	cso_set_vertex_shader_handle(p->cso, p->vs); + +	/* vertex element data */ +	cso_set_vertex_elements(p->cso, 2, p->velem); + +	util_draw_vertex_buffer(p->pipe, +	                        p->vbuf, 0, +	                        PIPE_PRIM_QUADS, +	                        4,  /* verts */ +	                        2); /* attribs/vert */ + +	p->pipe->flush(p->pipe, PIPE_FLUSH_RENDER_CACHE, NULL); + +	debug_dump_surface_bmp(p->pipe, "result.bmp", p->framebuffer.cbufs[0]); +} + +int main(int argc, char** argv) +{ +	struct program *p = CALLOC_STRUCT(program); + +	init_prog(p); +	draw(p); +	close_prog(p); + +	return 0; +} diff --git a/progs/gallium/trivial/tri.c b/progs/gallium/trivial/tri.c new file mode 100644 index 0000000000..cae1bdb1b1 --- /dev/null +++ b/progs/gallium/trivial/tri.c @@ -0,0 +1,278 @@ +/************************************************************************** + * + * Copyright © 2010 Jakob Bornecrantz + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice (including the next + * paragraph) shall be included in all copies or substantial portions of the + * Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + * + **************************************************************************/ + + +#define USE_TRACE 0 +#define WIDTH 300 +#define HEIGHT 300 +#define NEAR 30 +#define FAR 1000 +#define FLIP 0 + +/* pipe_*_state structs */ +#include "pipe/p_state.h" +/* pipe_context */ +#include "pipe/p_context.h" +/* pipe_screen */ +#include "pipe/p_screen.h" +/* PIPE_* */ +#include "pipe/p_defines.h" +/* TGSI_SEMANTIC_{POSITION|GENERIC} */ +#include "pipe/p_shader_tokens.h" +/* pipe_buffer_* helpers */ +#include "util/u_inlines.h" + +/* constant state object helper */ +#include "cso_cache/cso_context.h" + +/* debug_dump_surface_bmp */ +#include "util/u_debug.h" +/* util_draw_vertex_buffer helper */ +#include "util/u_draw_quad.h" +/* FREE & CALLOC_STRUCT */ +#include "util/u_memory.h" +/* util_make_[fragment|vertex]_passthrough_shader */ +#include "util/u_simple_shaders.h" + +/* softpipe software driver */ +#include "softpipe/sp_public.h" + +/* null software winsys */ +#include "sw/null/null_sw_winsys.h" + +/* traceing support see src/gallium/drivers/trace/README for more info. */ +#if USE_TRACE +#include "trace/tr_screen.h" +#include "trace/tr_context.h" +#endif + +struct program +{ +	struct pipe_screen *screen; +	struct pipe_context *pipe; +	struct cso_context *cso; + +	struct pipe_blend_state blend; +	struct pipe_depth_stencil_alpha_state depthstencil; +	struct pipe_rasterizer_state rasterizer; +	struct pipe_viewport_state viewport; +	struct pipe_framebuffer_state framebuffer; +	struct pipe_vertex_element velem[2]; + +	void *vs; +	void *fs; + +	float clear_color[4]; + +	struct pipe_buffer *vbuf; +	struct pipe_texture *target; +}; + +static void init_prog(struct program *p) +{ +	/* create the software rasterizer */ +	p->screen = softpipe_create_screen(null_sw_create()); +#if USE_TRACE +	p->screen = trace_screen_create(p->screen); +#endif +	p->pipe = p->screen->context_create(p->screen, NULL); +	p->cso = cso_create_context(p->pipe); + +	/* set clear color */ +	p->clear_color[0] = 0.3; +	p->clear_color[1] = 0.1; +	p->clear_color[2] = 0.3; +	p->clear_color[3] = 1.0; + +	/* vertex buffer */ +	{ +		float vertices[4][2][4] = { +			{ +				{ 0.0f, -0.9f, 0.0f, 1.0f }, +				{ 1.0f, 0.0f, 0.0f, 1.0f } +			}, +			{ +				{ -0.9f, 0.9f, 0.0f, 1.0f }, +				{ 0.0f, 1.0f, 0.0f, 1.0f } +			}, +			{ +				{ 0.9f, 0.9f, 0.0f, 1.0f }, +				{ 0.0f, 0.0f, 1.0f, 1.0f } +			} +		}; + +		p->vbuf = pipe_buffer_create(p->screen, 16, PIPE_BUFFER_USAGE_VERTEX, sizeof(vertices)); +		pipe_buffer_write(p->screen, p->vbuf, 0, sizeof(vertices), vertices); +	} + +	/* render target texture */ +	{ +		struct pipe_texture tmplt; +		memset(&tmplt, 0, sizeof(tmplt)); +		tmplt.target = PIPE_TEXTURE_2D; +		tmplt.format = PIPE_FORMAT_B8G8R8A8_UNORM; /* All drivers support this */ +		tmplt.width0 = WIDTH; +		tmplt.height0 = HEIGHT; +		tmplt.depth0 = 1; +		tmplt.last_level = 0; +		tmplt.tex_usage = PIPE_TEXTURE_USAGE_RENDER_TARGET; + +		p->target = p->screen->texture_create(p->screen, &tmplt); +	} + +	/* disabled blending/masking */ +	memset(&p->blend, 0, sizeof(p->blend)); +	p->blend.rt[0].colormask = PIPE_MASK_RGBA; + +	/* no-op depth/stencil/alpha */ +	memset(&p->depthstencil, 0, sizeof(p->depthstencil)); + +	/* rasterizer */ +	memset(&p->rasterizer, 0, sizeof(p->rasterizer)); +	p->rasterizer.front_winding = PIPE_WINDING_CW; +	p->rasterizer.cull_mode = PIPE_WINDING_NONE; +	p->rasterizer.gl_rasterization_rules = 1; + +	/* drawing destination */ +	memset(&p->framebuffer, 0, sizeof(p->framebuffer)); +	p->framebuffer.width = WIDTH; +	p->framebuffer.height = HEIGHT; +	p->framebuffer.nr_cbufs = 1; +	p->framebuffer.cbufs[0] = p->screen->get_tex_surface(p->screen, p->target, 0, 0, 0, PIPE_BUFFER_USAGE_GPU_WRITE); + +	/* viewport, depth isn't really needed */ +	{ +		float x = 0; +		float y = 0; +		float z = FAR; +		float half_width = (float)WIDTH / 2.0f; +		float half_height = (float)HEIGHT / 2.0f; +		float half_depth = ((float)FAR - (float)NEAR) / 2.0f; +		float scale, bias; + +		if (FLIP) { +			scale = -1.0f; +			bias = (float)HEIGHT; +		} else { +			scale = 1.0f; +			bias = 0.0f; +		} + +		p->viewport.scale[0] = half_width; +		p->viewport.scale[1] = half_height * scale; +		p->viewport.scale[2] = half_depth; +		p->viewport.scale[3] = 1.0f; + +		p->viewport.translate[0] = half_width + x; +		p->viewport.translate[1] = (half_height + y) * scale + bias; +		p->viewport.translate[2] = half_depth + z; +		p->viewport.translate[3] = 0.0f; +	} + +	/* vertex elements state */ +	memset(p->velem, 0, sizeof(p->velem)); +	p->velem[0].src_offset = 0 * 4 * sizeof(float); /* offset 0, first element */ +	p->velem[0].instance_divisor = 0; +	p->velem[0].vertex_buffer_index = 0; +	p->velem[0].src_format = PIPE_FORMAT_R32G32B32A32_FLOAT; + +	p->velem[1].src_offset = 1 * 4 * sizeof(float); /* offset 16, second element */ +	p->velem[1].instance_divisor = 0; +	p->velem[1].vertex_buffer_index = 0; +	p->velem[1].src_format = PIPE_FORMAT_R32G32B32A32_FLOAT; + +	/* vertex shader */ +	{ +			const uint semantic_names[] = { TGSI_SEMANTIC_POSITION, +							TGSI_SEMANTIC_COLOR }; +			const uint semantic_indexes[] = { 0, 0 }; +			p->vs = util_make_vertex_passthrough_shader(p->pipe, 2, semantic_names, semantic_indexes); +	} + +	/* fragment shader */ +	p->fs = util_make_fragment_passthrough_shader(p->pipe); +} + +static void close_prog(struct program *p) +{ +	/* unset all state */ +	cso_release_all(p->cso); + +	p->pipe->delete_vs_state(p->pipe, p->vs); +	p->pipe->delete_fs_state(p->pipe, p->fs); + +	pipe_surface_reference(&p->framebuffer.cbufs[0], NULL); +	pipe_texture_reference(&p->target, NULL); +	pipe_buffer_reference(&p->vbuf, NULL); + +	cso_destroy_context(p->cso); +	p->pipe->destroy(p->pipe); +	p->screen->destroy(p->screen); + +	FREE(p); +} + +static void draw(struct program *p) +{ +	/* set the render target */ +	cso_set_framebuffer(p->cso, &p->framebuffer); + +	/* clear the render target */ +	p->pipe->clear(p->pipe, PIPE_CLEAR_COLOR, p->clear_color, 0, 0); + +	/* set misc state we care about */ +	cso_set_blend(p->cso, &p->blend); +	cso_set_depth_stencil_alpha(p->cso, &p->depthstencil); +	cso_set_rasterizer(p->cso, &p->rasterizer); +	cso_set_viewport(p->cso, &p->viewport); + +	/* shaders */ +	cso_set_fragment_shader_handle(p->cso, p->fs); +	cso_set_vertex_shader_handle(p->cso, p->vs); + +	/* vertex element data */ +	cso_set_vertex_elements(p->cso, 2, p->velem); + +	util_draw_vertex_buffer(p->pipe, +	                        p->vbuf, 0, +	                        PIPE_PRIM_TRIANGLES, +	                        3,  /* verts */ +	                        2); /* attribs/vert */ + +	p->pipe->flush(p->pipe, PIPE_FLUSH_RENDER_CACHE, NULL); + +	debug_dump_surface_bmp(p->pipe, "result.bmp", p->framebuffer.cbufs[0]); +} + +int main(int argc, char** argv) +{ +	struct program *p = CALLOC_STRUCT(program); + +	init_prog(p); +	draw(p); +	close_prog(p); + +	return 0; +} diff --git a/progs/gallium/unit/Makefile b/progs/gallium/unit/Makefile new file mode 100644 index 0000000000..f3dbd7695c --- /dev/null +++ b/progs/gallium/unit/Makefile @@ -0,0 +1,44 @@ +# progs/gallium/simple/Makefile + +TOP = ../../.. +include $(TOP)/configs/current + +INCLUDES = \ +	-I. \ +	-I$(TOP)/src/gallium/include \ +	-I$(TOP)/src/gallium/auxiliary \ +	-I$(TOP)/src/gallium/drivers \ +	-I$(TOP)/src/gallium/winsys \ +	$(PROG_INCLUDES) + +LINKS = \ +	$(TOP)/src/gallium/drivers/trace/libtrace.a \ +	$(TOP)/src/gallium/winsys/sw/null/libws_null.a \ +	$(TOP)/src/gallium/drivers/softpipe/libsoftpipe.a \ +	$(GALLIUM_AUXILIARIES) \ +	$(PROG_LINKS) + +SOURCES = \ +	u_format_test.c \ +	u_half_test.c + +OBJECTS = $(SOURCES:.c=.o) + +PROGS = $(OBJECTS:.o=) + +##### TARGETS ##### + +default: $(PROGS) + +clean: +	-rm -f $(PROGS) +	-rm -f *.o +	-rm -f result.bmp + +##### RULES ##### + +$(OBJECTS): %.o: %.c +	$(CC) -c $(INCLUDES) $(CFLAGS) $(DEFINES) $(PROG_DEFINES) $< -o $@ + +$(PROGS): %: %.o +	$(CC) $(LDFLAGS) $< $(LINKS) -lm -lpthread -ldl -o $@ diff --git a/progs/gallium/unit/SConscript b/progs/gallium/unit/SConscript index 9891440df6..0db3bb687c 100644 --- a/progs/gallium/unit/SConscript +++ b/progs/gallium/unit/SConscript @@ -5,7 +5,8 @@ env = env.Clone()  env.Prepend(LIBS = [gallium])  progs = [ -    'u_format_test' +    'u_format_test', +    'u_half_test'  ]  for prog in progs: @@ -13,6 +14,8 @@ for prog in progs:          target = prog,          source = prog + '.c',      ) +     +    env.InstallProgram(prog)      # http://www.scons.org/wiki/UnitTests      test_alias = env.Alias('unit', [prog], prog[0].abspath) diff --git a/progs/gallium/unit/u_format_test.c b/progs/gallium/unit/u_format_test.c index 2dfba5538b..cfde6af75e 100644 --- a/progs/gallium/unit/u_format_test.c +++ b/progs/gallium/unit/u_format_test.c @@ -28,565 +28,479 @@  #include <stdlib.h>  #include <stdio.h> +#include <float.h> +#include "util/u_half.h"  #include "util/u_format.h" -#include "util/u_format_pack.h" +#include "util/u_format_tests.h" +#include "util/u_format_s3tc.h" -#define MAX_PACKED_BYTES 16 - - -/** - * A (packed, unpacked) color pair. - */ -struct util_format_test_case +static boolean +compare_float(float x, float y)  { -   enum pipe_format format; - -   /** -    * Mask of the bits that actually meaningful data. Used to mask out the -    * "X" channels. -    */ -   uint8_t mask[MAX_PACKED_BYTES]; - -   uint8_t packed[MAX_PACKED_BYTES]; +   float error = y - x; -   /** -    * RGBA. -    */ -   double unpacked[4]; -}; +   if (error < 0.0f) +      error = -error; +   if (error > FLT_EPSILON) { +      return FALSE; +   } -/* - * Helper macros to create the packed bytes for longer words. - */ - -#define PACKED_1x8(x)          {x, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} -#define PACKED_2x8(x, y)       {x, y, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} -#define PACKED_3x8(x, y, z)    {x, y, z, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} -#define PACKED_4x8(x, y, z, w) {x, y, z, w, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0} - -#define PACKED_1x16(x)          {(x) & 0xff, (x) >> 8,          0,        0,          0,        0,          0,        0, 0, 0, 0, 0, 0, 0, 0, 0} -#define PACKED_2x16(x, y)       {(x) & 0xff, (x) >> 8, (y) & 0xff, (y) >> 8,          0,        0,          0,        0, 0, 0, 0, 0, 0, 0, 0, 0} -#define PACKED_3x16(x, y, z)    {(x) & 0xff, (x) >> 8, (y) & 0xff, (y) >> 8, (z) & 0xff, (z) >> 8,          0,        0, 0, 0, 0, 0, 0, 0, 0, 0} -#define PACKED_4x16(x, y, z, w) {(x) & 0xff, (x) >> 8, (y) & 0xff, (y) >> 8, (z) & 0xff, (z) >> 8, (w) & 0xff, (w) >> 8, 0, 0, 0, 0, 0, 0, 0, 0} - -#define PACKED_1x32(x)          {(x) & 0xff, ((x) >> 8) & 0xff, ((x) >> 16) & 0xff, (x) >> 24,          0,                 0,                  0,         0,          0,                 0,                  0,         0,          0,                 0,                  0,         0} -#define PACKED_2x32(x, y)       {(x) & 0xff, ((x) >> 8) & 0xff, ((x) >> 16) & 0xff, (x) >> 24, (y) & 0xff, ((y) >> 8) & 0xff, ((y) >> 16) & 0xff, (y) >> 24,          0,                 0,                  0,         0,          0,                 0,                  0,         0} -#define PACKED_3x32(x, y, z)    {(x) & 0xff, ((x) >> 8) & 0xff, ((x) >> 16) & 0xff, (x) >> 24, (y) & 0xff, ((y) >> 8) & 0xff, ((y) >> 16) & 0xff, (y) >> 24, (z) & 0xff, ((z) >> 8) & 0xff, ((z) >> 16) & 0xff, (z) >> 24,          0,                 0,                  0,         0} -#define PACKED_4x32(x, y, z, w) {(x) & 0xff, ((x) >> 8) & 0xff, ((x) >> 16) & 0xff, (x) >> 24, (y) & 0xff, ((y) >> 8) & 0xff, ((y) >> 16) & 0xff, (y) >> 24, (z) & 0xff, ((z) >> 8) & 0xff, ((z) >> 16) & 0xff, (z) >> 24, (w) & 0xff, ((w) >> 8) & 0xff, ((w) >> 16) & 0xff, (w) >> 24} +   return TRUE; +} -/** - * Test cases. - * - * These were manually entered. We could generate these - * - * To keep this to a we cover only the corner cases, which should produce - * good enough coverage since that pixel format transformations are afine for - * non SRGB formats. - */ -static const struct util_format_test_case -test_cases[] = +static void +print_packed(const struct util_format_description *format_desc, +             const char *prefix, +             const uint8_t *packed, +             const char *suffix)  { +   unsigned i; +   const char *sep = ""; -   /* -    * 32-bit rendertarget formats -    */ - -   {PIPE_FORMAT_B8G8R8A8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x00000000), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_B8G8R8A8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x000000ff), {0.0, 0.0, 1.0, 0.0}}, -   {PIPE_FORMAT_B8G8R8A8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x0000ff00), {0.0, 1.0, 0.0, 0.0}}, -   {PIPE_FORMAT_B8G8R8A8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x00ff0000), {1.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_B8G8R8A8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0xff000000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B8G8R8A8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0xffffffff), {1.0, 1.0, 1.0, 1.0}}, - -   {PIPE_FORMAT_B8G8R8X8_UNORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x00000000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B8G8R8X8_UNORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x000000ff), {0.0, 0.0, 1.0, 1.0}}, -   {PIPE_FORMAT_B8G8R8X8_UNORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x0000ff00), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B8G8R8X8_UNORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x00ff0000), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B8G8R8X8_UNORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0xff000000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B8G8R8X8_UNORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0xffffffff), {1.0, 1.0, 1.0, 1.0}}, - -   {PIPE_FORMAT_A8R8G8B8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x00000000), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_A8R8G8B8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x000000ff), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_A8R8G8B8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x0000ff00), {1.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_A8R8G8B8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x00ff0000), {0.0, 1.0, 0.0, 0.0}}, -   {PIPE_FORMAT_A8R8G8B8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0xff000000), {0.0, 0.0, 1.0, 0.0}}, -   {PIPE_FORMAT_A8R8G8B8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0xffffffff), {1.0, 1.0, 1.0, 1.0}}, - -   {PIPE_FORMAT_X8R8G8B8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0x00000000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_X8R8G8B8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0x000000ff), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_X8R8G8B8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0x0000ff00), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_X8R8G8B8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0x00ff0000), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_X8R8G8B8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0xff000000), {0.0, 0.0, 1.0, 1.0}}, -   {PIPE_FORMAT_X8R8G8B8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0xffffffff), {1.0, 1.0, 1.0, 1.0}}, - -   {PIPE_FORMAT_A8B8G8R8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x00000000), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_A8B8G8R8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x000000ff), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_A8B8G8R8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x0000ff00), {0.0, 0.0, 1.0, 0.0}}, -   {PIPE_FORMAT_A8B8G8R8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x00ff0000), {0.0, 1.0, 0.0, 0.0}}, -   {PIPE_FORMAT_A8B8G8R8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0xff000000), {1.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_A8B8G8R8_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0xffffffff), {1.0, 1.0, 1.0, 1.0}}, - -   {PIPE_FORMAT_X8B8G8R8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0x00000000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_X8B8G8R8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0x000000ff), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_X8B8G8R8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0x0000ff00), {0.0, 0.0, 1.0, 1.0}}, -   {PIPE_FORMAT_X8B8G8R8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0x00ff0000), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_X8B8G8R8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0xff000000), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_X8B8G8R8_UNORM, PACKED_1x32(0xffffff00), PACKED_1x32(0xffffffff), {1.0, 1.0, 1.0, 1.0}}, - -   {PIPE_FORMAT_R10G10B10A2_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x00000000), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R10G10B10A2_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x000003ff), {1.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R10G10B10A2_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x000ffc00), {0.0, 1.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R10G10B10A2_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x3ff00000), {0.0, 0.0, 1.0, 0.0}}, -   {PIPE_FORMAT_R10G10B10A2_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0xc0000000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R10G10B10A2_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0xffffffff), {1.0, 1.0, 1.0, 1.0}}, - -   /* -    * 16-bit rendertarget formats -    */ - -   {PIPE_FORMAT_B5G5R5A1_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x0000), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_B5G5R5A1_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x001f), {0.0, 0.0, 1.0, 0.0}}, -   {PIPE_FORMAT_B5G5R5A1_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x03e0), {0.0, 1.0, 0.0, 0.0}}, -   {PIPE_FORMAT_B5G5R5A1_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x7c00), {1.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_B5G5R5A1_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x8000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B5G5R5A1_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0xffff), {1.0, 1.0, 1.0, 1.0}}, - -   {PIPE_FORMAT_B4G4R4A4_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x0000), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_B4G4R4A4_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x000f), {0.0, 0.0, 1.0, 0.0}}, -   {PIPE_FORMAT_B4G4R4A4_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x00f0), {0.0, 1.0, 0.0, 0.0}}, -   {PIPE_FORMAT_B4G4R4A4_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x0f00), {1.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_B4G4R4A4_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0xf000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B4G4R4A4_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0xffff), {1.0, 1.0, 1.0, 1.0}}, +   printf("%s", prefix); +   for (i = 0; i < format_desc->block.bits/8; ++i) { +      printf("%s%02x", sep, packed[i]); +      sep = " "; +   } +   printf("%s", suffix); +} -   {PIPE_FORMAT_B5G6R5_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x0000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B5G6R5_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x001f), {0.0, 0.0, 1.0, 1.0}}, -   {PIPE_FORMAT_B5G6R5_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x07e0), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B5G6R5_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0xf800), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_B5G6R5_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0xffff), {1.0, 1.0, 1.0, 1.0}}, -   /* -    * Luminance/intensity/alpha formats -    */ +static void +print_unpacked_rgba_doubl(const struct util_format_description *format_desc, +                     const char *prefix, +                     const double unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH][4], +                     const char *suffix) +{ +   unsigned i, j; +   const char *sep = ""; -   {PIPE_FORMAT_L8_UNORM, PACKED_1x8(0xff), PACKED_1x8(0x00), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_L8_UNORM, PACKED_1x8(0xff), PACKED_1x8(0xff), {1.0, 1.0, 1.0, 1.0}}, +   printf("%s", prefix); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         printf("%s{%f, %f, %f, %f}", sep, unpacked[i][j][0], unpacked[i][j][1], unpacked[i][j][2], unpacked[i][j][3]); +         sep = ", "; +      } +      sep = ",\n"; +   } +   printf("%s", suffix); +} -   {PIPE_FORMAT_A8_UNORM, PACKED_1x8(0xff), PACKED_1x8(0x00), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_A8_UNORM, PACKED_1x8(0xff), PACKED_1x8(0xff), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_I8_UNORM, PACKED_1x8(0xff), PACKED_1x8(0x00), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_I8_UNORM, PACKED_1x8(0xff), PACKED_1x8(0xff), {1.0, 1.0, 1.0, 1.0}}, +static void +print_unpacked_rgba_float(const struct util_format_description *format_desc, +                     const char *prefix, +                     float unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH][4], +                     const char *suffix) +{ +   unsigned i, j; +   const char *sep = ""; -   {PIPE_FORMAT_L8A8_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x0000), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_L8A8_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x00ff), {1.0, 1.0, 1.0, 0.0}}, -   {PIPE_FORMAT_L8A8_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0xff00), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_L8A8_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0xffff), {1.0, 1.0, 1.0, 1.0}}, +   printf("%s", prefix); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         printf("%s{%f, %f, %f, %f}", sep, unpacked[i][j][0], unpacked[i][j][1], unpacked[i][j][2], unpacked[i][j][3]); +         sep = ", "; +      } +      sep = ",\n"; +   } +   printf("%s", suffix); +} -   {PIPE_FORMAT_L16_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x0000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_L16_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0xffff), {1.0, 1.0, 1.0, 1.0}}, -   /* -    * TODO: SRGB formats -    */ +static void +print_unpacked_rgba_8unorm(const struct util_format_description *format_desc, +                      const char *prefix, +                      uint8_t unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH][4], +                      const char *suffix) +{ +   unsigned i, j; +   const char *sep = ""; -   /* -    * Mixed-signed formats -    */ +   printf("%s", prefix); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         printf("%s{0x%02x, 0x%02x, 0x%02x, 0x%02x}", sep, unpacked[i][j][0], unpacked[i][j][1], unpacked[i][j][2], unpacked[i][j][3]); +         sep = ", "; +      } +   } +   printf("%s", suffix); +} -   {PIPE_FORMAT_R8SG8SB8UX8U_NORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x00000000), { 0.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8SG8SB8UX8U_NORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x0000007f), { 1.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8SG8SB8UX8U_NORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x00000081), {-1.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8SG8SB8UX8U_NORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x00007f00), { 0.0,  1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8SG8SB8UX8U_NORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x00008100), { 0.0, -1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8SG8SB8UX8U_NORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0x00ff0000), { 0.0,  0.0, 1.0, 1.0}}, -   {PIPE_FORMAT_R8SG8SB8UX8U_NORM, PACKED_1x32(0x00ffffff), PACKED_1x32(0xff000000), { 0.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R5SG5SB6U_NORM, PACKED_1x16(0xffff), PACKED_1x16(0x0000), { 0.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R5SG5SB6U_NORM, PACKED_1x16(0xffff), PACKED_1x16(0x000f), { 1.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R5SG5SB6U_NORM, PACKED_1x16(0xffff), PACKED_1x16(0x0011), {-1.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R5SG5SB6U_NORM, PACKED_1x16(0xffff), PACKED_1x16(0x01e0), { 0.0,  1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R5SG5SB6U_NORM, PACKED_1x16(0xffff), PACKED_1x16(0x0220), { 0.0, -1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R5SG5SB6U_NORM, PACKED_1x16(0xffff), PACKED_1x16(0xfc00), { 0.0,  0.0, 1.0, 1.0}}, +static void +print_unpacked_z_float(const struct util_format_description *format_desc, +                       const char *prefix, +                       float unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH], +                       const char *suffix) +{ +   unsigned i, j; +   const char *sep = ""; -   /* -    * TODO: Depth-stencil formats -    */ +   printf("%s", prefix); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         printf("%s%f", sep, unpacked[i][j]); +         sep = ", "; +      } +      sep = ",\n"; +   } +   printf("%s", suffix); +} -   /* -    * TODO: YUV formats -    */ -   /* -    * TODO: Compressed formats -    */ +static void +print_unpacked_z_32unorm(const struct util_format_description *format_desc, +                         const char *prefix, +                         uint32_t unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH], +                         const char *suffix) +{ +   unsigned i, j; +   const char *sep = ""; -   /* -    * Standard 8-bit integer formats -    */ +   printf("%s", prefix); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         printf("%s0x%08x", sep, unpacked[i][j]); +         sep = ", "; +      } +   } +   printf("%s", suffix); +} -   {PIPE_FORMAT_R8_UNORM, PACKED_1x8(0xff), PACKED_1x8(0x00), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8_UNORM, PACKED_1x8(0xff), PACKED_1x8(0xff), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_UNORM, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0x00), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_UNORM, PACKED_2x8(0xff, 0xff), PACKED_2x8(0xff, 0x00), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_UNORM, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0xff), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_UNORM, PACKED_2x8(0xff, 0xff), PACKED_2x8(0xff, 0xff), {1.0, 1.0, 0.0, 1.0}}, +static void +print_unpacked_s_8uscaled(const struct util_format_description *format_desc, +                          const char *prefix, +                          uint8_t unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH], +                          const char *suffix) +{ +   unsigned i, j; +   const char *sep = ""; -   {PIPE_FORMAT_R8G8B8_UNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0x00), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_UNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0xff, 0x00, 0x00), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_UNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0xff, 0x00), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_UNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0xff), {0.0, 0.0, 1.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_UNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0xff, 0xff, 0xff), {1.0, 1.0, 1.0, 1.0}}, +   printf("%s", prefix); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         printf("%s0x%02x", sep, unpacked[i][j]); +         sep = ", "; +      } +   } +   printf("%s", suffix); +} -   {PIPE_FORMAT_R8G8B8A8_UNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0x00), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R8G8B8A8_UNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0xff, 0x00, 0x00, 0x00), {1.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R8G8B8A8_UNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0xff, 0x00, 0x00), {0.0, 1.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R8G8B8A8_UNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0xff, 0x00), {0.0, 0.0, 1.0, 0.0}}, -   {PIPE_FORMAT_R8G8B8A8_UNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0xff), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8A8_UNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0xff, 0xff, 0xff, 0xff), {1.0, 1.0, 1.0, 1.0}}, -   {PIPE_FORMAT_R8_USCALED, PACKED_1x8(0xff), PACKED_1x8(0x00), {  0.0,   0.0,   0.0, 1.0}}, -   {PIPE_FORMAT_R8_USCALED, PACKED_1x8(0xff), PACKED_1x8(0xff), {255.0,   0.0,   0.0, 1.0}}, +static boolean +test_format_fetch_rgba_float(const struct util_format_description *format_desc, +                             const struct util_format_test_case *test) +{ +   float unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH][4] = { { { 0 } } }; +   unsigned i, j, k; +   boolean success; -   {PIPE_FORMAT_R8G8_USCALED, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0x00), {  0.0,   0.0,   0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_USCALED, PACKED_2x8(0xff, 0xff), PACKED_2x8(0xff, 0x00), {255.0,   0.0,   0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_USCALED, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0xff), {  0.0, 255.0,   0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_USCALED, PACKED_2x8(0xff, 0xff), PACKED_2x8(0xff, 0xff), {255.0, 255.0,   0.0, 1.0}}, +   success = TRUE; +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         format_desc->fetch_rgba_float(unpacked[i][j], test->packed, j, i); +         for (k = 0; k < 4; ++k) { +            if (!compare_float(test->unpacked[i][j][k], unpacked[i][j][k])) { +               success = FALSE; +            } +         } +      } +   } -   {PIPE_FORMAT_R8G8B8_USCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0x00), {  0.0,   0.0,   0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_USCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0xff, 0x00, 0x00), {255.0,   0.0,   0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_USCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0xff, 0x00), {  0.0, 255.0,   0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_USCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0xff), {  0.0,   0.0, 255.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_USCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0xff, 0xff, 0xff), {255.0, 255.0, 255.0, 1.0}}, +   if (!success) { +      print_unpacked_rgba_float(format_desc, "FAILED: ", unpacked, " obtained\n"); +      print_unpacked_rgba_doubl(format_desc, "        ", test->unpacked, " expected\n"); +   } -   {PIPE_FORMAT_R8G8B8A8_USCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0x00), {  0.0,   0.0,   0.0,   0.0}}, -   {PIPE_FORMAT_R8G8B8A8_USCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0xff, 0x00, 0x00, 0x00), {255.0,   0.0,   0.0,   0.0}}, -   {PIPE_FORMAT_R8G8B8A8_USCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0xff, 0x00, 0x00), {  0.0, 255.0,   0.0,   0.0}}, -   {PIPE_FORMAT_R8G8B8A8_USCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0xff, 0x00), {  0.0,   0.0, 255.0,   0.0}}, -   {PIPE_FORMAT_R8G8B8A8_USCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0xff), {  0.0,   0.0,   0.0, 255.0}}, -   {PIPE_FORMAT_R8G8B8A8_USCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0xff, 0xff, 0xff, 0xff), {255.0, 255.0, 255.0, 255.0}}, +   return success; +} -   {PIPE_FORMAT_R8_SNORM, PACKED_1x8(0xff), PACKED_1x8(0x00), { 0.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8_SNORM, PACKED_1x8(0xff), PACKED_1x8(0x7f), { 1.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8_SNORM, PACKED_1x8(0xff), PACKED_1x8(0x81), {-1.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8_SNORM, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0x00), { 0.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8_SNORM, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x7f, 0x00), { 1.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8_SNORM, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x81, 0x00), {-1.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8_SNORM, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0x7f), { 0.0,  1.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8_SNORM, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0x81), { 0.0, -1.0,  0.0,  1.0}}, +static boolean +test_format_unpack_rgba_float(const struct util_format_description *format_desc, +                              const struct util_format_test_case *test) +{ +   float unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH][4] = { { { 0 } } }; +   unsigned i, j, k; +   boolean success; -   {PIPE_FORMAT_R8G8B8_SNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0x00), { 0.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8B8_SNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x7f, 0x00, 0x00), { 1.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8B8_SNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x81, 0x00, 0x00), {-1.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8B8_SNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x7f, 0x00), { 0.0,  1.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8B8_SNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x81, 0x00), { 0.0, -1.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8B8_SNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0x7f), { 0.0,  0.0,  1.0,  1.0}}, -   {PIPE_FORMAT_R8G8B8_SNORM, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0x81), { 0.0,  0.0, -1.0,  1.0}}, +   format_desc->unpack_rgba_float(&unpacked[0][0][0], sizeof unpacked[0], +                             test->packed, 0, +                             format_desc->block.width, format_desc->block.height); -   {PIPE_FORMAT_R8G8B8A8_SNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0x00), { 0.0,  0.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x7f, 0x00, 0x00, 0x00), { 1.0,  0.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x81, 0x00, 0x00, 0x00), {-1.0,  0.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x7f, 0x00, 0x00), { 0.0,  1.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x81, 0x00, 0x00), { 0.0, -1.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x7f, 0x00), { 0.0,  0.0,  1.0,  0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x81, 0x00), { 0.0,  0.0, -1.0,  0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0x7f), { 0.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R8G8B8A8_SNORM, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0x81), { 0.0,  0.0,  0.0, -1.0}}, +   success = TRUE; +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         for (k = 0; k < 4; ++k) { +            if (!compare_float(test->unpacked[i][j][k], unpacked[i][j][k])) { +               success = FALSE; +            } +         } +      } +   } -   {PIPE_FORMAT_R8_SSCALED, PACKED_1x8(0xff), PACKED_1x8(0x00), {   0.0,    0.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8_SSCALED, PACKED_1x8(0xff), PACKED_1x8(0x7f), { 127.0,    0.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8_SSCALED, PACKED_1x8(0xff), PACKED_1x8(0x80), {-128.0,    0.0,    0.0, 1.0}}, +   if (!success) { +      print_unpacked_rgba_float(format_desc, "FAILED: ", unpacked, " obtained\n"); +      print_unpacked_rgba_doubl(format_desc, "        ", test->unpacked, " expected\n"); +   } -   {PIPE_FORMAT_R8G8_SSCALED, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0x00), {   0.0,    0.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_SSCALED, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x7f, 0x00), { 127.0,    0.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_SSCALED, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x80, 0x00), {-128.0,    0.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_SSCALED, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0x7f), {   0.0,  127.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8G8_SSCALED, PACKED_2x8(0xff, 0xff), PACKED_2x8(0x00, 0x80), {   0.0, -128.0,    0.0, 1.0}}, +   return success; +} -   {PIPE_FORMAT_R8G8B8_SSCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0x00), {   0.0,    0.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_SSCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x7f, 0x00, 0x00), { 127.0,    0.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_SSCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x80, 0x00, 0x00), {-128.0,    0.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_SSCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x7f, 0x00), {   0.0,  127.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_SSCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x80, 0x00), {   0.0, -128.0,    0.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_SSCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0x7f), {   0.0,    0.0,  127.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8_SSCALED, PACKED_3x8(0xff, 0xff, 0xff), PACKED_3x8(0x00, 0x00, 0x80), {   0.0,    0.0, -128.0, 1.0}}, -   {PIPE_FORMAT_R8G8B8A8_SSCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0x00), {   0.0,    0.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SSCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x7f, 0x00, 0x00, 0x00), { 127.0,    0.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SSCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x80, 0x00, 0x00, 0x00), {-128.0,    0.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SSCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x7f, 0x00, 0x00), {   0.0,  127.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SSCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x80, 0x00, 0x00), {   0.0, -128.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SSCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x7f, 0x00), {   0.0,    0.0,  127.0,    0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SSCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x80, 0x00), {   0.0,    0.0, -128.0,    0.0}}, -   {PIPE_FORMAT_R8G8B8A8_SSCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0x7f), {   0.0,    0.0,    0.0,  127.0}}, -   {PIPE_FORMAT_R8G8B8A8_SSCALED, PACKED_4x8(0xff, 0xff, 0xff, 0xff), PACKED_4x8(0x00, 0x00, 0x00, 0x80), {   0.0,    0.0,    0.0, -128.0}}, +static boolean +test_format_pack_rgba_float(const struct util_format_description *format_desc, +                            const struct util_format_test_case *test) +{ +   float unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH][4]; +   uint8_t packed[UTIL_FORMAT_MAX_PACKED_BYTES]; +   unsigned i, j, k; +   boolean success; -   /* -    * Standard 16-bit integer formats -    */ +   if (test->format == PIPE_FORMAT_DXT1_RGBA) { +      /* +       * Skip S3TC as packed representation is not canonical. +       * +       * TODO: Do a round trip conversion. +       */ +      return TRUE; +   } -   {PIPE_FORMAT_R16_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0x0000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R16_UNORM, PACKED_1x16(0xffff), PACKED_1x16(0xffff), {1.0, 0.0, 0.0, 1.0}}, +   memset(packed, 0, sizeof packed); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         for (k = 0; k < 4; ++k) { +            unpacked[i][j][k] = (float) test->unpacked[i][j][k]; +         } +      } +   } -   {PIPE_FORMAT_R16G16_UNORM, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0x0000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R16G16_UNORM, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0xffff, 0x0000), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R16G16_UNORM, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0xffff), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R16G16_UNORM, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0xffff, 0xffff), {1.0, 1.0, 0.0, 1.0}}, +   format_desc->pack_rgba_float(packed, 0, +                           &unpacked[0][0][0], sizeof unpacked[0], +                           format_desc->block.width, format_desc->block.height); -   {PIPE_FORMAT_R16G16B16_UNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0x0000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R16G16B16_UNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0xffff, 0x0000, 0x0000), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R16G16B16_UNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0xffff, 0x0000), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R16G16B16_UNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0xffff), {0.0, 0.0, 1.0, 1.0}}, -   {PIPE_FORMAT_R16G16B16_UNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0xffff, 0xffff, 0xffff), {1.0, 1.0, 1.0, 1.0}}, +   success = TRUE; +   for (i = 0; i < format_desc->block.bits/8; ++i) +      if ((test->packed[i] & test->mask[i]) != (packed[i] & test->mask[i])) +         success = FALSE; -   {PIPE_FORMAT_R16G16B16A16_UNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0x0000), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R16G16B16A16_UNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0xffff, 0x0000, 0x0000, 0x0000), {1.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R16G16B16A16_UNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0xffff, 0x0000, 0x0000), {0.0, 1.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R16G16B16A16_UNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0xffff, 0x0000), {0.0, 0.0, 1.0, 0.0}}, -   {PIPE_FORMAT_R16G16B16A16_UNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0xffff), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R16G16B16A16_UNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), {1.0, 1.0, 1.0, 1.0}}, +   if (!success) { +      print_packed(format_desc, "FAILED: ", packed, " obtained\n"); +      print_packed(format_desc, "        ", test->packed, " expected\n"); +   } -   {PIPE_FORMAT_R16_USCALED, PACKED_1x16(0xffff), PACKED_1x16(0x0000), {    0.0,     0.0,     0.0,   1.0}}, -   {PIPE_FORMAT_R16_USCALED, PACKED_1x16(0xffff), PACKED_1x16(0xffff), {65535.0,     0.0,     0.0,   1.0}}, +   return success; +} -   {PIPE_FORMAT_R16G16_USCALED, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0x0000), {    0.0,     0.0,     0.0,   1.0}}, -   {PIPE_FORMAT_R16G16_USCALED, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0xffff, 0x0000), {65535.0,     0.0,     0.0,   1.0}}, -   {PIPE_FORMAT_R16G16_USCALED, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0xffff), {    0.0, 65535.0,     0.0,   1.0}}, -   {PIPE_FORMAT_R16G16_USCALED, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0xffff, 0xffff), {65535.0, 65535.0,     0.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_USCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0x0000), {    0.0,     0.0,     0.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_USCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0xffff, 0x0000, 0x0000), {65535.0,     0.0,     0.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_USCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0xffff, 0x0000), {    0.0, 65535.0,     0.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_USCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0xffff), {    0.0,     0.0, 65535.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_USCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0xffff, 0xffff, 0xffff), {65535.0, 65535.0, 65535.0,   1.0}}, +static boolean +convert_float_to_8unorm(uint8_t *dst, const double *src) +{ +   unsigned i; +   boolean accurate = TRUE; -   {PIPE_FORMAT_R16G16B16A16_USCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0x0000), {    0.0,     0.0,     0.0,     0.0}}, -   {PIPE_FORMAT_R16G16B16A16_USCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0xffff, 0x0000, 0x0000, 0x0000), {65535.0,     0.0,     0.0,     0.0}}, -   {PIPE_FORMAT_R16G16B16A16_USCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0xffff, 0x0000, 0x0000), {    0.0, 65535.0,     0.0,     0.0}}, -   {PIPE_FORMAT_R16G16B16A16_USCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0xffff, 0x0000), {    0.0,     0.0, 65535.0,     0.0}}, -   {PIPE_FORMAT_R16G16B16A16_USCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0xffff), {    0.0,     0.0,     0.0, 65535.0}}, -   {PIPE_FORMAT_R16G16B16A16_USCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), {65535.0, 65535.0, 65535.0, 65535.0}}, +   for (i = 0; i < UTIL_FORMAT_MAX_UNPACKED_HEIGHT*UTIL_FORMAT_MAX_UNPACKED_WIDTH*4; ++i) { +      if (src[i] < 0.0) { +         accurate = FALSE; +         dst[i] = 0; +      } +      else if (src[i] > 1.0) { +         accurate = FALSE; +         dst[i] = 255; +      } +      else { +         dst[i] = src[i] * 255.0; +      } +   } -   {PIPE_FORMAT_R16_SNORM, PACKED_1x16(0xffff), PACKED_1x16(0x0000), {   0.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16_SNORM, PACKED_1x16(0xffff), PACKED_1x16(0x7fff), {   1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16_SNORM, PACKED_1x16(0xffff), PACKED_1x16(0x8001), {  -1.0,    0.0,    0.0,    1.0}}, +   return accurate; +} -   {PIPE_FORMAT_R16G16_SNORM, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0x0000), {   0.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16_SNORM, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x7fff, 0x0000), {   1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16_SNORM, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x8001, 0x0000), {  -1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16_SNORM, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0x7fff), {   0.0,    1.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16_SNORM, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0x8001), {   0.0,   -1.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16B16_SNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0x0000), {   0.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16B16_SNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x7fff, 0x0000, 0x0000), {   1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16B16_SNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x8001, 0x0000, 0x0000), {  -1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16B16_SNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x7fff, 0x0000), {   0.0,    1.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16B16_SNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x8001, 0x0000), {   0.0,   -1.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16B16_SNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0x7fff), {   0.0,    0.0,    1.0,    1.0}}, -   {PIPE_FORMAT_R16G16B16_SNORM, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0x8001), {   0.0,    0.0,   -1.0,    1.0}}, +static boolean +test_format_unpack_rgba_8unorm(const struct util_format_description *format_desc, +                               const struct util_format_test_case *test) +{ +   uint8_t unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH][4] = { { { 0 } } }; +   uint8_t expected[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH][4] = { { { 0 } } }; +   unsigned i, j, k; +   boolean success; -   {PIPE_FORMAT_R16G16B16A16_SNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0x0000), {   0.0,    0.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x7fff, 0x0000, 0x0000, 0x0000), {   1.0,    0.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x8001, 0x0000, 0x0000, 0x0000), {  -1.0,    0.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x7fff, 0x0000, 0x0000), {   0.0,    1.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x8001, 0x0000, 0x0000), {   0.0,   -1.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x7fff, 0x0000), {   0.0,    0.0,    1.0,    0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x8001, 0x0000), {   0.0,    0.0,   -1.0,    0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0x7fff), {   0.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R16G16B16A16_SNORM, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0x8001), {   0.0,    0.0,    0.0,   -1.0}}, +   format_desc->unpack_rgba_8unorm(&unpacked[0][0][0], sizeof unpacked[0], +                              test->packed, 0, +                              format_desc->block.width, format_desc->block.height); -   {PIPE_FORMAT_R16_SSCALED, PACKED_1x16(0xffff), PACKED_1x16(0x0000), {     0.0,      0.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16_SSCALED, PACKED_1x16(0xffff), PACKED_1x16(0x7fff), { 32767.0,      0.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16_SSCALED, PACKED_1x16(0xffff), PACKED_1x16(0x8000), {-32768.0,      0.0,      0.0,   1.0}}, +   convert_float_to_8unorm(&expected[0][0][0], &test->unpacked[0][0][0]); -   {PIPE_FORMAT_R16G16_SSCALED, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0x0000), {     0.0,      0.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16G16_SSCALED, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x7fff, 0x0000), { 32767.0,      0.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16G16_SSCALED, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x8000, 0x0000), {-32768.0,      0.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16G16_SSCALED, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0x7fff), {     0.0,  32767.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16G16_SSCALED, PACKED_2x16(0xffff, 0xffff), PACKED_2x16(0x0000, 0x8000), {     0.0, -32768.0,      0.0,   1.0}}, +   success = TRUE; +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         for (k = 0; k < 4; ++k) { +            if (expected[i][j][k] != unpacked[i][j][k]) { +               success = FALSE; +            } +         } +      } +   } -   {PIPE_FORMAT_R16G16B16_SSCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0x0000), {     0.0,      0.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_SSCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x7fff, 0x0000, 0x0000), { 32767.0,      0.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_SSCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x8000, 0x0000, 0x0000), {-32768.0,      0.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_SSCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x7fff, 0x0000), {     0.0,  32767.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_SSCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x8000, 0x0000), {     0.0, -32768.0,      0.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_SSCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0x7fff), {     0.0,      0.0,  32767.0,   1.0}}, -   {PIPE_FORMAT_R16G16B16_SSCALED, PACKED_3x16(0xffff, 0xffff, 0xffff), PACKED_3x16(0x0000, 0x0000, 0x8000), {     0.0,      0.0, -32768.0,   1.0}}, +   if (!success) { +      print_unpacked_rgba_8unorm(format_desc, "FAILED: ", unpacked, " obtained\n"); +      print_unpacked_rgba_8unorm(format_desc, "        ", expected, " expected\n"); +   } -   {PIPE_FORMAT_R16G16B16A16_SSCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0x0000), {     0.0,      0.0,      0.0,      0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SSCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x7fff, 0x0000, 0x0000, 0x0000), { 32767.0,      0.0,      0.0,      0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SSCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x8000, 0x0000, 0x0000, 0x0000), {-32768.0,      0.0,      0.0,      0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SSCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x7fff, 0x0000, 0x0000), {     0.0,  32767.0,      0.0,      0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SSCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x8000, 0x0000, 0x0000), {     0.0, -32768.0,      0.0,      0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SSCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x7fff, 0x0000), {     0.0,      0.0,  32767.0,      0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SSCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x8000, 0x0000), {     0.0,      0.0, -32768.0,      0.0}}, -   {PIPE_FORMAT_R16G16B16A16_SSCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0x7fff), {     0.0,      0.0,      0.0,  32767.0}}, -   {PIPE_FORMAT_R16G16B16A16_SSCALED, PACKED_4x16(0xffff, 0xffff, 0xffff, 0xffff), PACKED_4x16(0x0000, 0x0000, 0x0000, 0x8000), {     0.0,      0.0,      0.0, -32768.0}}, +   return success; +} -   /* -    * Standard 32-bit integer formats -    * -    * NOTE: We can't accurately represent integers larger than +/-0x1000000 -    * with single precision floats, so that's as far as we test. -    */ -   {PIPE_FORMAT_R32_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x00000000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32_UNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0xffffffff), {1.0, 0.0, 0.0, 1.0}}, +static boolean +test_format_pack_rgba_8unorm(const struct util_format_description *format_desc, +                             const struct util_format_test_case *test) +{ +   uint8_t unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH][4]; +   uint8_t packed[UTIL_FORMAT_MAX_PACKED_BYTES]; +   unsigned i; +   boolean success; -   {PIPE_FORMAT_R32G32_UNORM, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x00000000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32_UNORM, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0xffffffff, 0x00000000), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32_UNORM, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0xffffffff), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32_UNORM, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0xffffffff, 0xffffffff), {1.0, 1.0, 0.0, 1.0}}, +   if (test->format == PIPE_FORMAT_DXT1_RGBA) { +      /* +       * Skip S3TC as packed representation is not canonical. +       * +       * TODO: Do a round trip conversion. +       */ +      return TRUE; +   } -   {PIPE_FORMAT_R32G32B32_UNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x00000000), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_UNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0xffffffff, 0x00000000, 0x00000000), {1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_UNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0xffffffff, 0x00000000), {0.0, 1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_UNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0xffffffff), {0.0, 0.0, 1.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_UNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), {1.0, 1.0, 1.0, 1.0}}, +   if (!convert_float_to_8unorm(&unpacked[0][0][0], &test->unpacked[0][0][0])) { +      /* +       * Skip test cases which cannot be represented by four unorm bytes. +       */ +      return TRUE; +   } -   {PIPE_FORMAT_R32G32B32A32_UNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x00000000), {0.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R32G32B32A32_UNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0xffffffff, 0x00000000, 0x00000000, 0x00000000), {1.0, 0.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R32G32B32A32_UNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0xffffffff, 0x00000000, 0x00000000), {0.0, 1.0, 0.0, 0.0}}, -   {PIPE_FORMAT_R32G32B32A32_UNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0xffffffff, 0x00000000), {0.0, 0.0, 1.0, 0.0}}, -   {PIPE_FORMAT_R32G32B32A32_UNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0xffffffff), {0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32A32_UNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), {1.0, 1.0, 1.0, 1.0}}, +   memset(packed, 0, sizeof packed); -   {PIPE_FORMAT_R32_USCALED, PACKED_1x32(0xffffffff), PACKED_1x32(0x00000000), {       0.0,        0.0,        0.0,   1.0}}, -   {PIPE_FORMAT_R32_USCALED, PACKED_1x32(0xffffffff), PACKED_1x32(0x01000000), {16777216.0,        0.0,        0.0,   1.0}}, +   format_desc->pack_rgba_8unorm(packed, 0, +                            &unpacked[0][0][0], sizeof unpacked[0], +                            format_desc->block.width, format_desc->block.height); -   {PIPE_FORMAT_R32G32_USCALED, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x00000000), {       0.0,        0.0,        0.0,   1.0}}, -   {PIPE_FORMAT_R32G32_USCALED, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x01000000, 0x00000000), {16777216.0,        0.0,        0.0,   1.0}}, -   {PIPE_FORMAT_R32G32_USCALED, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x01000000), {       0.0, 16777216.0,        0.0,   1.0}}, -   {PIPE_FORMAT_R32G32_USCALED, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x01000000, 0x01000000), {16777216.0, 16777216.0,        0.0,   1.0}}, +   success = TRUE; +   for (i = 0; i < format_desc->block.bits/8; ++i) +      if ((test->packed[i] & test->mask[i]) != (packed[i] & test->mask[i])) +         success = FALSE; -   {PIPE_FORMAT_R32G32B32_USCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x00000000), {       0.0,        0.0,        0.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_USCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x01000000, 0x00000000, 0x00000000), {16777216.0,        0.0,        0.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_USCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x01000000, 0x00000000), {       0.0, 16777216.0,        0.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_USCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x01000000), {       0.0,        0.0, 16777216.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_USCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x01000000, 0x01000000, 0x01000000), {16777216.0, 16777216.0, 16777216.0,   1.0}}, +   if (!success) { +      print_packed(format_desc, "FAILED: ", packed, " obtained\n"); +      print_packed(format_desc, "        ", test->packed, " expected\n"); +   } -   {PIPE_FORMAT_R32G32B32A32_USCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x00000000), {       0.0,        0.0,        0.0,        0.0}}, -   {PIPE_FORMAT_R32G32B32A32_USCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x01000000, 0x00000000, 0x00000000, 0x00000000), {16777216.0,        0.0,        0.0,        0.0}}, -   {PIPE_FORMAT_R32G32B32A32_USCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x01000000, 0x00000000, 0x00000000), {       0.0, 16777216.0,        0.0,        0.0}}, -   {PIPE_FORMAT_R32G32B32A32_USCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x01000000, 0x00000000), {       0.0,        0.0, 16777216.0,        0.0}}, -   {PIPE_FORMAT_R32G32B32A32_USCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x01000000), {       0.0,        0.0,        0.0, 16777216.0}}, -   {PIPE_FORMAT_R32G32B32A32_USCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x01000000, 0x01000000, 0x01000000, 0x01000000), {16777216.0, 16777216.0, 16777216.0, 16777216.0}}, +   return success; +} -   {PIPE_FORMAT_R32_SNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x00000000), {   0.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32_SNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x7fffffff), {   1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32_SNORM, PACKED_1x32(0xffffffff), PACKED_1x32(0x80000001), {  -1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32_SNORM, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x00000000), {   0.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32_SNORM, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x7fffffff, 0x00000000), {   1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32_SNORM, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x80000001, 0x00000000), {  -1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32_SNORM, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x7fffffff), {   0.0,    1.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32_SNORM, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x80000001), {   0.0,   -1.0,    0.0,    1.0}}, +static boolean +test_format_unpack_z_float(const struct util_format_description *format_desc, +                              const struct util_format_test_case *test) +{ +   float unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH] = { { 0 } }; +   unsigned i, j; +   boolean success; -   {PIPE_FORMAT_R32G32B32_SNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x00000000), {   0.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32B32_SNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x7fffffff, 0x00000000, 0x00000000), {   1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32B32_SNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x80000001, 0x00000000, 0x00000000), {  -1.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32B32_SNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x7fffffff, 0x00000000), {   0.0,    1.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32B32_SNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x80000001, 0x00000000), {   0.0,   -1.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32B32_SNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x7fffffff), {   0.0,    0.0,    1.0,    1.0}}, -   {PIPE_FORMAT_R32G32B32_SNORM, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x80000001), {   0.0,    0.0,   -1.0,    1.0}}, +   format_desc->unpack_z_float(&unpacked[0][0], sizeof unpacked[0], +                               test->packed, 0, +                               format_desc->block.width, format_desc->block.height); -   {PIPE_FORMAT_R32G32B32A32_SNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x00000000), {   0.0,    0.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x7fffffff, 0x00000000, 0x00000000, 0x00000000), {   1.0,    0.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x80000001, 0x00000000, 0x00000000, 0x00000000), {  -1.0,    0.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x7fffffff, 0x00000000, 0x00000000), {   0.0,    1.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x80000001, 0x00000000, 0x00000000), {   0.0,   -1.0,    0.0,    0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x7fffffff, 0x00000000), {   0.0,    0.0,    1.0,    0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x80000001, 0x00000000), {   0.0,    0.0,   -1.0,    0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x7fffffff), {   0.0,    0.0,    0.0,    1.0}}, -   {PIPE_FORMAT_R32G32B32A32_SNORM, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x80000001), {   0.0,    0.0,    0.0,   -1.0}}, +   success = TRUE; +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         if (!compare_float(test->unpacked[i][j][0], unpacked[i][j])) { +            success = FALSE; +         } +      } +   } -   {PIPE_FORMAT_R32_SSCALED, PACKED_1x32(0xffffffff), PACKED_1x32(0x00000000), {        0.0,         0.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32_SSCALED, PACKED_1x32(0xffffffff), PACKED_1x32(0x01000000), { 16777216.0,         0.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32_SSCALED, PACKED_1x32(0xffffffff), PACKED_1x32(0xff000000), {-16777216.0,         0.0,         0.0,   1.0}}, +   if (!success) { +      print_unpacked_z_float(format_desc, "FAILED: ", unpacked, " obtained\n"); +      print_unpacked_rgba_doubl(format_desc, "        ", test->unpacked, " expected\n"); +   } -   {PIPE_FORMAT_R32G32_SSCALED, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x00000000), {        0.0,         0.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32G32_SSCALED, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x01000000, 0x00000000), { 16777216.0,         0.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32G32_SSCALED, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0xff000000, 0x00000000), {-16777216.0,         0.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32G32_SSCALED, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x01000000), {        0.0,  16777216.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32G32_SSCALED, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0xff000000), {        0.0, -16777216.0,         0.0,   1.0}}, +   return success; +} -   {PIPE_FORMAT_R32G32B32_SSCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x00000000), {        0.0,         0.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_SSCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x01000000, 0x00000000, 0x00000000), { 16777216.0,         0.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_SSCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0xff000000, 0x00000000, 0x00000000), {-16777216.0,         0.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_SSCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x01000000, 0x00000000), {        0.0,  16777216.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_SSCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0xff000000, 0x00000000), {        0.0, -16777216.0,         0.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_SSCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x01000000), {        0.0,         0.0,  16777216.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32_SSCALED, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0xff000000), {        0.0,         0.0, -16777216.0,   1.0}}, -   {PIPE_FORMAT_R32G32B32A32_SSCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x00000000), {        0.0,         0.0,         0.0,         0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SSCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x01000000, 0x00000000, 0x00000000, 0x00000000), { 16777216.0,         0.0,         0.0,         0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SSCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0xff000000, 0x00000000, 0x00000000, 0x00000000), {-16777216.0,         0.0,         0.0,         0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SSCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x01000000, 0x00000000, 0x00000000), {        0.0,  16777216.0,         0.0,         0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SSCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0xff000000, 0x00000000, 0x00000000), {        0.0, -16777216.0,         0.0,         0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SSCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x01000000, 0x00000000), {        0.0,         0.0,  16777216.0,         0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SSCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0xff000000, 0x00000000), {        0.0,         0.0, -16777216.0,         0.0}}, -   {PIPE_FORMAT_R32G32B32A32_SSCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x01000000), {        0.0,         0.0,         0.0,  16777216.0}}, -   {PIPE_FORMAT_R32G32B32A32_SSCALED, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0xff000000), {        0.0,         0.0,         0.0, -16777216.0}}, +static boolean +test_format_pack_z_float(const struct util_format_description *format_desc, +                            const struct util_format_test_case *test) +{ +   float unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH]; +   uint8_t packed[UTIL_FORMAT_MAX_PACKED_BYTES]; +   unsigned i, j; +   boolean success; -   /* -    * Standard 32-bit float formats -    */ +   memset(packed, 0, sizeof packed); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         unpacked[i][j] = (float) test->unpacked[i][j][0]; +         if (test->unpacked[i][j][1]) { +            return TRUE; +         } +      } +   } -   {PIPE_FORMAT_R32_FLOAT, PACKED_1x32(0xffffffff), PACKED_1x32(0x00000000), {  0.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32_FLOAT, PACKED_1x32(0xffffffff), PACKED_1x32(0x3f800000), {  1.0, 0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32_FLOAT, PACKED_1x32(0xffffffff), PACKED_1x32(0xbf800000), { -1.0, 0.0, 0.0, 1.0}}, +   format_desc->pack_z_float(packed, 0, +                             &unpacked[0][0], sizeof unpacked[0], +                             format_desc->block.width, format_desc->block.height); -   {PIPE_FORMAT_R32G32_FLOAT, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x00000000), { 0.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32_FLOAT, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x3f800000, 0x00000000), { 1.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32_FLOAT, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0xbf800000, 0x00000000), {-1.0,  0.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32_FLOAT, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0x3f800000), { 0.0,  1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32_FLOAT, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x00000000, 0xbf800000), { 0.0, -1.0, 0.0, 1.0}}, -   {PIPE_FORMAT_R32G32_FLOAT, PACKED_2x32(0xffffffff, 0xffffffff), PACKED_2x32(0x3f800000, 0x3f800000), { 1.0,  1.0, 0.0, 1.0}}, +   success = TRUE; +   for (i = 0; i < format_desc->block.bits/8; ++i) +      if ((test->packed[i] & test->mask[i]) != (packed[i] & test->mask[i])) +         success = FALSE; -   {PIPE_FORMAT_R32G32B32_FLOAT, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x00000000), { 0.0,  0.0,  0.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_FLOAT, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x3f800000, 0x00000000, 0x00000000), { 1.0,  0.0,  0.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_FLOAT, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0xbf800000, 0x00000000, 0x00000000), {-1.0,  0.0,  0.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_FLOAT, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x3f800000, 0x00000000), { 0.0,  1.0,  0.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_FLOAT, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0xbf800000, 0x00000000), { 0.0, -1.0,  0.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_FLOAT, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0x3f800000), { 0.0,  0.0,  1.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_FLOAT, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x00000000, 0x00000000, 0xbf800000), { 0.0,  0.0, -1.0, 1.0}}, -   {PIPE_FORMAT_R32G32B32_FLOAT, PACKED_3x32(0xffffffff, 0xffffffff, 0xffffffff), PACKED_3x32(0x3f800000, 0x3f800000, 0x3f800000), { 1.0,  1.0,  1.0, 1.0}}, +   if (!success) { +      print_packed(format_desc, "FAILED: ", packed, " obtained\n"); +      print_packed(format_desc, "        ", test->packed, " expected\n"); +   } -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x00000000), { 0.0,  0.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x3f800000, 0x00000000, 0x00000000, 0x00000000), { 1.0,  0.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0xbf800000, 0x00000000, 0x00000000, 0x00000000), {-1.0,  0.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x3f800000, 0x00000000, 0x00000000), { 0.0,  1.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0xbf800000, 0x00000000, 0x00000000), { 0.0, -1.0,  0.0,  0.0}}, -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x3f800000, 0x00000000), { 0.0,  0.0,  1.0,  0.0}}, -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0xbf800000, 0x00000000), { 0.0,  0.0, -1.0,  0.0}}, -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0x3f800000), { 0.0,  0.0,  0.0,  1.0}}, -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x00000000, 0x00000000, 0x00000000, 0xbf800000), { 0.0,  0.0,  0.0, -1.0}}, -   {PIPE_FORMAT_R32G32B32A32_FLOAT, PACKED_4x32(0xffffffff, 0xffffffff, 0xffffffff, 0xffffffff), PACKED_4x32(0x3f800000, 0x3f800000, 0x3f800000, 0x3f800000), { 1.0,  1.0,  1.0,  1.0}}, -}; +   return success; +}  static boolean -test_format_unpack_4f(const struct util_format_test_case *test) +test_format_unpack_z_32unorm(const struct util_format_description *format_desc, +                               const struct util_format_test_case *test)  { -   float unpacked[4]; -   unsigned i; +   uint32_t unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH] = { { 0 } }; +   uint32_t expected[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH] = { { 0 } }; +   unsigned i, j;     boolean success; -   util_format_unpack_4f(test->format, unpacked, test->packed); +   format_desc->unpack_z_32unorm(&unpacked[0][0], sizeof unpacked[0], +                                 test->packed, 0, +                                 format_desc->block.width, format_desc->block.height); + +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         expected[i][j] = test->unpacked[i][j][0] * 0xffffffff; +      } +   }     success = TRUE; -   for (i = 0; i < 4; ++i) -      if (test->unpacked[i] != unpacked[i]) -         success = FALSE; +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         if (expected[i][j] != unpacked[i][j]) { +            success = FALSE; +         } +      } +   }     if (!success) { -      printf("FAILED: (%f %f %f %f) obtained\n", unpacked[0], unpacked[1], unpacked[2], unpacked[3]); -      printf("        (%f %f %f %f) expected\n", test->unpacked[0], test->unpacked[1], test->unpacked[2], test->unpacked[3]); +      print_unpacked_z_32unorm(format_desc, "FAILED: ", unpacked, " obtained\n"); +      print_unpacked_z_32unorm(format_desc, "        ", expected, " expected\n");     }     return success; @@ -594,69 +508,74 @@ test_format_unpack_4f(const struct util_format_test_case *test)  static boolean -test_format_pack_4f(const struct util_format_test_case *test) +test_format_pack_z_32unorm(const struct util_format_description *format_desc, +                             const struct util_format_test_case *test)  { -   uint8_t packed[MAX_PACKED_BYTES]; -   unsigned i; +   uint32_t unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH]; +   uint8_t packed[UTIL_FORMAT_MAX_PACKED_BYTES]; +   unsigned i, j;     boolean success; +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         unpacked[i][j] = test->unpacked[i][j][0] * 0xffffffff; +         if (test->unpacked[i][j][1]) { +            return TRUE; +         } +      } +   } +     memset(packed, 0, sizeof packed); -   util_format_pack_4f(test->format, packed, test->unpacked[0], test->unpacked[1], test->unpacked[2], test->unpacked[3]); +   format_desc->pack_z_32unorm(packed, 0, +                               &unpacked[0][0], sizeof unpacked[0], +                               format_desc->block.width, format_desc->block.height);     success = TRUE; -   for (i = 0; i < MAX_PACKED_BYTES; ++i) +   for (i = 0; i < format_desc->block.bits/8; ++i)        if ((test->packed[i] & test->mask[i]) != (packed[i] & test->mask[i]))           success = FALSE;     if (!success) { -      /* TODO: print more than 4 bytes */ -      printf("FAILED: (%02x %02x %02x %02x  %02x %02x %02x %02x  %02x %02x %02x %02x  %02x %02x %02x %02x) obtained\n", -             packed[0], packed[1], packed[2], packed[3], -             packed[4], packed[5], packed[6], packed[7], -             packed[8], packed[9], packed[10], packed[11], -             packed[12], packed[13], packed[14], packed[15]); -      printf("        (%02x %02x %02x %02x  %02x %02x %02x %02x  %02x %02x %02x %02x  %02x %02x %02x %02x) expected\n", -             test->packed[0], test->packed[1], test->packed[2], test->packed[3], -             test->packed[4], test->packed[5], test->packed[6], test->packed[7], -             test->packed[8], test->packed[9], test->packed[10], test->packed[11], -             test->packed[12], test->packed[13], test->packed[14], test->packed[15]); +      print_packed(format_desc, "FAILED: ", packed, " obtained\n"); +      print_packed(format_desc, "        ", test->packed, " expected\n");     }     return success;  } -static void -convert_4f_to_4ub(uint8_t *dst, const double *src) -{ -   unsigned i; - -   for (i = 0; i < 4; ++i) -      dst[i] = CLAMP(src[i], 0.0, 1.0) * 255.0; -} - -  static boolean -test_format_unpack_4ub(const struct util_format_test_case *test) +test_format_unpack_s_8uscaled(const struct util_format_description *format_desc, +                               const struct util_format_test_case *test)  { -   uint8_t unpacked[4]; -   uint8_t expected[4]; -   unsigned i; +   uint8_t unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH] = { { 0 } }; +   uint8_t expected[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH] = { { 0 } }; +   unsigned i, j;     boolean success; -   util_format_unpack_4ub(test->format, unpacked, test->packed); +   format_desc->unpack_s_8uscaled(&unpacked[0][0], sizeof unpacked[0], +                                  test->packed, 0, +                                  format_desc->block.width, format_desc->block.height); -   convert_4f_to_4ub(expected, test->unpacked); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         expected[i][j] = test->unpacked[i][j][1]; +      } +   }     success = TRUE; -   for (i = 0; i < 4; ++i) -      if (expected[i] != unpacked[i]) -         success = FALSE; +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         if (expected[i][j] != unpacked[i][j]) { +            success = FALSE; +         } +      } +   }     if (!success) { -      printf("FAILED: (0x%02x 0x%02x 0x%02x 0x%02x) obtained\n", unpacked[0], unpacked[1], unpacked[2], unpacked[3]); -      printf("        (0x%02x 0x%02x 0x%02x 0x%02x) expected\n", expected[0], expected[1], expected[2], expected[3]); +      print_unpacked_s_8uscaled(format_desc, "FAILED: ", unpacked, " obtained\n"); +      print_unpacked_s_8uscaled(format_desc, "        ", expected, " expected\n");     }     return success; @@ -664,36 +583,37 @@ test_format_unpack_4ub(const struct util_format_test_case *test)  static boolean -test_format_pack_4ub(const struct util_format_test_case *test) +test_format_pack_s_8uscaled(const struct util_format_description *format_desc, +                             const struct util_format_test_case *test)  { -   uint8_t unpacked[4]; -   uint8_t packed[MAX_PACKED_BYTES]; -   unsigned i; +   uint8_t unpacked[UTIL_FORMAT_MAX_UNPACKED_HEIGHT][UTIL_FORMAT_MAX_UNPACKED_WIDTH]; +   uint8_t packed[UTIL_FORMAT_MAX_PACKED_BYTES]; +   unsigned i, j;     boolean success; -   convert_4f_to_4ub(unpacked, test->unpacked); +   for (i = 0; i < format_desc->block.height; ++i) { +      for (j = 0; j < format_desc->block.width; ++j) { +         unpacked[i][j] = test->unpacked[i][j][1]; +         if (test->unpacked[i][j][0]) { +            return TRUE; +         } +      } +   }     memset(packed, 0, sizeof packed); -   util_format_pack_4ub(test->format, packed, unpacked[0], unpacked[1], unpacked[2], unpacked[3]); +   format_desc->pack_s_8uscaled(packed, 0, +                                &unpacked[0][0], sizeof unpacked[0], +                                format_desc->block.width, format_desc->block.height);     success = TRUE; -   for (i = 0; i < MAX_PACKED_BYTES; ++i) +   for (i = 0; i < format_desc->block.bits/8; ++i)        if ((test->packed[i] & test->mask[i]) != (packed[i] & test->mask[i]))           success = FALSE;     if (!success) { -      /* TODO: print more than 4 bytes */ -      printf("FAILED: (%02x %02x %02x %02x  %02x %02x %02x %02x  %02x %02x %02x %02x  %02x %02x %02x %02x) obtained\n", -             packed[0], packed[1], packed[2], packed[3], -             packed[4], packed[5], packed[6], packed[7], -             packed[8], packed[9], packed[10], packed[11], -             packed[12], packed[13], packed[14], packed[15]); -      printf("        (%02x %02x %02x %02x  %02x %02x %02x %02x  %02x %02x %02x %02x  %02x %02x %02x %02x) expected\n", -             test->packed[0], test->packed[1], test->packed[2], test->packed[3], -             test->packed[4], test->packed[5], test->packed[6], test->packed[7], -             test->packed[8], test->packed[9], test->packed[10], test->packed[11], -             test->packed[12], test->packed[13], test->packed[14], test->packed[15]); +      print_packed(format_desc, "FAILED: ", packed, " obtained\n"); +      print_packed(format_desc, "        ", test->packed, " expected\n");     }     return success; @@ -701,26 +621,29 @@ test_format_pack_4ub(const struct util_format_test_case *test)  typedef boolean -(*test_func_t)(const struct util_format_test_case *test); +(*test_func_t)(const struct util_format_description *format_desc, +               const struct util_format_test_case *test);  static boolean -test_one(test_func_t func, const char *suffix) +test_one_func(const struct util_format_description *format_desc, +              test_func_t func, +              const char *suffix)  { -   enum pipe_format last_format = PIPE_FORMAT_NONE;     unsigned i;     bool success = TRUE; -   for (i = 0; i < sizeof(test_cases)/sizeof(test_cases[0]); ++i) { -      if (test_cases[i].format != last_format) { -         const struct util_format_description *format_desc; -         format_desc = util_format_description(test_cases[i].format); -         printf("Testing %s.%s ...\n", format_desc->name, suffix); -         last_format = test_cases[i].format; -      } +   printf("Testing util_format_%s_%s ...\n", +          format_desc->short_name, suffix); -      if (!func(&test_cases[i])) -        success = FALSE; +   for (i = 0; i < util_format_nr_test_cases; ++i) { +      const struct util_format_test_case *test = &util_format_test_cases[i]; + +      if (test->format == format_desc->format) { +         if (!func(format_desc, &util_format_test_cases[i])) { +           success = FALSE; +         } +      }     }     return success; @@ -730,19 +653,44 @@ test_one(test_func_t func, const char *suffix)  static boolean  test_all(void)  { +   enum pipe_format format;     bool success = TRUE; -   if (!test_one(&test_format_pack_4f, "pack_4f")) -     success = FALSE; +   for (format = 1; format < PIPE_FORMAT_COUNT; ++format) { +      const struct util_format_description *format_desc; -   if (!test_one(&test_format_unpack_4f, "unpack_4f")) -     success = FALSE; +      format_desc = util_format_description(format); +      if (!format_desc) { +         continue; +      } -   if (!test_one(&test_format_pack_4ub, "pack_4ub")) -     success = FALSE; +      if (format_desc->layout == UTIL_FORMAT_LAYOUT_S3TC && +          !util_format_s3tc_enabled) { +         continue; +      } -   if (!test_one(&test_format_unpack_4ub, "unpack_4ub")) -     success = FALSE; +#     define TEST_ONE_FUNC(name) \ +      if (format_desc->name) { \ +         if (!test_one_func(format_desc, &test_format_##name, #name)) { \ +           success = FALSE; \ +         } \ +      } + +      TEST_ONE_FUNC(fetch_rgba_float); +      TEST_ONE_FUNC(pack_rgba_float); +      TEST_ONE_FUNC(unpack_rgba_float); +      TEST_ONE_FUNC(pack_rgba_8unorm); +      TEST_ONE_FUNC(unpack_rgba_8unorm); + +      TEST_ONE_FUNC(unpack_z_32unorm); +      TEST_ONE_FUNC(pack_z_32unorm); +      TEST_ONE_FUNC(unpack_z_float); +      TEST_ONE_FUNC(pack_z_float); +      TEST_ONE_FUNC(unpack_s_8uscaled); +      TEST_ONE_FUNC(pack_s_8uscaled); + +#     undef TEST_ONE_FUNC +   }     return success;  } @@ -752,6 +700,8 @@ int main(int argc, char **argv)  {     boolean success; +   util_format_s3tc_init(); +     success = test_all();     return success ? 0 : 1; diff --git a/progs/gallium/unit/u_half_test.c b/progs/gallium/unit/u_half_test.c new file mode 100644 index 0000000000..00bda7f50a --- /dev/null +++ b/progs/gallium/unit/u_half_test.c @@ -0,0 +1,32 @@ +#include <stdlib.h> +#include <stdio.h> +#include <float.h> + +#include "util/u_math.h" +#include "util/u_half.h" + +int +main(int argc, char **argv) +{ +   unsigned i; +   unsigned roundtrip_fails = 0; +   for(i = 0; i < 1 << 16; ++i) +   { +      uint16_t h = (uint16_t) i; +      union fi f; +      uint16_t rh; +      f.ui = util_half_to_floatui(h); +      rh = util_floatui_to_half(f.ui); +      if(h != rh) +      { +	 printf("Roundtrip failed: %x -> %x = %f -> %x\n", h, f.ui, f.f, rh); +	 ++roundtrip_fails; +      } +   } + +   if(roundtrip_fails) +      printf("Failure! %u/65536 half floats failed a conversion to float and back.\n", roundtrip_fails); +   else +      printf("Success!\n"); +   return 0; +} | 
