From 87d335b92ab7580fdd0aef729646c8c2131b3ec8 Mon Sep 17 00:00:00 2001 From: Gregory Nutt Date: Mon, 27 May 2013 11:39:13 -0600 Subject: The SLCD driver is now fully functional for Sure PIC32MX board --- apps/examples/slcd/slcd_main.c | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) (limited to 'apps/examples/slcd') diff --git a/apps/examples/slcd/slcd_main.c b/apps/examples/slcd/slcd_main.c index e7f0ff00f..ecdd4a2b2 100644 --- a/apps/examples/slcd/slcd_main.c +++ b/apps/examples/slcd/slcd_main.c @@ -279,6 +279,8 @@ int slcd_main(int argc, char *argv[]) if (!priv->initialized) { + unsigned long brightness; + /* Initialize the output stream */ memset(priv, 0, sizeof(struct slcd_test_s)); @@ -296,8 +298,11 @@ int slcd_main(int argc, char *argv[]) goto errout_with_fd; } - printf("Geometry rows: %d columns: %d nbars: %d\n", + printf("Attributes:\n"); + printf(" rows: %d columns: %d nbars: %d\n", priv->attr.nrows, priv->attr.ncolumns, priv->attr.nbars); + printf(" max contrast: %d max brightness: %d\n", + priv->attr.maxcontrast, priv->attr.maxbrightness); /* Home the cursor and clear the display */ @@ -305,6 +310,21 @@ int slcd_main(int argc, char *argv[]) slcd_encode(SLCDCODE_CLEAR, 0, &priv->stream); slcd_flush(&priv->stream); + /* Set the brightness to the mid value */ + + brightness = ((unsigned long)priv->attr.maxbrightness + 1) >> 1; + printf("Set brightness to %ld\n", brightness); + + ret = ioctl(fd, SLCDIOC_SETBRIGHTNESS, brightness); + if (ret < 0) + { + /* Report the ioctl failure, but do not error out. Some SLCDs + * do not support brightness settings. + */ + + printf("ioctl(SLCDIOC_GETATTRIBUTES) failed: %d\n", errno); + } + priv->initialized = true; } -- cgit v1.2.3