1f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* 2f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Mesa 3-D graphics library 3f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Version: 7.10 4f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * 5f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Copyright (C) 2011 LunarG Inc. 6f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * 7f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Permission is hereby granted, free of charge, to any person obtaining a 8f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * copy of this software and associated documentation files (the "Software"), 9f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * to deal in the Software without restriction, including without limitation 10f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * the rights to use, copy, modify, merge, publish, distribute, sublicense, 11f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * and/or sell copies of the Software, and to permit persons to whom the 12f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Software is furnished to do so, subject to the following conditions: 13f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * 14f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * The above copyright notice and this permission notice shall be included 15f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * in all copies or substantial portions of the Software. 16f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * 17f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 18f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 19f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 20f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 21f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 22f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 23f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * DEALINGS IN THE SOFTWARE. 24f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * 25f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Authors: 26f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org * Chia-I Wu <olv@lunarg.com> 27f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org */ 28f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "target-helpers/inline_debug_helper.h" 29f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "target-helpers/inline_sw_helper.h" 30f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "egl_pipe.h" 31f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 32f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* for i915 */ 33f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "i915/drm/i915_drm_public.h" 34f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "i915/i915_public.h" 35f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "target-helpers/inline_wrapper_sw_helper.h" 36f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* for nouveau */ 37f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "nouveau/drm/nouveau_drm_public.h" 38f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* for r300 */ 39f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "radeon/drm/radeon_drm_public.h" 40f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "r300/r300_public.h" 41f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* for r600 */ 42f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "r600/r600_public.h" 43f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* for radeonsi */ 44f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "radeonsi/radeonsi_public.h" 45f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org/* for vmwgfx */ 46f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "svga/drm/svga_drm_public.h" 47f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#include "svga/svga_public.h" 48f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 49f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic struct pipe_screen * 50f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgpipe_i915_create_screen(int fd) 51f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{ 52f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#if _EGL_PIPE_I915 53f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct i915_winsys *iws; 54f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct pipe_screen *screen; 55f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 56f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org iws = i915_drm_winsys_create(fd); 57f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!iws) 58f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 59f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 60f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = i915_screen_create(iws); 61f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!screen) 62f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 63f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 64f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = debug_screen_wrap(screen); 65f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 66f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return screen; 67f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#else 68f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 69f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#endif 70f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org} 71f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 72f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic struct pipe_screen * 73f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgpipe_nouveau_create_screen(int fd) 74f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{ 75f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#if _EGL_PIPE_NOUVEAU 76f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct pipe_screen *screen; 77f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 78f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = nouveau_drm_screen_create(fd); 79f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!screen) 80f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 81f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 82f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = debug_screen_wrap(screen); 83f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 84f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return screen; 85f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#else 86f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 87f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#endif 88f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org} 89f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 90f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic struct pipe_screen * 91f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgpipe_r300_create_screen(int fd) 92f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{ 93f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#if _EGL_PIPE_R300 94f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct radeon_winsys *sws; 95f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct pipe_screen *screen; 96f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 97f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org sws = radeon_drm_winsys_create(fd); 98f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!sws) 99f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 100f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 101f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = r300_screen_create(sws); 102f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!screen) 103f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 104f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 105f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = debug_screen_wrap(screen); 106f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 107f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return screen; 108f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#else 109f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 110f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#endif 111f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org} 112f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 113f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic struct pipe_screen * 114f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgpipe_r600_create_screen(int fd) 115f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{ 116f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#if _EGL_PIPE_R600 117f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct radeon_winsys *rw; 118f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct pipe_screen *screen; 119f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 120f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org rw = radeon_drm_winsys_create(fd); 121f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!rw) 122f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 123f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 124f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = r600_screen_create(rw); 125f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!screen) 126f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 127f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 128f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = debug_screen_wrap(screen); 129f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 130f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return screen; 131f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#else 132f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 133f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#endif 134f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org} 135f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 136f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic struct pipe_screen * 137f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgpipe_radeonsi_create_screen(int fd) 138f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{ 139f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#if _EGL_PIPE_RADEONSI 140f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct radeon_winsys *rw; 141f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct pipe_screen *screen; 142f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 143f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org rw = radeon_drm_winsys_create(fd); 144f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!rw) 145f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 146f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 147f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = radeonsi_screen_create(rw); 148f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!screen) 149f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 150f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 151f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = debug_screen_wrap(screen); 152f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 153f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return screen; 154f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#else 155f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 156f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#endif 157f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org} 158f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 159f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstatic struct pipe_screen * 160f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgpipe_vmwgfx_create_screen(int fd) 161f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{ 162f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#if _EGL_PIPE_VMWGFX 163f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct svga_winsys_screen *sws; 164f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct pipe_screen *screen; 165f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 166f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org sws = svga_drm_winsys_screen_create(fd); 167f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!sws) 168f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 169f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 170f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = svga_screen_create(sws); 171f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (!screen) 172f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 173f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 174f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = debug_screen_wrap(screen); 175f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 176f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return screen; 177f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#else 178f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 179f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org#endif 180f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org} 181f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 182f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstruct pipe_screen * 183f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgegl_pipe_create_drm_screen(const char *name, int fd) 184f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{ 185f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (strcmp(name, "i915") == 0) 186f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return pipe_i915_create_screen(fd); 187f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org else if (strcmp(name, "nouveau") == 0) 188f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return pipe_nouveau_create_screen(fd); 189f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org else if (strcmp(name, "r300") == 0) 190f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return pipe_r300_create_screen(fd); 191f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org else if (strcmp(name, "r600") == 0) 192f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return pipe_r600_create_screen(fd); 193f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org else if (strcmp(name, "radeonsi") == 0) 194f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return pipe_radeonsi_create_screen(fd); 195f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org else if (strcmp(name, "vmwgfx") == 0) 196f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return pipe_vmwgfx_create_screen(fd); 197f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org else 198f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return NULL; 199f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org} 200f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 201f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgstruct pipe_screen * 202f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.orgegl_pipe_create_swrast_screen(struct sw_winsys *ws) 203f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org{ 204f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org struct pipe_screen *screen; 205f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 206f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = sw_screen_create(ws); 207f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org if (screen) 208f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org screen = debug_screen_wrap(screen); 209f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org 210f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org return screen; 211f2ba7591b1407a7ee9209f842c50696914dc2dedkbr@chromium.org} 212