diff options
author | Guennadi Liakhovetski <g.liakhovetski@gmx.de> | 2010-09-03 03:20:23 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2010-09-14 04:23:21 -0400 |
commit | 6de9edd5bde0cdfea12e9948690e53ec669c3018 (patch) | |
tree | 638602a3d7726b27ae6ab85ef45f4f11c38c0283 /drivers/video/sh_mobile_lcdcfb.h | |
parent | 89712699d7bc9cc93602407e0e9bc2490b771400 (diff) |
fbdev: sh_mobile_hdmi: implement locking
The SH-Mobile HDMI driver runs in several contexts: ISR, delayed work-queue,
task context, when called from the sh_mobile_lcdc framebuffer driver. This
creates ample race possibilities. Even though most these races are purely
theoretical, it is better to close them. To trace fb_info validity we install a
notification callback in the HDMI driver, and the only way for it to get to
driver internal data is by using struct sh_mobile_lcdc_chan, therefore it had
to be extracted into a separate common header.
Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'drivers/video/sh_mobile_lcdcfb.h')
-rw-r--r-- | drivers/video/sh_mobile_lcdcfb.h | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/drivers/video/sh_mobile_lcdcfb.h b/drivers/video/sh_mobile_lcdcfb.h new file mode 100644 index 000000000000..6fcfc0ffe3f8 --- /dev/null +++ b/drivers/video/sh_mobile_lcdcfb.h | |||
@@ -0,0 +1,37 @@ | |||
1 | #ifndef SH_MOBILE_LCDCFB_H | ||
2 | #define SH_MOBILE_LCDCFB_H | ||
3 | |||
4 | #include <linux/completion.h> | ||
5 | #include <linux/fb.h> | ||
6 | #include <linux/wait.h> | ||
7 | |||
8 | /* per-channel registers */ | ||
9 | enum { LDDCKPAT1R, LDDCKPAT2R, LDMT1R, LDMT2R, LDMT3R, LDDFR, LDSM1R, | ||
10 | LDSM2R, LDSA1R, LDMLSR, LDHCNR, LDHSYNR, LDVLNR, LDVSYNR, LDPMR, | ||
11 | LDHAJR, | ||
12 | NR_CH_REGS }; | ||
13 | |||
14 | #define PALETTE_NR 16 | ||
15 | |||
16 | struct sh_mobile_lcdc_priv; | ||
17 | struct fb_info; | ||
18 | |||
19 | struct sh_mobile_lcdc_chan { | ||
20 | struct sh_mobile_lcdc_priv *lcdc; | ||
21 | unsigned long *reg_offs; | ||
22 | unsigned long ldmt1r_value; | ||
23 | unsigned long enabled; /* ME and SE in LDCNT2R */ | ||
24 | struct sh_mobile_lcdc_chan_cfg cfg; | ||
25 | u32 pseudo_palette[PALETTE_NR]; | ||
26 | unsigned long saved_ch_regs[NR_CH_REGS]; | ||
27 | struct fb_info *info; | ||
28 | dma_addr_t dma_handle; | ||
29 | struct fb_deferred_io defio; | ||
30 | struct scatterlist *sglist; | ||
31 | unsigned long frame_end; | ||
32 | unsigned long pan_offset; | ||
33 | wait_queue_head_t frame_end_wait; | ||
34 | struct completion vsync_completion; | ||
35 | }; | ||
36 | |||
37 | #endif | ||