2017-09-23 10:26:01 +02:00
|
|
|
#ifndef BACKEND_DRM_UTIL_H
|
|
|
|
#define BACKEND_DRM_UTIL_H
|
2017-08-05 07:56:22 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
2018-02-12 21:29:23 +01:00
|
|
|
#include <wlr/types/wlr_output.h>
|
2017-08-05 07:56:22 +02:00
|
|
|
#include <xf86drm.h>
|
|
|
|
#include <xf86drmMode.h>
|
|
|
|
|
|
|
|
// Calculates a more accurate refresh rate (mHz) than what mode itself provides
|
2018-12-16 11:06:46 +01:00
|
|
|
int32_t calculate_refresh_rate(const drmModeModeInfo *mode);
|
2017-08-05 07:56:22 +02:00
|
|
|
// Populates the make/model/phys_{width,height} of output from the edid data
|
2018-04-26 00:24:58 +02:00
|
|
|
void parse_edid(struct wlr_output *restrict output, size_t len,
|
|
|
|
const uint8_t *data);
|
2017-08-05 07:56:22 +02:00
|
|
|
// Returns the string representation of a DRM output type
|
|
|
|
const char *conn_get_name(uint32_t type_id);
|
2017-08-09 10:43:01 +02:00
|
|
|
// Returns the DRM framebuffer id for a gbm_bo
|
2020-02-08 07:02:31 +01:00
|
|
|
uint32_t get_fb_for_bo(struct gbm_bo *bo, bool with_modifiers);
|
2017-08-05 07:56:22 +02:00
|
|
|
|
|
|
|
// Part of match_obj
|
|
|
|
enum {
|
|
|
|
UNMATCHED = (uint32_t)-1,
|
|
|
|
SKIP = (uint32_t)-2,
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Tries to match some DRM objects with some other DRM resource.
|
|
|
|
* e.g. Match CRTCs with Encoders, CRTCs with Planes.
|
|
|
|
*
|
|
|
|
* objs contains a bit array which resources it can be matched with.
|
|
|
|
* e.g. Bit 0 set means can be matched with res[0]
|
|
|
|
*
|
|
|
|
* res contains an index of which objs it is matched with or UNMATCHED.
|
|
|
|
*
|
|
|
|
* This solution is left in out.
|
|
|
|
* Returns the total number of matched solutions.
|
|
|
|
*/
|
|
|
|
size_t match_obj(size_t num_objs, const uint32_t objs[static restrict num_objs],
|
|
|
|
size_t num_res, const uint32_t res[static restrict num_res],
|
|
|
|
uint32_t out[static restrict num_res]);
|
2018-04-26 00:24:58 +02:00
|
|
|
|
2017-08-05 07:56:22 +02:00
|
|
|
#endif
|