1f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/*
2f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Copyright 2008 Corbin Simpson <MostAwesomeDude@gmail.com>
3f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Copyright 2010 Marek Olšák <maraeo@gmail.com>
4f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org *
5f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Permission is hereby granted, free of charge, to any person obtaining a
6f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * copy of this software and associated documentation files (the "Software"),
7f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * to deal in the Software without restriction, including without limitation
8f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * on the rights to use, copy, modify, merge, publish, distribute, sub
9f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * license, and/or sell copies of the Software, and to permit persons to whom
10f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * the Software is furnished to do so, subject to the following conditions:
11f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org *
12f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * The above copyright notice and this permission notice (including the next
13f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * paragraph) shall be included in all copies or substantial portions of the
14f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Software.
15f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org *
16f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
19f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM,
20f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
21f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
22f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * USE OR OTHER DEALINGS IN THE SOFTWARE. */
23f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
24f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#ifndef R300_SCREEN_H
25f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define R300_SCREEN_H
26f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
27f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "r300_chipset.h"
28f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "../../winsys/radeon/drm/radeon_winsys.h"
29f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "pipe/p_screen.h"
30f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "util/u_slab.h"
31f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include <stdio.h>
32f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
33f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstruct r300_screen {
34f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    /* Parent class */
35f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    struct pipe_screen screen;
36f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
37f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    struct radeon_winsys *rws;
38f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
39f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    /* Chipset info and capabilities. */
40f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    struct radeon_info info;
41f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    struct r300_capabilities caps;
42f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
43f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    /** Combination of DBG_xxx flags */
44f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    unsigned debug;
45f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org};
46f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
47f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
48f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* Convenience cast wrappers. */
49f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic INLINE struct r300_screen* r300_screen(struct pipe_screen* screen) {
50f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    return (struct r300_screen*)screen;
51f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org}
52f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
53f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic INLINE struct radeon_winsys *
54f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgradeon_winsys(struct pipe_screen *screen) {
55f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    return r300_screen(screen)->rws;
56f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org}
57f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
58f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* Debug functionality. */
59f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
60f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/**
61f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Debug flags to disable/enable certain groups of debugging outputs.
62f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org *
63f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * \note These may be rather coarse, and the grouping may be impractical.
64f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * If you find, while debugging the driver, that a different grouping
65f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * of these flags would be beneficial, just feel free to change them
66f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * but make sure to update the documentation in r300_debug.c to reflect
67f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * those changes.
68f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org */
69f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/*@{*/
70f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
71f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* Logging. */
72f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_PSC         (1 << 0)
73f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_FP          (1 << 1)
74f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_VP          (1 << 2)
75f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_SWTCL       (1 << 3)
76f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_DRAW        (1 << 4)
77f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_TEX         (1 << 5)
78f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_TEXALLOC    (1 << 6)
79f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_RS          (1 << 7)
80f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_FB          (1 << 8)
81f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_RS_BLOCK    (1 << 9)
82f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_CBZB        (1 << 10)
83f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_HYPERZ      (1 << 11)
84f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_SCISSOR     (1 << 12)
85f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_INFO        (1 << 13)
86f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* Features. */
87f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_ANISOHQ     (1 << 16)
88f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_NO_TILING   (1 << 17)
89f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_NO_IMMD     (1 << 18)
90f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_NO_OPT      (1 << 19)
91f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_NO_CBZB     (1 << 20)
92f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_NO_ZMASK    (1 << 21)
93f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_NO_HIZ      (1 << 22)
94f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* Statistics. */
95f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#define DBG_P_STAT      (1 << 25)
96f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/*@}*/
97f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
98f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic INLINE boolean SCREEN_DBG_ON(struct r300_screen * screen, unsigned flags)
99f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{
100f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    return (screen->debug & flags) ? TRUE : FALSE;
101f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org}
102f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
103f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic INLINE void SCREEN_DBG(struct r300_screen * screen, unsigned flags,
104f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org                              const char * fmt, ...)
105f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{
106f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    if (SCREEN_DBG_ON(screen, flags)) {
107f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org        va_list va;
108f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org        va_start(va, fmt);
109f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org        vfprintf(stderr, fmt, va);
110f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org        va_end(va);
111f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org    }
112f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org}
113f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
114f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgvoid r300_init_debug(struct r300_screen* ctx);
115f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
116f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgvoid r300_init_screen_resource_functions(struct r300_screen *r300screen);
117f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org
118f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#endif /* R300_SCREEN_H */
119