Subversion Repositories Kolibri OS

Rev

Blame | Last modification | View Log | RSS feed

  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.