summaryrefslogtreecommitdiff
path: root/tests/modetest
diff options
context:
space:
mode:
Diffstat (limited to 'tests/modetest')
-rw-r--r--tests/modetest/modetest.c94
1 files changed, 82 insertions, 12 deletions
diff --git a/tests/modetest/modetest.c b/tests/modetest/modetest.c
index 4eb9eac8..64bee1d6 100644
--- a/tests/modetest/modetest.c
+++ b/tests/modetest/modetest.c
@@ -77,6 +77,7 @@ struct connector {
drmModeConnector *connector;
drmModeObjectProperties *props;
drmModePropertyRes **props_info;
+ char *name;
};
struct fb {
@@ -372,18 +373,18 @@ static void dump_connectors(struct device *dev)
int i, j;
printf("Connectors:\n");
- printf("id\tencoder\tstatus\t\ttype\tsize (mm)\tmodes\tencoders\n");
+ printf("id\tencoder\tstatus\t\tname\t\tsize (mm)\tmodes\tencoders\n");
for (i = 0; i < dev->resources->res->count_connectors; i++) {
struct connector *_connector = &dev->resources->connectors[i];
drmModeConnector *connector = _connector->connector;
if (!connector)
continue;
- printf("%d\t%d\t%s\t%s\t%dx%d\t\t%d\t",
+ printf("%d\t%d\t%s\t%-15s\t%dx%d\t\t%d\t",
connector->connector_id,
connector->encoder_id,
connector_status_str(connector->connection),
- connector_type_str(connector->connector_type),
+ _connector->name,
connector->mmWidth, connector->mmHeight,
connector->count_modes);
@@ -509,12 +510,13 @@ static void dump_planes(struct device *dev)
static void free_resources(struct resources *res)
{
+ int i;
+
if (!res)
return;
#define free_resource(_res, __res, type, Type) \
do { \
- int i; \
if (!(_res)->type##s) \
break; \
for (i = 0; i < (int)(_res)->__res->count_##type##s; ++i) { \
@@ -527,7 +529,6 @@ static void free_resources(struct resources *res)
#define free_properties(_res, __res, type) \
do { \
- int i; \
for (i = 0; i < (int)(_res)->__res->count_##type##s; ++i) { \
drmModeFreeObjectProperties(res->type##s[i].props); \
free(res->type##s[i].props_info); \
@@ -539,6 +540,10 @@ static void free_resources(struct resources *res)
free_resource(res, res, crtc, Crtc);
free_resource(res, res, encoder, Encoder);
+
+ for (i = 0; i < res->res->count_connectors; i++)
+ free(res->connectors[i].name);
+
free_resource(res, res, connector, Connector);
free_resource(res, res, fb, FB);
@@ -600,6 +605,15 @@ static struct resources *get_resources(struct device *dev)
get_resource(res, res, connector, Connector);
get_resource(res, res, fb, FB);
+ /* Set the name of all connectors based on the type name and the per-type ID. */
+ for (i = 0; i < res->res->count_connectors; i++) {
+ struct connector *connector = &res->connectors[i];
+
+ asprintf(&connector->name, "%s-%u",
+ connector_type_str(connector->connector->connector_type),
+ connector->connector->connector_type_id);
+ }
+
#define get_properties(_res, __res, type, Type) \
do { \
int i; \
@@ -666,6 +680,21 @@ static int get_crtc_index(struct device *dev, uint32_t id)
return -1;
}
+static drmModeConnector *get_connector_by_name(struct device *dev, const char *name)
+{
+ struct connector *connector;
+ int i;
+
+ for (i = 0; i < dev->resources->res->count_connectors; i++) {
+ connector = &dev->resources->connectors[i];
+
+ if (strcmp(connector->name, name) == 0)
+ return connector->connector;
+ }
+
+ return NULL;
+}
+
static drmModeConnector *get_connector_by_id(struct device *dev, uint32_t id)
{
drmModeConnector *connector;
@@ -706,6 +735,7 @@ static drmModeEncoder *get_encoder_by_id(struct device *dev, uint32_t id)
* can bind it with a free crtc.
*/
struct pipe_arg {
+ const char **cons;
uint32_t *con_ids;
unsigned int num_cons;
uint32_t crtc_id;
@@ -821,8 +851,8 @@ static int pipe_find_crtc_and_mode(struct device *dev, struct pipe_arg *pipe)
pipe->mode_str, pipe->vrefresh);
if (mode == NULL) {
fprintf(stderr,
- "failed to find mode \"%s\" for connector %u\n",
- pipe->mode_str, pipe->con_ids[i]);
+ "failed to find mode \"%s\" for connector %s\n",
+ pipe->mode_str, pipe->cons[i]);
return -EINVAL;
}
}
@@ -1122,7 +1152,7 @@ static void set_mode(struct device *dev, struct pipe_arg *pipes, unsigned int co
printf("setting mode %s-%dHz@%s on connectors ",
pipe->mode_str, pipe->mode->vrefresh, pipe->format_str);
for (j = 0; j < pipe->num_cons; ++j)
- printf("%u, ", pipe->con_ids[j]);
+ printf("%s, ", pipe->cons[j]);
printf("crtc %d\n", pipe->crtc->crtc->crtc_id);
ret = drmModeSetCrtc(dev->fd, pipe->crtc->crtc->crtc_id, fb_id,
@@ -1311,18 +1341,24 @@ static int parse_connector(struct pipe_arg *pipe, const char *arg)
/* Count the number of connectors and allocate them. */
pipe->num_cons = 1;
- for (p = arg; isdigit(*p) || *p == ','; ++p) {
+ for (p = arg; *p && *p != ':' && *p != '@'; ++p) {
if (*p == ',')
pipe->num_cons++;
}
pipe->con_ids = calloc(pipe->num_cons, sizeof(*pipe->con_ids));
- if (pipe->con_ids == NULL)
+ pipe->cons = calloc(pipe->num_cons, sizeof(*pipe->cons));
+ if (pipe->con_ids == NULL || pipe->cons == NULL)
return -1;
/* Parse the connectors. */
for (i = 0, p = arg; i < pipe->num_cons; ++i, p = endp + 1) {
- pipe->con_ids[i] = strtoul(p, &endp, 10);
+ endp = strpbrk(p, ",@:");
+ if (!endp)
+ break;
+
+ pipe->cons[i] = strndup(p, endp - p);
+
if (*endp != ',')
break;
}
@@ -1484,6 +1520,32 @@ static int cursor_supported(void)
return 1;
}
+static int pipe_resolve_connectors(struct device *dev, struct pipe_arg *pipe)
+{
+ drmModeConnector *connector;
+ unsigned int i;
+ uint32_t id;
+ char *endp;
+
+ for (i = 0; i < pipe->num_cons; i++) {
+ id = strtoul(pipe->cons[i], &endp, 10);
+ if (endp == pipe->cons[i]) {
+ connector = get_connector_by_name(dev, pipe->cons[i]);
+ if (!connector) {
+ fprintf(stderr, "no connector named '%s'\n",
+ pipe->cons[i]);
+ return -ENODEV;
+ }
+
+ id = connector->connector_id;
+ }
+
+ pipe->con_ids[i] = id;
+ }
+
+ return 0;
+}
+
static char optstr[] = "cdD:efM:P:ps:Cvw:";
int main(int argc, char **argv)
@@ -1499,7 +1561,7 @@ int main(int argc, char **argv)
char *device = NULL;
char *module = NULL;
unsigned int i;
- int count = 0, plane_count = 0;
+ unsigned int count = 0, plane_count = 0;
unsigned int prop_count = 0;
struct pipe_arg *pipe_args = NULL;
struct plane_arg *plane_args = NULL;
@@ -1641,6 +1703,14 @@ int main(int argc, char **argv)
return 1;
}
+ for (i = 0; i < count; i++) {
+ if (pipe_resolve_connectors(&dev, &pipe_args[i]) < 0) {
+ free_resources(dev.resources);
+ drmClose(dev.fd);
+ return 1;
+ }
+ }
+
#define dump_resource(dev, res) if (res) dump_##res(dev)
dump_resource(&dev, encoders);