1 #include "state_tracker/drm_driver.h"
2 #include "target-helpers/inline_debug_helper.h"
3 #include "radeon/drm/radeon_drm_public.h"
4 #include "radeon/radeon_winsys.h"
5 #include "amdgpu/drm/amdgpu_public.h"
6 #include "radeonsi/si_public.h"
7 #include "util/xmlpool.h"
8 
9 static struct pipe_screen *
create_screen(int fd,const struct pipe_screen_config * config)10 create_screen(int fd, const struct pipe_screen_config *config)
11 {
12    struct radeon_winsys *rw;
13 
14    /* First, try amdgpu. */
15    rw = amdgpu_winsys_create(fd, config, radeonsi_screen_create);
16 
17    if (!rw)
18       rw = radeon_drm_winsys_create(fd, config, radeonsi_screen_create);
19 
20    return rw ? debug_screen_wrap(rw->screen) : NULL;
21 }
22 
23 static const struct drm_conf_ret throttle_ret = {
24    .type = DRM_CONF_INT,
25    .val.val_int = 2,
26 };
27 
28 static const struct drm_conf_ret share_fd_ret = {
29    .type = DRM_CONF_BOOL,
30    .val.val_bool = true,
31 };
32 
drm_configuration(enum drm_conf conf)33 static const struct drm_conf_ret *drm_configuration(enum drm_conf conf)
34 {
35    static const struct drm_conf_ret xml_options_ret = {
36       .type = DRM_CONF_POINTER,
37       .val.val_pointer =
38 #include "radeonsi/si_driinfo.h"
39    };
40 
41    switch (conf) {
42    case DRM_CONF_THROTTLE:
43       return &throttle_ret;
44    case DRM_CONF_SHARE_FD:
45       return &share_fd_ret;
46    case DRM_CONF_XML_OPTIONS:
47       return &xml_options_ret;
48    default:
49       break;
50    }
51    return NULL;
52 }
53 
54 PUBLIC
55 DRM_DRIVER_DESCRIPTOR("radeonsi", create_screen, drm_configuration)
56