Tizen 2.0 Release
[profile/ivi/osmesa.git] / src / gallium / drivers / cell / ppu / cell_screen.c
1 /**************************************************************************
2  * 
3  * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
4  * All Rights Reserved.
5  * 
6  * Permission is hereby granted, free of charge, to any person obtaining a
7  * copy of this software and associated documentation files (the
8  * "Software"), to deal in the Software without restriction, including
9  * without limitation the rights to use, copy, modify, merge, publish,
10  * distribute, sub license, and/or sell copies of the Software, and to
11  * permit persons to whom the Software is furnished to do so, subject to
12  * the following conditions:
13  * 
14  * The above copyright notice and this permission notice (including the
15  * next paragraph) shall be included in all copies or substantial portions
16  * of the Software.
17  * 
18  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21  * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
22  * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23  * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24  * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25  * 
26  **************************************************************************/
27
28
29 #include "util/u_memory.h"
30 #include "util/u_simple_screen.h"
31 #include "pipe/p_defines.h"
32 #include "pipe/p_screen.h"
33
34 #include "cell/common.h"
35 #include "cell_context.h"
36 #include "cell_screen.h"
37 #include "cell_texture.h"
38 #include "cell_public.h"
39
40 #include "state_tracker/sw_winsys.h"
41
42
43 static const char *
44 cell_get_vendor(struct pipe_screen *screen)
45 {
46    return "VMware, Inc.";
47 }
48
49
50 static const char *
51 cell_get_name(struct pipe_screen *screen)
52 {
53    return "Cell";
54 }
55
56
57 static int
58 cell_get_param(struct pipe_screen *screen, enum pipe_cap param)
59 {
60    switch (param) {
61    case PIPE_CAP_MAX_TEXTURE_IMAGE_UNITS:
62       return CELL_MAX_SAMPLERS;
63    case PIPE_CAP_MAX_COMBINED_SAMPLERS:
64       return CELL_MAX_SAMPLERS;
65    case PIPE_CAP_NPOT_TEXTURES:
66       return 1;
67    case PIPE_CAP_TWO_SIDED_STENCIL:
68       return 1;
69    case PIPE_CAP_GLSL:
70       return 1;
71    case PIPE_CAP_ANISOTROPIC_FILTER:
72       return 0;
73    case PIPE_CAP_POINT_SPRITE:
74       return 1;
75    case PIPE_CAP_MAX_RENDER_TARGETS:
76       return 1;
77    case PIPE_CAP_OCCLUSION_QUERY:
78       return 1;
79    case PIPE_CAP_TIMER_QUERY:
80       return 0;
81    case PIPE_CAP_TEXTURE_SHADOW_MAP:
82       return 10;
83    case PIPE_CAP_MAX_TEXTURE_2D_LEVELS:
84       return CELL_MAX_TEXTURE_LEVELS;
85    case PIPE_CAP_MAX_TEXTURE_3D_LEVELS:
86       return 8;  /* max 128x128x128 */
87    case PIPE_CAP_MAX_TEXTURE_CUBE_LEVELS:
88       return CELL_MAX_TEXTURE_LEVELS;
89    case PIPE_CAP_TEXTURE_MIRROR_REPEAT:
90       return 1; /* XXX not really true */
91    case PIPE_CAP_TEXTURE_MIRROR_CLAMP:
92       return 0; /* XXX to do */
93    case PIPE_CAP_TGSI_FS_COORD_ORIGIN_UPPER_LEFT:
94    case PIPE_CAP_TGSI_FS_COORD_PIXEL_CENTER_HALF_INTEGER:
95       return 1;
96    case PIPE_CAP_TGSI_FS_COORD_ORIGIN_LOWER_LEFT:
97    case PIPE_CAP_TGSI_FS_COORD_PIXEL_CENTER_INTEGER:
98       return 0;
99    case PIPE_CAP_BLEND_EQUATION_SEPARATE:
100       return 1;
101    default:
102       return 0;
103    }
104 }
105
106 static int
107 cell_get_shader_param(struct pipe_screen *screen, unsigned shader, enum pipe_shader_cap param)
108 {
109    switch(shader)
110    {
111    case PIPE_SHADER_FRAGMENT:
112       return tgsi_exec_get_shader_param(param);
113    case PIPE_SHADER_VERTEX:
114    case PIPE_SHADER_GEOMETRY:
115       return draw_get_shader_param(shader, param);
116    default:
117       return 0;
118    }
119 }
120
121 static float
122 cell_get_paramf(struct pipe_screen *screen, enum pipe_cap param)
123 {
124    switch (param) {
125    case PIPE_CAP_MAX_LINE_WIDTH:
126       /* fall-through */
127    case PIPE_CAP_MAX_LINE_WIDTH_AA:
128       return 255.0; /* arbitrary */
129
130    case PIPE_CAP_MAX_POINT_WIDTH:
131       /* fall-through */
132    case PIPE_CAP_MAX_POINT_WIDTH_AA:
133       return 255.0; /* arbitrary */
134
135    case PIPE_CAP_MAX_TEXTURE_ANISOTROPY:
136       return 0.0;
137
138    case PIPE_CAP_MAX_TEXTURE_LOD_BIAS:
139       return 16.0; /* arbitrary */
140
141    default:
142       return 0;
143    }
144 }
145
146
147 static boolean
148 cell_is_format_supported( struct pipe_screen *screen,
149                           enum pipe_format format,
150                           enum pipe_texture_target target,
151                           unsigned sample_count,
152                           unsigned tex_usage)
153 {
154    struct sw_winsys *winsys = cell_screen(screen)->winsys;
155
156    if (sample_count > 1)
157       return FALSE;
158
159    if (tex_usage & (PIPE_BIND_DISPLAY_TARGET |
160                     PIPE_BIND_SCANOUT |
161                     PIPE_BIND_SHARED)) {
162       if (!winsys->is_displaytarget_format_supported(winsys, tex_usage, format))
163          return FALSE;
164    }
165
166    /* only a few formats are known to work at this time */
167    switch (format) {
168    case PIPE_FORMAT_Z24_UNORM_S8_USCALED:
169    case PIPE_FORMAT_Z24X8_UNORM:
170    case PIPE_FORMAT_B8G8R8A8_UNORM:
171    case PIPE_FORMAT_I8_UNORM:
172       return TRUE;
173    default:
174       return FALSE;
175    }
176 }
177
178
179 static void
180 cell_destroy_screen( struct pipe_screen *screen )
181 {
182    struct cell_screen *sp_screen = cell_screen(screen);
183    struct sw_winsys *winsys = sp_screen->winsys;
184
185    if(winsys->destroy)
186       winsys->destroy(winsys);
187
188    FREE(screen);
189 }
190
191
192
193 /**
194  * Create a new pipe_screen object
195  * Note: we're not presently subclassing pipe_screen (no cell_screen) but
196  * that would be the place to put SPU thread/context info...
197  */
198 struct pipe_screen *
199 cell_create_screen(struct sw_winsys *winsys)
200 {
201    struct cell_screen *screen = CALLOC_STRUCT(cell_screen);
202
203    if (!screen)
204       return NULL;
205
206    screen->winsys = winsys;
207    screen->base.winsys = NULL;
208
209    screen->base.destroy = cell_destroy_screen;
210
211    screen->base.get_name = cell_get_name;
212    screen->base.get_vendor = cell_get_vendor;
213    screen->base.get_param = cell_get_param;
214    screen->base.get_shader_param = cell_get_shader_param;
215    screen->base.get_paramf = cell_get_paramf;
216    screen->base.is_format_supported = cell_is_format_supported;
217    screen->base.context_create = cell_create_context;
218
219    cell_init_screen_texture_funcs(&screen->base);
220
221    return &screen->base;
222 }