mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-01-08 10:40:11 +01:00
drm_driver: Add a configuration function to the driver descriptor.
Adds a possibility for the state tracker manager to query the target for a specific configuration. Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com> Reviewed-by: Jakob Bornecrantz <jakob@vmware.com>
This commit is contained in:
parent
5a6ca7e9f2
commit
ec7d5b8c02
27 changed files with 72 additions and 27 deletions
|
|
@ -35,6 +35,40 @@ struct winsys_handle
|
|||
unsigned stride;
|
||||
};
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Configuration queries.
|
||||
*/
|
||||
enum drm_conf {
|
||||
/* How many frames to allow before throttling. Or -1 to indicate any number */
|
||||
DRM_CONF_THROTTLE, /* DRM_CONF_INT. */
|
||||
DRM_CONF_MAX
|
||||
};
|
||||
|
||||
/**
|
||||
* Type of configuration answer
|
||||
*/
|
||||
enum drm_conf_type {
|
||||
DRM_CONF_INT,
|
||||
DRM_CONF_BOOL,
|
||||
DRM_CONF_FLOAT,
|
||||
DRM_CONF_POINTER
|
||||
};
|
||||
|
||||
/**
|
||||
* Return value from the configuration function.
|
||||
*/
|
||||
struct drm_conf_ret {
|
||||
enum drm_conf_type type;
|
||||
union {
|
||||
int val_int;
|
||||
bool val_bool;
|
||||
float val_float;
|
||||
void *val_pointer;
|
||||
} val;
|
||||
};
|
||||
|
||||
struct drm_driver_descriptor
|
||||
{
|
||||
/**
|
||||
|
|
@ -54,6 +88,16 @@ struct drm_driver_descriptor
|
|||
* For example wrapping trace or rbug debugging drivers around it.
|
||||
*/
|
||||
struct pipe_screen* (*create_screen)(int drm_fd);
|
||||
|
||||
|
||||
/**
|
||||
* Return a configuration value.
|
||||
*
|
||||
* If this function is NULL, or if it returns NULL
|
||||
* the state tracker- or state
|
||||
* tracker manager should provide a reasonable default value.
|
||||
*/
|
||||
const struct drm_conf_ret *(*configuration) (enum drm_conf conf);
|
||||
};
|
||||
|
||||
extern struct drm_driver_descriptor driver_descriptor;
|
||||
|
|
@ -61,11 +105,12 @@ extern struct drm_driver_descriptor driver_descriptor;
|
|||
/**
|
||||
* Instantiate a drm_driver_descriptor struct.
|
||||
*/
|
||||
#define DRM_DRIVER_DESCRIPTOR(name_str, driver_name_str, func) \
|
||||
#define DRM_DRIVER_DESCRIPTOR(name_str, driver_name_str, func, conf) \
|
||||
struct drm_driver_descriptor driver_descriptor = { \
|
||||
.name = name_str, \
|
||||
.driver_name = driver_name_str, \
|
||||
.create_screen = func, \
|
||||
.configuration = (conf), \
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -26,4 +26,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i915", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i915", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -26,4 +26,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i965", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i965", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -17,4 +17,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -22,4 +22,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -21,4 +21,4 @@ static struct pipe_screen *create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -27,4 +27,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("vmwgfx", "vmwgfx", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("vmwgfx", "vmwgfx", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -24,4 +24,4 @@ create_screen(int fd)
|
|||
}
|
||||
|
||||
PUBLIC
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i915", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i915", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -27,4 +27,4 @@ create_screen(int fd)
|
|||
}
|
||||
|
||||
PUBLIC
|
||||
DRM_DRIVER_DESCRIPTOR("i965", "i965", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("i965", "i965", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -18,4 +18,4 @@ create_screen(int fd)
|
|||
}
|
||||
|
||||
PUBLIC
|
||||
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -24,4 +24,4 @@ create_screen(int fd)
|
|||
}
|
||||
|
||||
PUBLIC
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -23,4 +23,4 @@ create_screen(int fd)
|
|||
}
|
||||
|
||||
PUBLIC
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -7,7 +7,7 @@ PUBLIC struct pipe_screen *
|
|||
swrast_create_screen(struct sw_winsys *ws);
|
||||
|
||||
PUBLIC
|
||||
DRM_DRIVER_DESCRIPTOR("swrast", NULL, NULL)
|
||||
DRM_DRIVER_DESCRIPTOR("swrast", NULL, NULL, NULL)
|
||||
|
||||
struct pipe_screen *
|
||||
swrast_create_screen(struct sw_winsys *ws)
|
||||
|
|
|
|||
|
|
@ -24,4 +24,4 @@ create_screen(int fd)
|
|||
}
|
||||
|
||||
PUBLIC
|
||||
DRM_DRIVER_DESCRIPTOR("vmwgfx", "vmwgfx", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("vmwgfx", "vmwgfx", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -21,4 +21,4 @@ static struct pipe_screen *create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -21,4 +21,4 @@ static struct pipe_screen *create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -21,4 +21,4 @@ static struct pipe_screen *create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -21,4 +21,4 @@ static struct pipe_screen *create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -23,4 +23,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("vmwgfx", "vmwgfx", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("vmwgfx", "vmwgfx", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -23,4 +23,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i915", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i915", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -26,4 +26,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i965", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("i915", "i965", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -17,4 +17,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -23,4 +23,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -23,4 +23,4 @@ create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -15,4 +15,4 @@ static struct pipe_screen *create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -21,4 +21,4 @@ static struct pipe_screen *create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
|
|
@ -21,4 +21,4 @@ static struct pipe_screen *create_screen(int fd)
|
|||
return screen;
|
||||
}
|
||||
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen)
|
||||
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen, NULL)
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue