radv: Only save the descriptor set if we have one.
[mesa.git] / src / mesa / drivers / dri / nouveau / nv04_surface.c
index 239d77039b36a70dc8eee0f93e5a72aa4cf8caa4..b1f0ea0a983b9194b827db6ab6b35d939c82f99b 100644 (file)
 #include "nv04_driver.h"
 
 static inline int
-swzsurf_format(gl_format format)
+swzsurf_format(mesa_format format)
 {
        switch (format) {
-       case MESA_FORMAT_A8:
-       case MESA_FORMAT_L8:
-       case MESA_FORMAT_I8:
-       case MESA_FORMAT_RGB332:
+       case MESA_FORMAT_A_UNORM8:
+       case MESA_FORMAT_L_UNORM8:
+       case MESA_FORMAT_I_UNORM8:
+       case MESA_FORMAT_B2G3R3_UNORM:
                return NV04_SWIZZLED_SURFACE_FORMAT_COLOR_Y8;
 
-       case MESA_FORMAT_RGB565:
-       case MESA_FORMAT_RGB565_REV:
-       case MESA_FORMAT_ARGB4444:
-       case MESA_FORMAT_ARGB4444_REV:
-       case MESA_FORMAT_ARGB1555:
-       case MESA_FORMAT_RGBA5551:
-       case MESA_FORMAT_ARGB1555_REV:
-       case MESA_FORMAT_AL88:
-       case MESA_FORMAT_AL88_REV:
+       case MESA_FORMAT_B5G6R5_UNORM:
+       case MESA_FORMAT_R5G6B5_UNORM:
+       case MESA_FORMAT_B4G4R4A4_UNORM:
+       case MESA_FORMAT_A4R4G4B4_UNORM:
+       case MESA_FORMAT_B5G5R5A1_UNORM:
+       case MESA_FORMAT_A1B5G5R5_UNORM:
+       case MESA_FORMAT_A1R5G5B5_UNORM:
+       case MESA_FORMAT_L8A8_UNORM:
+       case MESA_FORMAT_A8L8_UNORM:
        case MESA_FORMAT_YCBCR:
        case MESA_FORMAT_YCBCR_REV:
-       case MESA_FORMAT_Z16:
+       case MESA_FORMAT_Z_UNORM16:
                return NV04_SWIZZLED_SURFACE_FORMAT_COLOR_R5G6B5;
 
-       case MESA_FORMAT_RGBA8888:
-       case MESA_FORMAT_RGBA8888_REV:
-       case MESA_FORMAT_XRGB8888:
-       case MESA_FORMAT_ARGB8888:
-       case MESA_FORMAT_ARGB8888_REV:
-       case MESA_FORMAT_S8_Z24:
-       case MESA_FORMAT_Z24_S8:
-       case MESA_FORMAT_Z32:
+       case MESA_FORMAT_A8B8G8R8_UNORM:
+       case MESA_FORMAT_R8G8B8A8_UNORM:
+       case MESA_FORMAT_B8G8R8X8_UNORM:
+       case MESA_FORMAT_B8G8R8A8_UNORM:
+       case MESA_FORMAT_A8R8G8B8_UNORM:
+       case MESA_FORMAT_Z24_UNORM_S8_UINT:
+       case MESA_FORMAT_S8_UINT_Z24_UNORM:
+       case MESA_FORMAT_Z_UNORM32:
                return NV04_SWIZZLED_SURFACE_FORMAT_COLOR_A8R8G8B8;
 
        default:
@@ -73,37 +73,37 @@ swzsurf_format(gl_format format)
 }
 
 static inline int
-surf2d_format(gl_format format)
+surf2d_format(mesa_format format)
 {
        switch (format) {
-       case MESA_FORMAT_A8:
-       case MESA_FORMAT_L8:
-       case MESA_FORMAT_I8:
-       case MESA_FORMAT_RGB332:
+       case MESA_FORMAT_A_UNORM8:
+       case MESA_FORMAT_L_UNORM8:
+       case MESA_FORMAT_I_UNORM8:
+       case MESA_FORMAT_B2G3R3_UNORM:
                return NV04_CONTEXT_SURFACES_2D_FORMAT_Y8;
 
-       case MESA_FORMAT_RGB565:
-       case MESA_FORMAT_RGB565_REV:
-       case MESA_FORMAT_ARGB4444:
-       case MESA_FORMAT_ARGB4444_REV:
-       case MESA_FORMAT_ARGB1555:
-       case MESA_FORMAT_RGBA5551:
-       case MESA_FORMAT_ARGB1555_REV:
-       case MESA_FORMAT_AL88:
-       case MESA_FORMAT_AL88_REV:
+       case MESA_FORMAT_B5G6R5_UNORM:
+       case MESA_FORMAT_R5G6B5_UNORM:
+       case MESA_FORMAT_B4G4R4A4_UNORM:
+       case MESA_FORMAT_A4R4G4B4_UNORM:
+       case MESA_FORMAT_B5G5R5A1_UNORM:
+       case MESA_FORMAT_A1B5G5R5_UNORM:
+       case MESA_FORMAT_A1R5G5B5_UNORM:
+       case MESA_FORMAT_L8A8_UNORM:
+       case MESA_FORMAT_A8L8_UNORM:
        case MESA_FORMAT_YCBCR:
        case MESA_FORMAT_YCBCR_REV:
-       case MESA_FORMAT_Z16:
+       case MESA_FORMAT_Z_UNORM16:
                return NV04_CONTEXT_SURFACES_2D_FORMAT_R5G6B5;
 
-       case MESA_FORMAT_RGBA8888:
-       case MESA_FORMAT_RGBA8888_REV:
-       case MESA_FORMAT_XRGB8888:
-       case MESA_FORMAT_ARGB8888:
-       case MESA_FORMAT_ARGB8888_REV:
-       case MESA_FORMAT_S8_Z24:
-       case MESA_FORMAT_Z24_S8:
-       case MESA_FORMAT_Z32:
+       case MESA_FORMAT_A8B8G8R8_UNORM:
+       case MESA_FORMAT_R8G8B8A8_UNORM:
+       case MESA_FORMAT_B8G8R8X8_UNORM:
+       case MESA_FORMAT_B8G8R8A8_UNORM:
+       case MESA_FORMAT_A8R8G8B8_UNORM:
+       case MESA_FORMAT_Z24_UNORM_S8_UINT:
+       case MESA_FORMAT_S8_UINT_Z24_UNORM:
+       case MESA_FORMAT_Z_UNORM32:
                return NV04_CONTEXT_SURFACES_2D_FORMAT_Y32;
 
        default:
@@ -112,37 +112,37 @@ surf2d_format(gl_format format)
 }
 
 static inline int
-rect_format(gl_format format)
+rect_format(mesa_format format)
 {
        switch (format) {
-       case MESA_FORMAT_A8:
-       case MESA_FORMAT_L8:
-       case MESA_FORMAT_I8:
-       case MESA_FORMAT_RGB332:
+       case MESA_FORMAT_A_UNORM8:
+       case MESA_FORMAT_L_UNORM8:
+       case MESA_FORMAT_I_UNORM8:
+       case MESA_FORMAT_B2G3R3_UNORM:
                return NV04_GDI_RECTANGLE_TEXT_COLOR_FORMAT_A8R8G8B8;
 
-       case MESA_FORMAT_RGB565:
-       case MESA_FORMAT_RGB565_REV:
-       case MESA_FORMAT_ARGB4444:
-       case MESA_FORMAT_ARGB4444_REV:
-       case MESA_FORMAT_ARGB1555:
-       case MESA_FORMAT_RGBA5551:
-       case MESA_FORMAT_ARGB1555_REV:
-       case MESA_FORMAT_AL88:
-       case MESA_FORMAT_AL88_REV:
+       case MESA_FORMAT_B5G6R5_UNORM:
+       case MESA_FORMAT_R5G6B5_UNORM:
+       case MESA_FORMAT_B4G4R4A4_UNORM:
+       case MESA_FORMAT_A4R4G4B4_UNORM:
+       case MESA_FORMAT_B5G5R5A1_UNORM:
+       case MESA_FORMAT_A1B5G5R5_UNORM:
+       case MESA_FORMAT_A1R5G5B5_UNORM:
+       case MESA_FORMAT_L8A8_UNORM:
+       case MESA_FORMAT_A8L8_UNORM:
        case MESA_FORMAT_YCBCR:
        case MESA_FORMAT_YCBCR_REV:
-       case MESA_FORMAT_Z16:
+       case MESA_FORMAT_Z_UNORM16:
                return NV04_GDI_RECTANGLE_TEXT_COLOR_FORMAT_A16R5G6B5;
 
-       case MESA_FORMAT_RGBA8888:
-       case MESA_FORMAT_RGBA8888_REV:
-       case MESA_FORMAT_XRGB8888:
-       case MESA_FORMAT_ARGB8888:
-       case MESA_FORMAT_ARGB8888_REV:
-       case MESA_FORMAT_S8_Z24:
-       case MESA_FORMAT_Z24_S8:
-       case MESA_FORMAT_Z32:
+       case MESA_FORMAT_A8B8G8R8_UNORM:
+       case MESA_FORMAT_R8G8B8A8_UNORM:
+       case MESA_FORMAT_B8G8R8X8_UNORM:
+       case MESA_FORMAT_B8G8R8A8_UNORM:
+       case MESA_FORMAT_A8R8G8B8_UNORM:
+       case MESA_FORMAT_Z24_UNORM_S8_UINT:
+       case MESA_FORMAT_S8_UINT_Z24_UNORM:
+       case MESA_FORMAT_Z_UNORM32:
                return NV04_GDI_RECTANGLE_TEXT_COLOR_FORMAT_A8R8G8B8;
 
        default:
@@ -151,37 +151,37 @@ rect_format(gl_format format)
 }
 
 static inline int
-sifm_format(gl_format format)
+sifm_format(mesa_format format)
 {
        switch (format) {
-       case MESA_FORMAT_A8:
-       case MESA_FORMAT_L8:
-       case MESA_FORMAT_I8:
-       case MESA_FORMAT_RGB332:
+       case MESA_FORMAT_A_UNORM8:
+       case MESA_FORMAT_L_UNORM8:
+       case MESA_FORMAT_I_UNORM8:
+       case MESA_FORMAT_B2G3R3_UNORM:
                return NV03_SCALED_IMAGE_FROM_MEMORY_COLOR_FORMAT_AY8;
 
-       case MESA_FORMAT_RGB565:
-       case MESA_FORMAT_RGB565_REV:
-       case MESA_FORMAT_ARGB4444:
-       case MESA_FORMAT_ARGB4444_REV:
-       case MESA_FORMAT_ARGB1555:
-       case MESA_FORMAT_RGBA5551:
-       case MESA_FORMAT_ARGB1555_REV:
-       case MESA_FORMAT_AL88:
-       case MESA_FORMAT_AL88_REV:
+       case MESA_FORMAT_B5G6R5_UNORM:
+       case MESA_FORMAT_R5G6B5_UNORM:
+       case MESA_FORMAT_B4G4R4A4_UNORM:
+       case MESA_FORMAT_A4R4G4B4_UNORM:
+       case MESA_FORMAT_B5G5R5A1_UNORM:
+       case MESA_FORMAT_A1B5G5R5_UNORM:
+       case MESA_FORMAT_A1R5G5B5_UNORM:
+       case MESA_FORMAT_L8A8_UNORM:
+       case MESA_FORMAT_A8L8_UNORM:
        case MESA_FORMAT_YCBCR:
        case MESA_FORMAT_YCBCR_REV:
-       case MESA_FORMAT_Z16:
+       case MESA_FORMAT_Z_UNORM16:
                return NV03_SCALED_IMAGE_FROM_MEMORY_COLOR_FORMAT_R5G6B5;
 
-       case MESA_FORMAT_RGBA8888:
-       case MESA_FORMAT_RGBA8888_REV:
-       case MESA_FORMAT_XRGB8888:
-       case MESA_FORMAT_ARGB8888:
-       case MESA_FORMAT_ARGB8888_REV:
-       case MESA_FORMAT_S8_Z24:
-       case MESA_FORMAT_Z24_S8:
-       case MESA_FORMAT_Z32:
+       case MESA_FORMAT_A8B8G8R8_UNORM:
+       case MESA_FORMAT_R8G8B8A8_UNORM:
+       case MESA_FORMAT_B8G8R8X8_UNORM:
+       case MESA_FORMAT_B8G8R8A8_UNORM:
+       case MESA_FORMAT_A8R8G8B8_UNORM:
+       case MESA_FORMAT_Z24_UNORM_S8_UINT:
+       case MESA_FORMAT_S8_UINT_Z24_UNORM:
+       case MESA_FORMAT_Z_UNORM32:
                return NV03_SCALED_IMAGE_FROM_MEMORY_COLOR_FORMAT_A8R8G8B8;
 
        default:
@@ -267,7 +267,6 @@ nv04_surface_copy_swizzle(struct gl_context *ctx,
        if (context_chipset(ctx) < 0x10) {
                BEGIN_NV04(push, NV01_SUBC(SURF, OBJECT), 1);
                PUSH_DATA (push, hw->surf3d->handle);
-               PUSH_KICK(push);
        }
 }
 
@@ -312,9 +311,6 @@ nv04_surface_copy_m2mf(struct gl_context *ctx,
                dst_offset += dst->pitch * count;
                h -= count;
        }
-
-       if (context_chipset(ctx) < 0x10)
-               PUSH_KICK(push);
 }
 
 typedef unsigned (*get_offset_t)(struct nouveau_surface *s,
@@ -397,6 +393,15 @@ nv04_surface_copy(struct gl_context *ctx,
                  int dx, int dy, int sx, int sy,
                  int w, int h)
 {
+       if (_mesa_is_format_compressed(src->format)) {
+               sx = get_format_blocksx(src->format, sx);
+               sy = get_format_blocksy(src->format, sy);
+               dx = get_format_blocksx(dst->format, dx);
+               dy = get_format_blocksy(dst->format, dy);
+               w = get_format_blocksx(src->format, w);
+               h = get_format_blocksy(src->format, h);
+       }
+
        /* Linear texture copy. */
        if ((src->layout == LINEAR && dst->layout == LINEAR) ||
            dst->width <= 2 || dst->height <= 1) {
@@ -453,9 +458,6 @@ nv04_surface_fill(struct gl_context *ctx,
        BEGIN_NV04(push, NV04_GDI(UNCLIPPED_RECTANGLE_POINT(0)), 2);
        PUSH_DATA (push, (dx << 16) | dy);
        PUSH_DATA (push, ( w << 16) |  h);
-
-       if (context_chipset(ctx) < 0x10)
-               PUSH_KICK(push);
 }
 
 void
@@ -575,8 +577,10 @@ nv04_surface_init(struct gl_context *ctx)
        /* Swizzled surface. */
        if (context_chipset(ctx) < 0x20)
                class = NV04_SURFACE_SWZ_CLASS;
-       else
+       else if (context_chipset (ctx) < 0x30)
                class = NV20_SURFACE_SWZ_CLASS;
+       else
+               class = NV30_SURFACE_SWZ_CLASS;
 
        ret = nouveau_object_new(chan, handle++, class, NULL, 0, &hw->swzsurf);
        if (ret)