~ubuntu-branches/ubuntu/natty/mesa/natty-proposed

« back to all changes in this revision

Viewing changes to src/mesa/drivers/dri/radeon/radeon_tex_getimage.c

  • Committer: Bazaar Package Importer
  • Author(s): Robert Hooker, Robert Hooker, Christopher James Halse Rogers
  • Date: 2010-09-14 08:55:40 UTC
  • mfrom: (1.2.28 upstream)
  • Revision ID: james.westby@ubuntu.com-20100914085540-m4fpl0hdjlfd4jgz
Tags: 7.9~git20100909-0ubuntu1
[ Robert Hooker ]
* New upstream git snapshot up to commit 94118fe2d4b1e5 (LP: #631413)
* New features include ATI HD5xxx series support in r600, and a vastly
  improved glsl compiler.
* Remove pre-generated .pc's, use the ones generated at build time
  instead.
* Remove all references to mesa-utils now that its no longer shipped
  with the mesa source.
* Disable the experimental ARB_fragment_shader option by default on
  i915, it exposes incomplete functionality that breaks KDE compositing
  among other things. It can be enabled via driconf still. (LP: #628930).

[ Christopher James Halse Rogers ]
* debian/patches/04_osmesa_version.diff:
  - Refresh for new upstream
* Bugs fixed in this release:
  - Fixes severe rendering corruption in Unity on radeon (LP: #628727,
    LP: #596292, LP: #599741, LP: #630315, LP: #613694, LP: #599741).
  - Also fixes rendering in gnome-shell (LP: #578619).
  - Flickering in OpenGL apps on radeon (LP: #626943, LP: #610541).
  - Provides preliminary support for new intel chips (LP: #601052).
* debian/rules:
  - Update configure flags to match upstream reshuffling.
  - Explicitly remove gallium DRI drivers that we don't want to ship.
* Update debian/gbp.conf for this Maverick-specific packaging
* libegl1-mesa-dri-x11,kms: There are no longer separate kms or x11 drivers
  for EGL, libegl1-mesa-drivers now contains a single driver that provides
  both backends.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Copyright (C) 2009 Maciej Cencora.
 
3
 * Copyright (C) 2008 Nicolai Haehnle.
 
4
 * Copyright (C) The Weather Channel, Inc.  2002.  All Rights Reserved.
 
5
 *
 
6
 * The Weather Channel (TM) funded Tungsten Graphics to develop the
 
7
 * initial release of the Radeon 8500 driver under the XFree86 license.
 
8
 * This notice must be preserved.
 
9
 *
 
10
 * Permission is hereby granted, free of charge, to any person obtaining
 
11
 * a copy of this software and associated documentation files (the
 
12
 * "Software"), to deal in the Software without restriction, including
 
13
 * without limitation the rights to use, copy, modify, merge, publish,
 
14
 * distribute, sublicense, and/or sell copies of the Software, and to
 
15
 * permit persons to whom the Software is furnished to do so, subject to
 
16
 * the following conditions:
 
17
 *
 
18
 * The above copyright notice and this permission notice (including the
 
19
 * next paragraph) shall be included in all copies or substantial
 
20
 * portions of the Software.
 
21
 *
 
22
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 
23
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 
24
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 
25
 * IN NO EVENT SHALL THE COPYRIGHT OWNER(S) AND/OR ITS SUPPLIERS BE
 
26
 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 
27
 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 
28
 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 
29
 *
 
30
 */
 
31
 
 
32
#include "radeon_common_context.h"
 
33
#include "radeon_texture.h"
 
34
#include "radeon_mipmap_tree.h"
 
35
 
 
36
#include "main/texgetimage.h"
 
37
 
 
38
/**
 
39
 * Need to map texture image into memory before copying image data,
 
40
 * then unmap it.
 
41
 */
 
42
static void
 
43
radeon_get_tex_image(GLcontext * ctx, GLenum target, GLint level,
 
44
             GLenum format, GLenum type, GLvoid * pixels,
 
45
             struct gl_texture_object *texObj,
 
46
             struct gl_texture_image *texImage, int compressed)
 
47
{
 
48
    radeon_texture_image *image = get_radeon_texture_image(texImage);
 
49
 
 
50
    radeon_print(RADEON_TEXTURE, RADEON_NORMAL,
 
51
                 "%s(%p, tex %p, image %p) compressed %d.\n",
 
52
                 __func__, ctx, texObj, image, compressed);
 
53
 
 
54
    if (image->mt) {
 
55
        radeonContextPtr rmesa = RADEON_CONTEXT(ctx);
 
56
        /* Map the texture image read-only */
 
57
        if (radeon_bo_is_referenced_by_cs(image->mt->bo, rmesa->cmdbuf.cs)) {
 
58
            radeon_print(RADEON_TEXTURE, RADEON_VERBOSE,
 
59
                "%s: called for texture that is queued for GPU processing\n",
 
60
                __func__);
 
61
            radeon_firevertices(rmesa);
 
62
        }
 
63
 
 
64
        radeon_teximage_map(image, GL_FALSE);
 
65
    } else {
 
66
        /* Image hasn't been uploaded to a miptree yet */
 
67
        assert(image->base.Data);
 
68
    }
 
69
 
 
70
    if (compressed) {
 
71
        /* FIXME: this can't work for small textures (mips) which
 
72
                 use different hw stride */
 
73
        _mesa_get_compressed_teximage(ctx, target, level, pixels,
 
74
                          texObj, texImage);
 
75
    } else {
 
76
        _mesa_get_teximage(ctx, target, level, format, type, pixels,
 
77
                   texObj, texImage);
 
78
    }
 
79
 
 
80
    if (image->mt) {
 
81
        radeon_teximage_unmap(image);
 
82
    }
 
83
}
 
84
 
 
85
void
 
86
radeonGetTexImage(GLcontext * ctx, GLenum target, GLint level,
 
87
          GLenum format, GLenum type, GLvoid * pixels,
 
88
          struct gl_texture_object *texObj,
 
89
          struct gl_texture_image *texImage)
 
90
{
 
91
    radeon_get_tex_image(ctx, target, level, format, type, pixels,
 
92
                 texObj, texImage, 0);
 
93
}
 
94
 
 
95
void
 
96
radeonGetCompressedTexImage(GLcontext *ctx, GLenum target, GLint level,
 
97
                GLvoid *pixels,
 
98
                struct gl_texture_object *texObj,
 
99
                struct gl_texture_image *texImage)
 
100
{
 
101
    radeon_get_tex_image(ctx, target, level, 0, 0, pixels,
 
102
                 texObj, texImage, 1);
 
103
}