• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2017 Rob Clark <robclark@freedesktop.org>
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice (including the next
12  * paragraph) shall be included in all copies or substantial portions of the
13  * Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21  * SOFTWARE.
22  *
23  * Authors:
24  *    Rob Clark <robclark@freedesktop.org>
25  */
26 
27 #ifndef FREEDRENO_BLIT_H_
28 #define FREEDRENO_BLIT_H_
29 
30 #include "pipe/p_state.h"
31 #include "util/u_dump.h"
32 
33 #include "freedreno_context.h"
34 
35 BEGINC;
36 
37 bool fd_blitter_blit(struct fd_context *ctx,
38                      const struct pipe_blit_info *info) assert_dt;
39 
40 void fd_blitter_clear(struct pipe_context *pctx, unsigned buffers,
41                       const union pipe_color_union *color, double depth,
42                       unsigned stencil) assert_dt;
43 
44 void fd_blitter_clear_render_target(struct pipe_context *pctx, struct pipe_surface *ps,
45                                     const union pipe_color_union *color, unsigned x,
46                                     unsigned y, unsigned w, unsigned h,
47                                     bool render_condition_enabled) assert_dt;
48 
49 void fd_blitter_clear_depth_stencil(struct pipe_context *pctx, struct pipe_surface *ps,
50                                     unsigned buffers, double depth, unsigned stencil,
51                                     unsigned x, unsigned y, unsigned w, unsigned h,
52                                     bool render_condition_enabled) assert_dt;
53 
54 void fd_resource_copy_region(struct pipe_context *pctx,
55                              struct pipe_resource *dst, unsigned dst_level,
56                              unsigned dstx, unsigned dsty, unsigned dstz,
57                              struct pipe_resource *src, unsigned src_level,
58                              const struct pipe_box *src_box) assert_dt;
59 
60 bool fd_blit(struct pipe_context *pctx,
61              const struct pipe_blit_info *blit_info) assert_dt;
62 
63 #define DBG_BLIT(blit, batch) do { \
64    if (FD_DBG(MSGS)) { \
65       const struct fd_resource *src = fd_resource((blit)->src.resource); \
66       const struct fd_resource *dst = fd_resource((blit)->dst.resource); \
67       const char *src_target = util_str_tex_target((blit)->src.resource->target, true); \
68       const char *dst_target = util_str_tex_target((blit)->dst.resource->target, true); \
69       const char *src_format = util_format_short_name((blit)->src.format); \
70       const char *dst_format = util_format_short_name((blit)->dst.format); \
71       const char *src_tiling = fd_resource_tile_mode_desc(src, (blit)->src.level); \
72       const char *dst_tiling = fd_resource_tile_mode_desc(dst, (blit)->dst.level); \
73       if (batch) { \
74          DBG("%p: %s %s %s (%p) -> %s %s %s (%p)", (batch), \
75             src_target, src_format, src_tiling, src, \
76             dst_target, dst_format, dst_tiling, dst); \
77       } else { \
78          DBG("%s %s %s (%p) -> %s %s %s (%p)", \
79             src_target, src_format, src_tiling, src, \
80             dst_target, dst_format, dst_tiling, dst); \
81       } \
82    } \
83 } while (0)
84 
85 ENDC;
86 
87 #endif /* FREEDRENO_BLIT_H_ */
88