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:
Thomas Hellstrom 2011-10-12 10:29:24 +02:00
parent 5a6ca7e9f2
commit ec7d5b8c02
27 changed files with 72 additions and 27 deletions

View file

@ -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

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -24,4 +24,4 @@ create_screen(int fd)
}
PUBLIC
DRM_DRIVER_DESCRIPTOR("i915", "i915", create_screen)
DRM_DRIVER_DESCRIPTOR("i915", "i915", create_screen, NULL)

View file

@ -27,4 +27,4 @@ create_screen(int fd)
}
PUBLIC
DRM_DRIVER_DESCRIPTOR("i965", "i965", create_screen)
DRM_DRIVER_DESCRIPTOR("i965", "i965", create_screen, NULL)

View file

@ -18,4 +18,4 @@ create_screen(int fd)
}
PUBLIC
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen)
DRM_DRIVER_DESCRIPTOR("nouveau", "nouveau", create_screen, NULL)

View file

@ -24,4 +24,4 @@ create_screen(int fd)
}
PUBLIC
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen)
DRM_DRIVER_DESCRIPTOR("r300", "radeon", create_screen, NULL)

View file

@ -23,4 +23,4 @@ create_screen(int fd)
}
PUBLIC
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen)
DRM_DRIVER_DESCRIPTOR("r600", "radeon", create_screen, NULL)

View file

@ -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)

View file

@ -24,4 +24,4 @@ create_screen(int fd)
}
PUBLIC
DRM_DRIVER_DESCRIPTOR("vmwgfx", "vmwgfx", create_screen)
DRM_DRIVER_DESCRIPTOR("vmwgfx", "vmwgfx", create_screen, NULL)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)

View file

@ -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)