Hi Thierry, Thank you for the patch. On Friday 23 January 2015 17:08:18 Thierry Reding wrote: > From: Thierry Reding <treding@xxxxxxxxxx> > > These tables are duplicated in several places, so move them into libutil > so that they can be shared. > > Signed-off-by: Thierry Reding <treding@xxxxxxxxxx> Acked-by: Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx> > --- > tests/modetest/modetest.c | 50 ++----------------- > tests/proptest/Makefile.am | 4 +- > tests/proptest/proptest.c | 40 +-------------- > tests/util/Makefile.am | 2 + > tests/util/kms.c | 122 ++++++++++++++++++++++++++++++++++++++++++ > tests/util/kms.h | 33 ++++++++++++ > 6 files changed, 165 insertions(+), 86 deletions(-) > create mode 100644 tests/util/kms.c > create mode 100644 tests/util/kms.h > > diff --git a/tests/modetest/modetest.c b/tests/modetest/modetest.c > index b610956adfcb..d5fd99ebe1fd 100644 > --- a/tests/modetest/modetest.c > +++ b/tests/modetest/modetest.c > @@ -61,6 +61,7 @@ > > #include "util/common.h" > #include "util/format.h" > +#include "util/kms.h" > #include "util/pattern.h" > > #include "buffers.h" > @@ -123,11 +124,6 @@ static inline int64_t U642I64(uint64_t val) > return (int64_t)*((int64_t *)&val); > } > > -struct type_name { > - int type; > - const char *name; > -}; > - > #define type_name_fn(res) \ > const char * res##_str(int type) { \ > unsigned int i; \ > @@ -138,44 +134,6 @@ const char * res##_str(int type) { \ > return "(invalid)"; \ > } > > -struct type_name encoder_type_names[] = { > - { DRM_MODE_ENCODER_NONE, "none" }, > - { DRM_MODE_ENCODER_DAC, "DAC" }, > - { DRM_MODE_ENCODER_TMDS, "TMDS" }, > - { DRM_MODE_ENCODER_LVDS, "LVDS" }, > - { DRM_MODE_ENCODER_TVDAC, "TVDAC" }, > -}; > - > -static type_name_fn(encoder_type) > - > -struct type_name connector_status_names[] = { > - { DRM_MODE_CONNECTED, "connected" }, > - { DRM_MODE_DISCONNECTED, "disconnected" }, > - { DRM_MODE_UNKNOWNCONNECTION, "unknown" }, > -}; > - > -static type_name_fn(connector_status) > - > -struct type_name connector_type_names[] = { > - { DRM_MODE_CONNECTOR_Unknown, "unknown" }, > - { DRM_MODE_CONNECTOR_VGA, "VGA" }, > - { DRM_MODE_CONNECTOR_DVII, "DVI-I" }, > - { DRM_MODE_CONNECTOR_DVID, "DVI-D" }, > - { DRM_MODE_CONNECTOR_DVIA, "DVI-A" }, > - { DRM_MODE_CONNECTOR_Composite, "composite" }, > - { DRM_MODE_CONNECTOR_SVIDEO, "s-video" }, > - { DRM_MODE_CONNECTOR_LVDS, "LVDS" }, > - { DRM_MODE_CONNECTOR_Component, "component" }, > - { DRM_MODE_CONNECTOR_9PinDIN, "9-pin DIN" }, > - { DRM_MODE_CONNECTOR_DisplayPort, "DP" }, > - { DRM_MODE_CONNECTOR_HDMIA, "HDMI-A" }, > - { DRM_MODE_CONNECTOR_HDMIB, "HDMI-B" }, > - { DRM_MODE_CONNECTOR_TV, "TV" }, > - { DRM_MODE_CONNECTOR_eDP, "eDP" }, > -}; > - > -static type_name_fn(connector_type) > - > #define bit_name_fn(res) \ > const char * res##_str(int type) { \ > unsigned int i; \ > @@ -235,7 +193,7 @@ static void dump_encoders(struct device *dev) > printf("%d\t%d\t%s\t0x%08x\t0x%08x\n", > encoder->encoder_id, > encoder->crtc_id, > - encoder_type_str(encoder->encoder_type), > + util_lookup_encoder_type_name(encoder->encoder_type), > encoder->possible_crtcs, > encoder->possible_clones); > } > @@ -379,8 +337,8 @@ static void dump_connectors(struct device *dev) > printf("%d\t%d\t%s\t%s\t%dx%d\t\t%d\t", > connector->connector_id, > connector->encoder_id, > - connector_status_str(connector->connection), > - connector_type_str(connector->connector_type), > + util_lookup_connector_status_name(connector->connection), > + util_lookup_connector_type_name(connector->connector_type), > connector->mmWidth, connector->mmHeight, > connector->count_modes); > > diff --git a/tests/proptest/Makefile.am b/tests/proptest/Makefile.am > index f81a3c00846b..c615489b9a92 100644 > --- a/tests/proptest/Makefile.am > +++ b/tests/proptest/Makefile.am > @@ -1,5 +1,6 @@ > AM_CFLAGS = \ > -I$(top_srcdir)/include/drm \ > + -I$(top_srcdir)/tests \ > -I$(top_srcdir) > > noinst_PROGRAMS = \ > @@ -8,4 +9,5 @@ noinst_PROGRAMS = \ > proptest_SOURCES = \ > proptest.c > proptest_LDADD = \ > - $(top_builddir)/libdrm.la > + $(top_builddir)/libdrm.la \ > + $(top_builddir)/tests/util/libutil.la > diff --git a/tests/proptest/proptest.c b/tests/proptest/proptest.c > index ee3fa408a310..b442d583d528 100644 > --- a/tests/proptest/proptest.c > +++ b/tests/proptest/proptest.c > @@ -45,44 +45,6 @@ static inline int64_t U642I64(uint64_t val) > int fd; > drmModeResPtr res = NULL; > > -const char *connector_type_str(uint32_t type) > -{ > - switch (type) { > - case DRM_MODE_CONNECTOR_Unknown: > - return "Unknown"; > - case DRM_MODE_CONNECTOR_VGA: > - return "VGA"; > - case DRM_MODE_CONNECTOR_DVII: > - return "DVI-I"; > - case DRM_MODE_CONNECTOR_DVID: > - return "DVI-D"; > - case DRM_MODE_CONNECTOR_DVIA: > - return "DVI-A"; > - case DRM_MODE_CONNECTOR_Composite: > - return "Composite"; > - case DRM_MODE_CONNECTOR_SVIDEO: > - return "SVIDEO"; > - case DRM_MODE_CONNECTOR_LVDS: > - return "LVDS"; > - case DRM_MODE_CONNECTOR_Component: > - return "Component"; > - case DRM_MODE_CONNECTOR_9PinDIN: > - return "9PinDin"; > - case DRM_MODE_CONNECTOR_DisplayPort: > - return "DisplayPort"; > - case DRM_MODE_CONNECTOR_HDMIA: > - return "HDMI-A"; > - case DRM_MODE_CONNECTOR_HDMIB: > - return "HDMI-B"; > - case DRM_MODE_CONNECTOR_TV: > - return "TV"; > - case DRM_MODE_CONNECTOR_eDP: > - return "eDP"; > - default: > - return "Invalid"; > - } > -} > - > /* dump_blob and dump_prop shamelessly copied from ../modetest/modetest.c > */ static void > dump_blob(uint32_t blob_id) > @@ -226,7 +188,7 @@ static void listConnectorProperties(void) > } > > printf("Connector %u (%s-%u)\n", c->connector_id, > - connector_type_str(c->connector_type), > + util_lookup_connector_type_name(c->connector_type), > c->connector_type_id); > > listObjectProperties(c->connector_id, > diff --git a/tests/util/Makefile.am b/tests/util/Makefile.am > index 1a2519fbea89..c00574484867 100644 > --- a/tests/util/Makefile.am > +++ b/tests/util/Makefile.am > @@ -12,6 +12,8 @@ libutil_la_SOURCES = \ > common.h \ > format.c \ > format.h \ > + kms.c \ > + kms.h \ > pattern.c \ > pattern.h > > diff --git a/tests/util/kms.c b/tests/util/kms.c > new file mode 100644 > index 000000000000..a271ca047c4e > --- /dev/null > +++ b/tests/util/kms.c > @@ -0,0 +1,122 @@ > +/* > + * Copyright 2008 Tungsten Graphics > + * Jakob Bornecrantz <jakob@xxxxxxxxxxxxxxxxxxxx> > + * Copyright 2008 Intel Corporation > + * Jesse Barnes <jesse.barnes@xxxxxxxxx> > + * > + * Permission is hereby granted, free of charge, to any person obtaining a > + * copy of this software and associated documentation files (the > "Software"), + * to deal in the Software without restriction, including > without limitation + * the rights to use, copy, modify, merge, publish, > distribute, sublicense, + * and/or sell copies of the Software, and to > permit persons to whom the + * Software is furnished to do so, subject to > the following conditions: + * > + * The above copyright notice and this permission notice shall be included > in + * all copies or substantial portions of the Software. > + * > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS > OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF > MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. > IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY > CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, > TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE > SOFTWARE OR THE USE OR OTHER DEALINGS + * IN THE SOFTWARE. > + */ > + > +/* > + * This fairly simple test program dumps output in a similar format to the > + * "xrandr" tool everyone knows & loves. It's necessarily slightly > different + * since the kernel separates outputs into encoder and connector > structures, + * each with their own unique ID. The program also allows > test testing of the + * memory management and mode setting APIs by allowing > the user to specify a + * connector and mode to use for mode setting. If > all works as expected, a + * blue background should be painted on the > monitor attached to the specified + * connector after the selected mode is > set. > + * > + * TODO: use cairo to write the mode info on the selected output once > + * the mode has been programmed, along with possible test patterns. > + */ > + > +#ifdef HAVE_CONFIG_H > +#include "config.h" > +#endif > + > +#include <stdint.h> > +#include <stdlib.h> > + > +#include "xf86drmMode.h" > + > +#include "common.h" > + > +struct type_name { > + unsigned int type; > + const char *name; > +}; > + > +static const char *util_lookup_type_name(unsigned int type, > + const struct type_name *table, > + unsigned int count) > +{ > + unsigned int i; > + > + for (i = 0; i < count; i++) > + if (table[i].type == type) > + return table[i].name; > + > + return NULL; > +} > + > +static const struct type_name encoder_type_names[] = { > + { DRM_MODE_ENCODER_NONE, "none" }, > + { DRM_MODE_ENCODER_DAC, "DAC" }, > + { DRM_MODE_ENCODER_TMDS, "TMDS" }, > + { DRM_MODE_ENCODER_LVDS, "LVDS" }, > + { DRM_MODE_ENCODER_TVDAC, "TVDAC" }, > + { DRM_MODE_ENCODER_VIRTUAL, "Virtual" }, > + { DRM_MODE_ENCODER_DSI, "DSI" }, > + { DRM_MODE_ENCODER_DPMST, "DisplayPort MST" }, > +}; > + > +const char *util_lookup_encoder_type_name(unsigned int type) > +{ > + return util_lookup_type_name(type, encoder_type_names, > + ARRAY_SIZE(encoder_type_names)); > +} > + > +static const struct type_name connector_status_names[] = { > + { DRM_MODE_CONNECTED, "connected" }, > + { DRM_MODE_DISCONNECTED, "disconnected" }, > + { DRM_MODE_UNKNOWNCONNECTION, "unknown" }, > +}; > + > +const char *util_lookup_connector_status_name(unsigned int status) > +{ > + return util_lookup_type_name(status, connector_status_names, > + ARRAY_SIZE(connector_status_names)); > +} > + > +static const struct type_name connector_type_names[] = { > + { DRM_MODE_CONNECTOR_Unknown, "unknown" }, > + { DRM_MODE_CONNECTOR_VGA, "VGA" }, > + { DRM_MODE_CONNECTOR_DVII, "DVI-I" }, > + { DRM_MODE_CONNECTOR_DVID, "DVI-D" }, > + { DRM_MODE_CONNECTOR_DVIA, "DVI-A" }, > + { DRM_MODE_CONNECTOR_Composite, "composite" }, > + { DRM_MODE_CONNECTOR_SVIDEO, "s-video" }, > + { DRM_MODE_CONNECTOR_LVDS, "LVDS" }, > + { DRM_MODE_CONNECTOR_Component, "component" }, > + { DRM_MODE_CONNECTOR_9PinDIN, "9-pin DIN" }, > + { DRM_MODE_CONNECTOR_DisplayPort, "DP" }, > + { DRM_MODE_CONNECTOR_HDMIA, "HDMI-A" }, > + { DRM_MODE_CONNECTOR_HDMIB, "HDMI-B" }, > + { DRM_MODE_CONNECTOR_TV, "TV" }, > + { DRM_MODE_CONNECTOR_eDP, "eDP" }, > + { DRM_MODE_CONNECTOR_VIRTUAL, "Virtual" }, > + { DRM_MODE_CONNECTOR_DSI, "DSI" }, > +}; > + > +const char *util_lookup_connector_type_name(unsigned int type) > +{ > + return util_lookup_type_name(type, connector_type_names, > + ARRAY_SIZE(connector_type_names)); > +} > diff --git a/tests/util/kms.h b/tests/util/kms.h > new file mode 100644 > index 000000000000..fa9ab69983ac > --- /dev/null > +++ b/tests/util/kms.h > @@ -0,0 +1,33 @@ > +/* > + * Copyright 2008 Tungsten Graphics > + * Jakob Bornecrantz <jakob@xxxxxxxxxxxxxxxxxxxx> > + * Copyright 2008 Intel Corporation > + * Jesse Barnes <jesse.barnes@xxxxxxxxx> > + * > + * Permission is hereby granted, free of charge, to any person obtaining a > + * copy of this software and associated documentation files (the > "Software"), + * to deal in the Software without restriction, including > without limitation + * the rights to use, copy, modify, merge, publish, > distribute, sublicense, + * and/or sell copies of the Software, and to > permit persons to whom the + * Software is furnished to do so, subject to > the following conditions: + * > + * The above copyright notice and this permission notice shall be included > in + * all copies or substantial portions of the Software. > + * > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS > OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF > MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. > IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY > CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, > TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE > SOFTWARE OR THE USE OR OTHER DEALINGS + * IN THE SOFTWARE. > + */ > + > +#ifndef UTIL_KMS_H > +#define UTIL_KMS_H > + > +const char *util_lookup_encoder_type_name(unsigned int type); > +const char *util_lookup_connector_status_name(unsigned int type); > +const char *util_lookup_connector_type_name(unsigned int type); > + > +#endif /* UTIL_KMS_H */ -- Regards, Laurent Pinchart _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/dri-devel