1 /* 2 * Copyright (c) 2007 Intel Corporation. All Rights Reserved. 3 * 4 * Permission is hereby granted, free of charge, to any person obtaining a 5 * copy of this software and associated documentation files (the 6 * "Software"), to deal in the Software without restriction, including 7 * without limitation the rights to use, copy, modify, merge, publish, 8 * distribute, sub license, and/or sell copies of the Software, and to 9 * permit persons to whom the Software is furnished to do so, subject to 10 * the following conditions: 11 * 12 * The above copyright notice and this permission notice (including the 13 * next paragraph) shall be included in all copies or substantial portions 14 * of the Software. 15 * 16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 17 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. 19 * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR 20 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 21 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 22 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 23 */ 24 25 #define TEST_DESCRIPTION "Create/destroy contexts for all profiles / entrypoints" 26 27 #include "test_common.c" 28 29 void pre() 30 { 31 test_init(); 32 test_profiles(); 33 } 34 35 void test() 36 { 37 int max_entrypoints; 38 int num_entrypoints; 39 int i, j, k; 40 int config_count = 0; 41 max_entrypoints = vaMaxNumEntrypoints(va_dpy); 42 ASSERT(max_entrypoints > 0); 43 VAEntrypoint *entrypoints = malloc(max_entrypoints * sizeof(VAEntrypoint)); 44 ASSERT(entrypoints); 45 46 VAConfigID *configs = malloc(max_entrypoints * num_profiles * sizeof(VAConfigID)); 47 VAContextID *contexts = malloc(max_entrypoints * num_profiles * sizeof(VAContextID)); 48 49 for(i = 0; i < num_profiles; i++) 50 { 51 va_status = vaQueryConfigEntrypoints(va_dpy, profiles[i], entrypoints, &num_entrypoints); 52 ASSERT( VA_STATUS_SUCCESS == va_status ); 53 54 for(j = 0; j < num_entrypoints; j++) 55 { 56 status("vaCreateConfig for %s, %s\n", profile2string(profiles[i]), entrypoint2string(entrypoints[j])); 57 va_status = vaCreateConfig(va_dpy, profiles[i], entrypoints[j], NULL, 0, &(configs[config_count])); 58 ASSERT( VA_STATUS_SUCCESS == va_status ); 59 status("vaCreateConfig returns %08x\n", configs[config_count]); 60 config_count++; 61 } 62 } 63 64 int width = 352; 65 int height = 288; 66 int surface_count = 4; 67 int total_surfaces = config_count * surface_count; 68 69 VASurfaceID *surfaces = malloc(total_surfaces * sizeof(VASurfaceID)); 70 71 // TODO: Don't assume VA_RT_FORMAT_YUV420 is supported / needed for each config 72 va_status = vaCreateSurfaces(va_dpy, VA_RT_FORMAT_YUV420, width, height, surfaces, total_surfaces, NULL, 0); 73 ASSERT( VA_STATUS_SUCCESS == va_status ); 74 75 for(i = 0; i < config_count; i++) 76 { 77 status("vaCreateContext with config %08x\n", configs[i]); 78 int flags = 0; 79 va_status = vaCreateContext( va_dpy, configs[i], width, height, flags, surfaces + i*surface_count, surface_count, &contexts[i] ); 80 ASSERT( VA_STATUS_SUCCESS == va_status ); 81 } 82 83 for(i = 0; i < config_count; i++) 84 { 85 status("vaDestroyContext for context %08x\n", contexts[i]); 86 va_status = vaDestroyContext( va_dpy, contexts[i] ); 87 ASSERT( VA_STATUS_SUCCESS == va_status ); 88 } 89 90 for(i = 0; i < config_count; i++) 91 { 92 status("vaDestroyConfig for config %08x\n", configs[i]); 93 va_status = vaDestroyConfig( va_dpy, configs[i] ); 94 ASSERT( VA_STATUS_SUCCESS == va_status ); 95 } 96 97 va_status = vaDestroySurfaces(va_dpy, surfaces, total_surfaces); 98 ASSERT( VA_STATUS_SUCCESS == va_status ); 99 100 free(contexts); 101 free(configs); 102 free(surfaces); 103 free(entrypoints); 104 } 105 106 void post() 107 { 108 test_terminate(); 109 } 110