From: Stefan Agner <stefan@agner.ch>
To: plagnioj@jcrosoft.com, shawnguo@kernel.org
Cc: s.hauer@pengutronix.de, Ying.Liu@freescale.com,
linux-fbdev@vger.kernel.org, linux-kernel@vger.kernel.org,
LW@KARO-electronics.de, fabio.estevam@freescale.com,
max.krummenacher@toradex.com, Stefan Agner <stefan@agner.ch>
Subject: [PATCH] video: fbdev: mxsfb: fix pixelclock polarity
Date: Tue, 26 Jan 2016 01:29:16 +0000 [thread overview]
Message-ID: <1453771756-5418-1-git-send-email-stefan@agner.ch> (raw)
The PIXDATA flags of the display_flags enum are controller centric,
e.g. NEGEDGE means the controller shall drive the data signals on
pixelclocks negative edge. However, the drivers flag is display
centric: Sample the data on negative (falling) edge.
Therefore, change the if statement to check for the POSEDGE flag
(which is typically not set):
Drive on positive edge => sample on negative edge
Signed-off-by: Stefan Agner <stefan@agner.ch>
---
Hi all
Shawn, I would like to have at least your Ack on this before merge.
It seems that this has been wrong since the driver is able to use
the timings from the device tree, introduced with 669406534b4a
("video: mxsfb: get display timings from device tree").
Not sure how many device trees actually specify the wrong pixel clock
polarity due to that. At least the initial flag convertion from the
old platform data structures done with 0d9f8217db15 ("ARM: mxs: move
display timing configurations into device tree") seems to be affected
and would need to be changed accordingly...
Not sure how we should handle this, maybe just invert all
pixelclk-active properties where the mxsfb driver is in use...?
--
Stefan
drivers/video/fbdev/mxsfb.c | 13 +++++++++++--
1 file changed, 11 insertions(+), 2 deletions(-)
diff --git a/drivers/video/fbdev/mxsfb.c b/drivers/video/fbdev/mxsfb.c
index 4e6608c..38898a9 100644
--- a/drivers/video/fbdev/mxsfb.c
+++ b/drivers/video/fbdev/mxsfb.c
@@ -150,7 +150,7 @@
#define STMLCDIF_24BIT 3 /** pixel data bus to the display is of 24 bit width */
#define MXSFB_SYNC_DATA_ENABLE_HIGH_ACT (1 << 6)
-#define MXSFB_SYNC_DOTCLK_FALLING_ACT (1 << 7) /* negtive edge sampling */
+#define MXSFB_SYNC_DOTCLK_FALLING_ACT (1 << 7) /* negative edge sampling */
enum mxsfb_devtype {
MXSFB_V3,
@@ -788,7 +788,16 @@ static int mxsfb_init_fbinfo_dt(struct mxsfb_info *host,
if (vm.flags & DISPLAY_FLAGS_DE_HIGH)
host->sync |= MXSFB_SYNC_DATA_ENABLE_HIGH_ACT;
- if (vm.flags & DISPLAY_FLAGS_PIXDATA_NEGEDGE)
+
+ /*
+ * The PIXDATA flags of the display_flags enum are controller
+ * centric, e.g. NEGEDGE means drive data on negative edge.
+ * However, the drivers flag is display centric: Sample the
+ * data on negative (falling) edge. Therefore, check for the
+ * POSEDGE flag:
+ * drive on positive edge => sample on negative edge
+ */
+ if (vm.flags & DISPLAY_FLAGS_PIXDATA_POSEDGE)
host->sync |= MXSFB_SYNC_DOTCLK_FALLING_ACT;
put_display_node:
--
2.7.0
next reply other threads:[~2016-01-26 1:29 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-01-26 1:29 Stefan Agner [this message]
2016-05-06 20:29 ` [PATCH] video: fbdev: mxsfb: fix pixelclock polarity Stefan Agner
[not found] ` <CGME20171017135621epcas1p39142851c7bc56478165c887ba14ee585@epcas1p3.samsung.com>
2017-10-17 13:56 ` Bartlomiej Zolnierkiewicz
2017-10-17 16:01 ` Stefan Agner
[not found] ` <CGME20171109133407epcas1p23f7ebf05f0d20e00ef56cf64425bdb60@epcas1p2.samsung.com>
2017-11-09 13:34 ` Bartlomiej Zolnierkiewicz
2017-10-18 2:05 ` Shawn Guo
2017-10-05 7:43 ` Mauro Salvini
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1453771756-5418-1-git-send-email-stefan@agner.ch \
--to=stefan@agner.ch \
--cc=LW@KARO-electronics.de \
--cc=Ying.Liu@freescale.com \
--cc=fabio.estevam@freescale.com \
--cc=linux-fbdev@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=max.krummenacher@toradex.com \
--cc=plagnioj@jcrosoft.com \
--cc=s.hauer@pengutronix.de \
--cc=shawnguo@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).