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>
|
|
|
|
#include <xf86drm.h>
|
|
|
|
#include <xf86drmMode.h>
|
|
|
|
|
2022-05-06 11:58:17 +02:00
|
|
|
struct wlr_drm_connector;
|
|
|
|
|
2017-08-05 07:56:22 +02:00
|
|
|
// 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
|
2022-05-06 11:58:17 +02:00
|
|
|
void parse_edid(struct wlr_drm_connector *conn, size_t len, const uint8_t *data);
|
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
|