2022-04-10 11:29:06 +02:00
|
|
|
#include <inttypes.h>
|
|
|
|
#include <stdio.h>
|
2022-04-10 11:07:42 +02:00
|
|
|
#include <stdlib.h>
|
2022-04-10 11:29:06 +02:00
|
|
|
#include <string.h>
|
2022-04-10 11:07:42 +02:00
|
|
|
|
|
|
|
#include "edid.h"
|
|
|
|
#include "info.h"
|
|
|
|
|
|
|
|
struct di_info *
|
|
|
|
di_info_parse_edid(const void *data, size_t size)
|
|
|
|
{
|
|
|
|
struct di_edid *edid;
|
|
|
|
struct di_info *info;
|
|
|
|
|
|
|
|
edid = di_edid_parse(data, size);
|
|
|
|
if (!edid)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
info = calloc(1, sizeof(*info));
|
|
|
|
if (!info) {
|
|
|
|
di_edid_destroy(edid);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
info->edid = edid;
|
|
|
|
|
|
|
|
return info;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
di_info_destroy(struct di_info *info)
|
|
|
|
{
|
|
|
|
di_edid_destroy(info->edid);
|
|
|
|
free(info);
|
|
|
|
}
|
2022-05-03 12:04:11 +02:00
|
|
|
|
|
|
|
const struct di_edid *
|
|
|
|
di_info_get_edid(const struct di_info *info)
|
|
|
|
{
|
|
|
|
return info->edid;
|
|
|
|
}
|
2022-04-10 11:29:06 +02:00
|
|
|
|
|
|
|
char *
|
|
|
|
di_info_get_product_name(const struct di_info *info)
|
|
|
|
{
|
2022-06-10 19:28:01 +02:00
|
|
|
char name[256], product_code[32], serial_code[32];
|
|
|
|
const char *product, *serial;
|
2022-04-10 11:29:06 +02:00
|
|
|
const struct di_edid_vendor_product *edid_vendor_product;
|
2022-06-10 19:28:01 +02:00
|
|
|
const struct di_edid_display_descriptor *const *display_descs;
|
|
|
|
size_t i;
|
2022-04-10 11:29:06 +02:00
|
|
|
|
|
|
|
edid_vendor_product = di_edid_get_vendor_product(info->edid);
|
|
|
|
|
2022-06-10 19:28:01 +02:00
|
|
|
snprintf(product_code, sizeof(product_code), "0x%X" PRIu16,
|
|
|
|
edid_vendor_product->product);
|
2022-06-10 19:15:13 +02:00
|
|
|
if (edid_vendor_product->serial != 0) {
|
2022-06-10 19:28:01 +02:00
|
|
|
snprintf(serial_code, sizeof(serial), " 0x%X" PRIu32,
|
2022-06-10 19:15:13 +02:00
|
|
|
edid_vendor_product->serial);
|
|
|
|
} else {
|
2022-06-10 19:28:01 +02:00
|
|
|
serial_code[0] = '\0';
|
2022-06-10 19:15:13 +02:00
|
|
|
}
|
|
|
|
|
2022-06-10 19:28:01 +02:00
|
|
|
product = product_code;
|
|
|
|
serial = serial_code;
|
|
|
|
display_descs = di_edid_get_display_descriptors(info->edid);
|
|
|
|
for (i = 0; display_descs[i] != NULL; i++) {
|
|
|
|
const struct di_edid_display_descriptor *desc = display_descs[i];
|
|
|
|
switch (di_edid_display_descriptor_get_tag(desc)) {
|
|
|
|
case DI_EDID_DISPLAY_DESCRIPTOR_PRODUCT_SERIAL:
|
|
|
|
serial = di_edid_display_descriptor_get_string(desc);
|
|
|
|
break;
|
|
|
|
case DI_EDID_DISPLAY_DESCRIPTOR_PRODUCT_NAME:
|
|
|
|
product = di_edid_display_descriptor_get_string(desc);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break; /* Ignore */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
snprintf(name, sizeof(name), "%.3s %s%s",
|
|
|
|
edid_vendor_product->manufacturer, product, serial);
|
2022-04-10 11:29:06 +02:00
|
|
|
|
|
|
|
return strdup(name);
|
|
|
|
}
|