diff options
| author | Marek Olšák <maraeo@gmail.com> | 2010-02-06 03:11:50 +0100 | 
|---|---|---|
| committer | Marek Olšák <maraeo@gmail.com> | 2010-03-07 15:39:37 +0100 | 
| commit | 4012219f1f215cec9406be644b6b9d421bb5d8e4 (patch) | |
| tree | b448a2460faf1f864a5ed230a742cbdf19c2cc57 /src | |
| parent | ccbe3f0314c8278c55e1046a619969ae539564de (diff) | |
r300g: move r300_transfer to separate files
Diffstat (limited to 'src')
| -rw-r--r-- | src/gallium/drivers/r300/Makefile | 3 | ||||
| -rw-r--r-- | src/gallium/drivers/r300/SConscript | 1 | ||||
| -rw-r--r-- | src/gallium/drivers/r300/r300_screen.c | 74 | ||||
| -rw-r--r-- | src/gallium/drivers/r300/r300_screen.h | 16 | ||||
| -rw-r--r-- | src/gallium/drivers/r300/r300_transfer.c | 101 | ||||
| -rw-r--r-- | src/gallium/drivers/r300/r300_transfer.h | 60 | 
6 files changed, 171 insertions, 84 deletions
| diff --git a/src/gallium/drivers/r300/Makefile b/src/gallium/drivers/r300/Makefile index 1f69daec81..61b54af4dd 100644 --- a/src/gallium/drivers/r300/Makefile +++ b/src/gallium/drivers/r300/Makefile @@ -19,7 +19,8 @@ C_SOURCES = \  	r300_state_invariant.c \  	r300_vs.c \  	r300_texture.c \ -	r300_tgsi_to_rc.c +	r300_tgsi_to_rc.c \ +	r300_transfer.c  LIBRARY_INCLUDES = \  	-I$(TOP)/src/mesa/drivers/dri/r300/compiler \ diff --git a/src/gallium/drivers/r300/SConscript b/src/gallium/drivers/r300/SConscript index 183aa17f9b..27b2e30993 100644 --- a/src/gallium/drivers/r300/SConscript +++ b/src/gallium/drivers/r300/SConscript @@ -30,6 +30,7 @@ r300 = env.ConvenienceLibrary(          'r300_vs.c',          'r300_texture.c',          'r300_tgsi_to_rc.c', +        'r300_transfer.c',      ] + r300compiler) + r300compiler  Export('r300') diff --git a/src/gallium/drivers/r300/r300_screen.c b/src/gallium/drivers/r300/r300_screen.c index d397a8eb2b..a35be05940 100644 --- a/src/gallium/drivers/r300/r300_screen.c +++ b/src/gallium/drivers/r300/r300_screen.c @@ -1,5 +1,6 @@  /*   * Copyright 2008 Corbin Simpson <MostAwesomeDude@gmail.com> + * Copyright 2010 Marek Olšák <maraeo@gmail.com>   *   * Permission is hereby granted, free of charge, to any person obtaining a   * copy of this software and associated documentation files (the "Software"), @@ -20,14 +21,13 @@   * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE   * USE OR OTHER DEALINGS IN THE SOFTWARE. */ -#include "util/u_inlines.h"  #include "util/u_format.h"  #include "util/u_memory.h"  #include "util/u_simple_screen.h"  #include "r300_context.h" -#include "r300_screen.h"  #include "r300_texture.h" +#include "r300_transfer.h"  #include "radeon_winsys.h"  #include "r300_winsys.h" @@ -250,70 +250,6 @@ static boolean r300_is_format_supported(struct pipe_screen* screen,      return retval == usage;  } -static struct pipe_transfer* -r300_get_tex_transfer(struct pipe_screen *screen, -                      struct pipe_texture *texture, -                      unsigned face, unsigned level, unsigned zslice, -                      enum pipe_transfer_usage usage, unsigned x, unsigned y, -                      unsigned w, unsigned h) -{ -    struct r300_texture *tex = (struct r300_texture *)texture; -    struct r300_transfer *trans; -    struct r300_screen *rscreen = r300_screen(screen); -    unsigned offset; - -    offset = r300_texture_get_offset(tex, level, zslice, face);  /* in bytes */ - -    trans = CALLOC_STRUCT(r300_transfer); -    if (trans) { -        pipe_texture_reference(&trans->transfer.texture, texture); -        trans->transfer.x = x; -        trans->transfer.y = y; -        trans->transfer.width = w; -        trans->transfer.height = h; -        trans->transfer.stride = r300_texture_get_stride(rscreen, tex, level); -        trans->transfer.usage = usage; -        trans->transfer.zslice = zslice; -        trans->transfer.face = face; - -        trans->offset = offset; -    } -    return &trans->transfer; -} - -static void -r300_tex_transfer_destroy(struct pipe_transfer *trans) -{ -   pipe_texture_reference(&trans->texture, NULL); -   FREE(trans); -} - -static void* r300_transfer_map(struct pipe_screen* screen, -                              struct pipe_transfer* transfer) -{ -    struct r300_texture* tex = (struct r300_texture*)transfer->texture; -    char* map; -    enum pipe_format format = tex->tex.format; - -    map = pipe_buffer_map(screen, tex->buffer, -                          pipe_transfer_buffer_flags(transfer)); - -    if (!map) { -        return NULL; -    } - -    return map + r300_transfer(transfer)->offset + -        transfer->y / util_format_get_blockheight(format) * transfer->stride + -        transfer->x / util_format_get_blockwidth(format) * util_format_get_blocksize(format); -} - -static void r300_transfer_unmap(struct pipe_screen* screen, -                                struct pipe_transfer* transfer) -{ -    struct r300_texture* tex = (struct r300_texture*)transfer->texture; -    pipe_buffer_unmap(screen, tex->buffer); -} -  static void r300_destroy_screen(struct pipe_screen* pscreen)  {      struct r300_screen* r300screen = r300_screen(pscreen); @@ -350,13 +286,11 @@ struct pipe_screen* r300_create_screen(struct radeon_winsys* radeon_winsys)      r300screen->screen.get_paramf = r300_get_paramf;      r300screen->screen.is_format_supported = r300_is_format_supported;      r300screen->screen.context_create = r300_create_context; -    r300screen->screen.get_tex_transfer = r300_get_tex_transfer; -    r300screen->screen.tex_transfer_destroy = r300_tex_transfer_destroy; -    r300screen->screen.transfer_map = r300_transfer_map; -    r300screen->screen.transfer_unmap = r300_transfer_unmap;      r300_init_screen_texture_functions(&r300screen->screen); +    r300_init_screen_transfer_functions(&r300screen->screen);      u_simple_screen_init(&r300screen->screen);      return &r300screen->screen;  } + diff --git a/src/gallium/drivers/r300/r300_screen.h b/src/gallium/drivers/r300/r300_screen.h index 502fbfa5a2..6d72fec778 100644 --- a/src/gallium/drivers/r300/r300_screen.h +++ b/src/gallium/drivers/r300/r300_screen.h @@ -1,5 +1,6 @@  /*   * Copyright 2008 Corbin Simpson <MostAwesomeDude@gmail.com> + * Copyright 2010 Marek Olšák <maraeo@gmail.com>   *   * Permission is hereby granted, free of charge, to any person obtaining a   * copy of this software and associated documentation files (the "Software"), @@ -42,25 +43,14 @@ struct r300_screen {      unsigned debug;  }; -struct r300_transfer { -    /* Parent class */ -    struct pipe_transfer transfer; - -    /* Offset from start of buffer. */ -    unsigned offset; -};  /* Convenience cast wrapper. */  static INLINE struct r300_screen* r300_screen(struct pipe_screen* screen) {      return (struct r300_screen*)screen;  } -/* Convenience cast wrapper. */ -static INLINE struct r300_transfer* -r300_transfer(struct pipe_transfer* transfer) -{ -    return (struct r300_transfer*)transfer; -} +/* Creates a new r300 screen. */ +struct pipe_screen* r300_create_screen(struct radeon_winsys* radeon_winsys);  /* Debug functionality. */ diff --git a/src/gallium/drivers/r300/r300_transfer.c b/src/gallium/drivers/r300/r300_transfer.c new file mode 100644 index 0000000000..fa48688db2 --- /dev/null +++ b/src/gallium/drivers/r300/r300_transfer.c @@ -0,0 +1,101 @@ +/* + * Copyright 2008 Corbin Simpson <MostAwesomeDude@gmail.com> + * Copyright 2010 Marek Olšák <maraeo@gmail.com> + * + * 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 + * on the rights to use, copy, modify, merge, publish, distribute, sub + * license, 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 NON-INFRINGEMENT. IN NO EVENT SHALL + * THE AUTHOR(S) AND/OR THEIR SUPPLIERS 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. */ + +#include "r300_context.h" +#include "r300_transfer.h" +#include "r300_texture.h" +#include "r300_screen.h" + +#include "util/u_memory.h" +#include "util/u_format.h" + +static struct pipe_transfer* +r300_get_tex_transfer(struct pipe_screen *screen, +                      struct pipe_texture *texture, +                      unsigned face, unsigned level, unsigned zslice, +                      enum pipe_transfer_usage usage, unsigned x, unsigned y, +                      unsigned w, unsigned h) +{ +    struct r300_texture *tex = (struct r300_texture *)texture; +    struct r300_transfer *trans; +    struct r300_screen *rscreen = r300_screen(screen); +    unsigned offset; + +    offset = r300_texture_get_offset(tex, level, zslice, face);  /* in bytes */ + +    trans = CALLOC_STRUCT(r300_transfer); +    if (trans) { +        pipe_texture_reference(&trans->transfer.texture, texture); +        trans->transfer.x = x; +        trans->transfer.y = y; +        trans->transfer.width = w; +        trans->transfer.height = h; +        trans->transfer.stride = r300_texture_get_stride(rscreen, tex, level); +        trans->transfer.usage = usage; +        trans->transfer.zslice = zslice; +        trans->transfer.face = face; + +        trans->offset = offset; +    } +    return &trans->transfer; +} + +static void r300_tex_transfer_destroy(struct pipe_transfer *trans) +{ +   pipe_texture_reference(&trans->texture, NULL); +   FREE(trans); +} + +static void* r300_transfer_map(struct pipe_screen *screen, +                              struct pipe_transfer *transfer) +{ +    struct r300_texture *tex = (struct r300_texture*)transfer->texture; +    char *map; +    enum pipe_format format = tex->tex.format; + +    map = pipe_buffer_map(screen, tex->buffer, +                          pipe_transfer_buffer_flags(transfer)); + +    if (!map) { +        return NULL; +    } + +    return map + r300_transfer(transfer)->offset + +        transfer->y / util_format_get_blockheight(format) * transfer->stride + +        transfer->x / util_format_get_blockwidth(format) * util_format_get_blocksize(format); +} + +static void r300_transfer_unmap(struct pipe_screen *screen, +                                struct pipe_transfer *transfer) +{ +    struct r300_texture *tex = (struct r300_texture*)transfer->texture; +    pipe_buffer_unmap(screen, tex->buffer); +} + +void r300_init_screen_transfer_functions(struct pipe_screen *screen) +{ +    screen->get_tex_transfer = r300_get_tex_transfer; +    screen->tex_transfer_destroy = r300_tex_transfer_destroy; +    screen->transfer_map = r300_transfer_map; +    screen->transfer_unmap = r300_transfer_unmap; +} diff --git a/src/gallium/drivers/r300/r300_transfer.h b/src/gallium/drivers/r300/r300_transfer.h new file mode 100644 index 0000000000..faf62338ef --- /dev/null +++ b/src/gallium/drivers/r300/r300_transfer.h @@ -0,0 +1,60 @@ +/* + * Copyright 2008 Corbin Simpson <MostAwesomeDude@gmail.com> + * Copyright 2010 Marek Olšák <maraeo@gmail.com> + * + * 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 + * on the rights to use, copy, modify, merge, publish, distribute, sub + * license, 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 NON-INFRINGEMENT. IN NO EVENT SHALL + * THE AUTHOR(S) AND/OR THEIR SUPPLIERS 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. */ + +#ifndef R300_TRANSFER +#define R300_TRANSFER + +#include "pipe/p_screen.h" +#include "pipe/p_state.h" + +struct r300_texture; +struct r300_screen; + +struct r300_transfer { +    /* Parent class */ +    struct pipe_transfer transfer; + +    /* Parameters of get_tex_transfer. */ +    unsigned x, y, level, zslice, face; + +    /* Offset from start of buffer. */ +    unsigned offset; + +    /* Untiled texture. */ +    struct r300_texture *untiled_texture; + +    /* Transfer and format flags. */ +    unsigned buffer_usage, render_target_usage; +}; + +/* Convenience cast wrapper. */ +static INLINE struct r300_transfer* +r300_transfer(struct pipe_transfer* transfer) +{ +    return (struct r300_transfer*)transfer; +} + +void r300_init_screen_transfer_functions(struct pipe_screen *screen); + +#endif + | 
