Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

at v3.6-rc4 519 lines 17 kB view raw
1/* 2 * linux/drivers/video/omap2/dss/dss.h 3 * 4 * Copyright (C) 2009 Nokia Corporation 5 * Author: Tomi Valkeinen <tomi.valkeinen@nokia.com> 6 * 7 * Some code and ideas taken from drivers/video/omap/ driver 8 * by Imre Deak. 9 * 10 * This program is free software; you can redistribute it and/or modify it 11 * under the terms of the GNU General Public License version 2 as published by 12 * the Free Software Foundation. 13 * 14 * This program is distributed in the hope that it will be useful, but WITHOUT 15 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 16 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 17 * more details. 18 * 19 * You should have received a copy of the GNU General Public License along with 20 * this program. If not, see <http://www.gnu.org/licenses/>. 21 */ 22 23#ifndef __OMAP2_DSS_H 24#define __OMAP2_DSS_H 25 26#ifdef CONFIG_OMAP2_DSS_DEBUG_SUPPORT 27#define DEBUG 28#endif 29 30#ifdef DEBUG 31extern bool dss_debug; 32#ifdef DSS_SUBSYS_NAME 33#define DSSDBG(format, ...) \ 34 if (dss_debug) \ 35 printk(KERN_DEBUG "omapdss " DSS_SUBSYS_NAME ": " format, \ 36 ## __VA_ARGS__) 37#else 38#define DSSDBG(format, ...) \ 39 if (dss_debug) \ 40 printk(KERN_DEBUG "omapdss: " format, ## __VA_ARGS__) 41#endif 42 43#ifdef DSS_SUBSYS_NAME 44#define DSSDBGF(format, ...) \ 45 if (dss_debug) \ 46 printk(KERN_DEBUG "omapdss " DSS_SUBSYS_NAME \ 47 ": %s(" format ")\n", \ 48 __func__, \ 49 ## __VA_ARGS__) 50#else 51#define DSSDBGF(format, ...) \ 52 if (dss_debug) \ 53 printk(KERN_DEBUG "omapdss: " \ 54 ": %s(" format ")\n", \ 55 __func__, \ 56 ## __VA_ARGS__) 57#endif 58 59#else /* DEBUG */ 60#define DSSDBG(format, ...) 61#define DSSDBGF(format, ...) 62#endif 63 64 65#ifdef DSS_SUBSYS_NAME 66#define DSSERR(format, ...) \ 67 printk(KERN_ERR "omapdss " DSS_SUBSYS_NAME " error: " format, \ 68 ## __VA_ARGS__) 69#else 70#define DSSERR(format, ...) \ 71 printk(KERN_ERR "omapdss error: " format, ## __VA_ARGS__) 72#endif 73 74#ifdef DSS_SUBSYS_NAME 75#define DSSINFO(format, ...) \ 76 printk(KERN_INFO "omapdss " DSS_SUBSYS_NAME ": " format, \ 77 ## __VA_ARGS__) 78#else 79#define DSSINFO(format, ...) \ 80 printk(KERN_INFO "omapdss: " format, ## __VA_ARGS__) 81#endif 82 83#ifdef DSS_SUBSYS_NAME 84#define DSSWARN(format, ...) \ 85 printk(KERN_WARNING "omapdss " DSS_SUBSYS_NAME ": " format, \ 86 ## __VA_ARGS__) 87#else 88#define DSSWARN(format, ...) \ 89 printk(KERN_WARNING "omapdss: " format, ## __VA_ARGS__) 90#endif 91 92/* OMAP TRM gives bitfields as start:end, where start is the higher bit 93 number. For example 7:0 */ 94#define FLD_MASK(start, end) (((1 << ((start) - (end) + 1)) - 1) << (end)) 95#define FLD_VAL(val, start, end) (((val) << (end)) & FLD_MASK(start, end)) 96#define FLD_GET(val, start, end) (((val) & FLD_MASK(start, end)) >> (end)) 97#define FLD_MOD(orig, val, start, end) \ 98 (((orig) & ~FLD_MASK(start, end)) | FLD_VAL(val, start, end)) 99 100enum dss_io_pad_mode { 101 DSS_IO_PAD_MODE_RESET, 102 DSS_IO_PAD_MODE_RFBI, 103 DSS_IO_PAD_MODE_BYPASS, 104}; 105 106enum dss_hdmi_venc_clk_source_select { 107 DSS_VENC_TV_CLK = 0, 108 DSS_HDMI_M_PCLK = 1, 109}; 110 111enum dss_dsi_content_type { 112 DSS_DSI_CONTENT_DCS, 113 DSS_DSI_CONTENT_GENERIC, 114}; 115 116struct dss_clock_info { 117 /* rates that we get with dividers below */ 118 unsigned long fck; 119 120 /* dividers */ 121 u16 fck_div; 122}; 123 124struct dispc_clock_info { 125 /* rates that we get with dividers below */ 126 unsigned long lck; 127 unsigned long pck; 128 129 /* dividers */ 130 u16 lck_div; 131 u16 pck_div; 132}; 133 134struct dsi_clock_info { 135 /* rates that we get with dividers below */ 136 unsigned long fint; 137 unsigned long clkin4ddr; 138 unsigned long clkin; 139 unsigned long dsi_pll_hsdiv_dispc_clk; /* OMAP3: DSI1_PLL_CLK 140 * OMAP4: PLLx_CLK1 */ 141 unsigned long dsi_pll_hsdiv_dsi_clk; /* OMAP3: DSI2_PLL_CLK 142 * OMAP4: PLLx_CLK2 */ 143 unsigned long lp_clk; 144 145 /* dividers */ 146 u16 regn; 147 u16 regm; 148 u16 regm_dispc; /* OMAP3: REGM3 149 * OMAP4: REGM4 */ 150 u16 regm_dsi; /* OMAP3: REGM4 151 * OMAP4: REGM5 */ 152 u16 lp_clk_div; 153}; 154 155struct reg_field { 156 u16 reg; 157 u8 high; 158 u8 low; 159}; 160 161struct dss_lcd_mgr_config { 162 enum dss_io_pad_mode io_pad_mode; 163 164 bool stallmode; 165 bool fifohandcheck; 166 167 struct dispc_clock_info clock_info; 168 169 int video_port_width; 170 171 int lcden_sig_polarity; 172}; 173 174struct seq_file; 175struct platform_device; 176 177/* core */ 178struct bus_type *dss_get_bus(void); 179struct regulator *dss_get_vdds_dsi(void); 180struct regulator *dss_get_vdds_sdi(void); 181int dss_get_ctx_loss_count(struct device *dev); 182int dss_dsi_enable_pads(int dsi_id, unsigned lane_mask); 183void dss_dsi_disable_pads(int dsi_id, unsigned lane_mask); 184int dss_set_min_bus_tput(struct device *dev, unsigned long tput); 185int dss_debugfs_create_file(const char *name, void (*write)(struct seq_file *)); 186 187int omap_dss_register_device(struct omap_dss_device *dssdev, 188 struct device *parent, int disp_num); 189void omap_dss_unregister_device(struct omap_dss_device *dssdev); 190void omap_dss_unregister_child_devices(struct device *parent); 191 192/* apply */ 193void dss_apply_init(void); 194int dss_mgr_wait_for_go(struct omap_overlay_manager *mgr); 195int dss_mgr_wait_for_go_ovl(struct omap_overlay *ovl); 196void dss_mgr_start_update(struct omap_overlay_manager *mgr); 197int omap_dss_mgr_apply(struct omap_overlay_manager *mgr); 198 199int dss_mgr_enable(struct omap_overlay_manager *mgr); 200void dss_mgr_disable(struct omap_overlay_manager *mgr); 201int dss_mgr_set_info(struct omap_overlay_manager *mgr, 202 struct omap_overlay_manager_info *info); 203void dss_mgr_get_info(struct omap_overlay_manager *mgr, 204 struct omap_overlay_manager_info *info); 205int dss_mgr_set_device(struct omap_overlay_manager *mgr, 206 struct omap_dss_device *dssdev); 207int dss_mgr_unset_device(struct omap_overlay_manager *mgr); 208void dss_mgr_set_timings(struct omap_overlay_manager *mgr, 209 struct omap_video_timings *timings); 210void dss_mgr_set_lcd_config(struct omap_overlay_manager *mgr, 211 const struct dss_lcd_mgr_config *config); 212const struct omap_video_timings *dss_mgr_get_timings(struct omap_overlay_manager *mgr); 213 214bool dss_ovl_is_enabled(struct omap_overlay *ovl); 215int dss_ovl_enable(struct omap_overlay *ovl); 216int dss_ovl_disable(struct omap_overlay *ovl); 217int dss_ovl_set_info(struct omap_overlay *ovl, 218 struct omap_overlay_info *info); 219void dss_ovl_get_info(struct omap_overlay *ovl, 220 struct omap_overlay_info *info); 221int dss_ovl_set_manager(struct omap_overlay *ovl, 222 struct omap_overlay_manager *mgr); 223int dss_ovl_unset_manager(struct omap_overlay *ovl); 224 225/* display */ 226int dss_suspend_all_devices(void); 227int dss_resume_all_devices(void); 228void dss_disable_all_devices(void); 229 230void dss_init_device(struct platform_device *pdev, 231 struct omap_dss_device *dssdev); 232void dss_uninit_device(struct platform_device *pdev, 233 struct omap_dss_device *dssdev); 234 235/* manager */ 236int dss_init_overlay_managers(struct platform_device *pdev); 237void dss_uninit_overlay_managers(struct platform_device *pdev); 238int dss_mgr_simple_check(struct omap_overlay_manager *mgr, 239 const struct omap_overlay_manager_info *info); 240int dss_mgr_check_timings(struct omap_overlay_manager *mgr, 241 const struct omap_video_timings *timings); 242int dss_mgr_check(struct omap_overlay_manager *mgr, 243 struct omap_overlay_manager_info *info, 244 const struct omap_video_timings *mgr_timings, 245 const struct dss_lcd_mgr_config *config, 246 struct omap_overlay_info **overlay_infos); 247 248static inline bool dss_mgr_is_lcd(enum omap_channel id) 249{ 250 if (id == OMAP_DSS_CHANNEL_LCD || id == OMAP_DSS_CHANNEL_LCD2 || 251 id == OMAP_DSS_CHANNEL_LCD3) 252 return true; 253 else 254 return false; 255} 256 257/* overlay */ 258void dss_init_overlays(struct platform_device *pdev); 259void dss_uninit_overlays(struct platform_device *pdev); 260void dss_overlay_setup_dispc_manager(struct omap_overlay_manager *mgr); 261void dss_recheck_connections(struct omap_dss_device *dssdev, bool force); 262int dss_ovl_simple_check(struct omap_overlay *ovl, 263 const struct omap_overlay_info *info); 264int dss_ovl_check(struct omap_overlay *ovl, struct omap_overlay_info *info, 265 const struct omap_video_timings *mgr_timings); 266bool dss_ovl_use_replication(struct dss_lcd_mgr_config config, 267 enum omap_color_mode mode); 268 269/* DSS */ 270int dss_init_platform_driver(void) __init; 271void dss_uninit_platform_driver(void); 272 273void dss_select_hdmi_venc_clk_source(enum dss_hdmi_venc_clk_source_select); 274enum dss_hdmi_venc_clk_source_select dss_get_hdmi_venc_clk_source(void); 275const char *dss_get_generic_clk_source_name(enum omap_dss_clk_source clk_src); 276void dss_dump_clocks(struct seq_file *s); 277 278#if defined(CONFIG_DEBUG_FS) && defined(CONFIG_OMAP2_DSS_DEBUG_SUPPORT) 279void dss_debug_dump_clocks(struct seq_file *s); 280#endif 281 282void dss_sdi_init(u8 datapairs); 283int dss_sdi_enable(void); 284void dss_sdi_disable(void); 285 286void dss_select_dispc_clk_source(enum omap_dss_clk_source clk_src); 287void dss_select_dsi_clk_source(int dsi_module, 288 enum omap_dss_clk_source clk_src); 289void dss_select_lcd_clk_source(enum omap_channel channel, 290 enum omap_dss_clk_source clk_src); 291enum omap_dss_clk_source dss_get_dispc_clk_source(void); 292enum omap_dss_clk_source dss_get_dsi_clk_source(int dsi_module); 293enum omap_dss_clk_source dss_get_lcd_clk_source(enum omap_channel channel); 294 295void dss_set_venc_output(enum omap_dss_venc_type type); 296void dss_set_dac_pwrdn_bgz(bool enable); 297 298unsigned long dss_get_dpll4_rate(void); 299int dss_calc_clock_rates(struct dss_clock_info *cinfo); 300int dss_set_clock_div(struct dss_clock_info *cinfo); 301int dss_get_clock_div(struct dss_clock_info *cinfo); 302int dss_calc_clock_div(unsigned long req_pck, struct dss_clock_info *dss_cinfo, 303 struct dispc_clock_info *dispc_cinfo); 304 305/* SDI */ 306int sdi_init_platform_driver(void) __init; 307void sdi_uninit_platform_driver(void) __exit; 308 309/* DSI */ 310#ifdef CONFIG_OMAP2_DSS_DSI 311 312struct dentry; 313struct file_operations; 314 315int dsi_init_platform_driver(void) __init; 316void dsi_uninit_platform_driver(void) __exit; 317 318int dsi_runtime_get(struct platform_device *dsidev); 319void dsi_runtime_put(struct platform_device *dsidev); 320 321void dsi_dump_clocks(struct seq_file *s); 322 323void dsi_irq_handler(void); 324u8 dsi_get_pixel_size(enum omap_dss_dsi_pixel_format fmt); 325 326unsigned long dsi_get_pll_hsdiv_dispc_rate(struct platform_device *dsidev); 327int dsi_pll_set_clock_div(struct platform_device *dsidev, 328 struct dsi_clock_info *cinfo); 329int dsi_pll_calc_clock_div_pck(struct platform_device *dsidev, 330 unsigned long req_pck, struct dsi_clock_info *cinfo, 331 struct dispc_clock_info *dispc_cinfo); 332int dsi_pll_init(struct platform_device *dsidev, bool enable_hsclk, 333 bool enable_hsdiv); 334void dsi_pll_uninit(struct platform_device *dsidev, bool disconnect_lanes); 335void dsi_wait_pll_hsdiv_dispc_active(struct platform_device *dsidev); 336void dsi_wait_pll_hsdiv_dsi_active(struct platform_device *dsidev); 337struct platform_device *dsi_get_dsidev_from_id(int module); 338#else 339static inline int dsi_runtime_get(struct platform_device *dsidev) 340{ 341 return 0; 342} 343static inline void dsi_runtime_put(struct platform_device *dsidev) 344{ 345} 346static inline u8 dsi_get_pixel_size(enum omap_dss_dsi_pixel_format fmt) 347{ 348 WARN("%s: DSI not compiled in, returning pixel_size as 0\n", __func__); 349 return 0; 350} 351static inline unsigned long dsi_get_pll_hsdiv_dispc_rate(struct platform_device *dsidev) 352{ 353 WARN("%s: DSI not compiled in, returning rate as 0\n", __func__); 354 return 0; 355} 356static inline int dsi_pll_set_clock_div(struct platform_device *dsidev, 357 struct dsi_clock_info *cinfo) 358{ 359 WARN("%s: DSI not compiled in\n", __func__); 360 return -ENODEV; 361} 362static inline int dsi_pll_calc_clock_div_pck(struct platform_device *dsidev, 363 unsigned long req_pck, 364 struct dsi_clock_info *dsi_cinfo, 365 struct dispc_clock_info *dispc_cinfo) 366{ 367 WARN("%s: DSI not compiled in\n", __func__); 368 return -ENODEV; 369} 370static inline int dsi_pll_init(struct platform_device *dsidev, 371 bool enable_hsclk, bool enable_hsdiv) 372{ 373 WARN("%s: DSI not compiled in\n", __func__); 374 return -ENODEV; 375} 376static inline void dsi_pll_uninit(struct platform_device *dsidev, 377 bool disconnect_lanes) 378{ 379} 380static inline void dsi_wait_pll_hsdiv_dispc_active(struct platform_device *dsidev) 381{ 382} 383static inline void dsi_wait_pll_hsdiv_dsi_active(struct platform_device *dsidev) 384{ 385} 386static inline struct platform_device *dsi_get_dsidev_from_id(int module) 387{ 388 WARN("%s: DSI not compiled in, returning platform device as NULL\n", 389 __func__); 390 return NULL; 391} 392#endif 393 394/* DPI */ 395int dpi_init_platform_driver(void) __init; 396void dpi_uninit_platform_driver(void) __exit; 397 398/* DISPC */ 399int dispc_init_platform_driver(void) __init; 400void dispc_uninit_platform_driver(void) __exit; 401void dispc_dump_clocks(struct seq_file *s); 402void dispc_irq_handler(void); 403 404int dispc_runtime_get(void); 405void dispc_runtime_put(void); 406 407void dispc_enable_sidle(void); 408void dispc_disable_sidle(void); 409 410void dispc_lcd_enable_signal_polarity(bool act_high); 411void dispc_lcd_enable_signal(bool enable); 412void dispc_pck_free_enable(bool enable); 413void dispc_enable_fifomerge(bool enable); 414void dispc_enable_gamma_table(bool enable); 415void dispc_set_loadmode(enum omap_dss_load_mode mode); 416 417bool dispc_mgr_timings_ok(enum omap_channel channel, 418 const struct omap_video_timings *timings); 419unsigned long dispc_fclk_rate(void); 420void dispc_find_clk_divs(unsigned long req_pck, unsigned long fck, 421 struct dispc_clock_info *cinfo); 422int dispc_calc_clock_rates(unsigned long dispc_fclk_rate, 423 struct dispc_clock_info *cinfo); 424 425 426void dispc_ovl_set_fifo_threshold(enum omap_plane plane, u32 low, u32 high); 427void dispc_ovl_compute_fifo_thresholds(enum omap_plane plane, 428 u32 *fifo_low, u32 *fifo_high, bool use_fifomerge, 429 bool manual_update); 430int dispc_ovl_setup(enum omap_plane plane, struct omap_overlay_info *oi, 431 bool replication, const struct omap_video_timings *mgr_timings); 432int dispc_ovl_enable(enum omap_plane plane, bool enable); 433void dispc_ovl_set_channel_out(enum omap_plane plane, 434 enum omap_channel channel); 435 436void dispc_mgr_enable_fifohandcheck(enum omap_channel channel, bool enable); 437u32 dispc_mgr_get_vsync_irq(enum omap_channel channel); 438u32 dispc_mgr_get_framedone_irq(enum omap_channel channel); 439bool dispc_mgr_go_busy(enum omap_channel channel); 440void dispc_mgr_go(enum omap_channel channel); 441bool dispc_mgr_is_enabled(enum omap_channel channel); 442void dispc_mgr_enable(enum omap_channel channel, bool enable); 443bool dispc_mgr_is_channel_enabled(enum omap_channel channel); 444void dispc_mgr_set_io_pad_mode(enum dss_io_pad_mode mode); 445void dispc_mgr_enable_stallmode(enum omap_channel channel, bool enable); 446void dispc_mgr_set_tft_data_lines(enum omap_channel channel, u8 data_lines); 447void dispc_mgr_set_lcd_type_tft(enum omap_channel channel); 448void dispc_mgr_set_timings(enum omap_channel channel, 449 struct omap_video_timings *timings); 450unsigned long dispc_mgr_lclk_rate(enum omap_channel channel); 451unsigned long dispc_mgr_pclk_rate(enum omap_channel channel); 452unsigned long dispc_core_clk_rate(void); 453void dispc_mgr_set_clock_div(enum omap_channel channel, 454 struct dispc_clock_info *cinfo); 455int dispc_mgr_get_clock_div(enum omap_channel channel, 456 struct dispc_clock_info *cinfo); 457void dispc_mgr_setup(enum omap_channel channel, 458 struct omap_overlay_manager_info *info); 459 460/* VENC */ 461#ifdef CONFIG_OMAP2_DSS_VENC 462int venc_init_platform_driver(void) __init; 463void venc_uninit_platform_driver(void) __exit; 464unsigned long venc_get_pixel_clock(void); 465#else 466static inline unsigned long venc_get_pixel_clock(void) 467{ 468 WARN("%s: VENC not compiled in, returning pclk as 0\n", __func__); 469 return 0; 470} 471#endif 472 473/* HDMI */ 474#ifdef CONFIG_OMAP4_DSS_HDMI 475int hdmi_init_platform_driver(void) __init; 476void hdmi_uninit_platform_driver(void) __exit; 477unsigned long hdmi_get_pixel_clock(void); 478#else 479static inline unsigned long hdmi_get_pixel_clock(void) 480{ 481 WARN("%s: HDMI not compiled in, returning pclk as 0\n", __func__); 482 return 0; 483} 484#endif 485int omapdss_hdmi_display_enable(struct omap_dss_device *dssdev); 486void omapdss_hdmi_display_disable(struct omap_dss_device *dssdev); 487void omapdss_hdmi_display_set_timing(struct omap_dss_device *dssdev); 488int omapdss_hdmi_display_check_timing(struct omap_dss_device *dssdev, 489 struct omap_video_timings *timings); 490int omapdss_hdmi_read_edid(u8 *buf, int len); 491bool omapdss_hdmi_detect(void); 492int hdmi_panel_init(void); 493void hdmi_panel_exit(void); 494#ifdef CONFIG_OMAP4_DSS_HDMI_AUDIO 495int hdmi_audio_enable(void); 496void hdmi_audio_disable(void); 497int hdmi_audio_start(void); 498void hdmi_audio_stop(void); 499bool hdmi_mode_has_audio(void); 500int hdmi_audio_config(struct omap_dss_audio *audio); 501#endif 502 503/* RFBI */ 504int rfbi_init_platform_driver(void) __init; 505void rfbi_uninit_platform_driver(void) __exit; 506 507 508#ifdef CONFIG_OMAP2_DSS_COLLECT_IRQ_STATS 509static inline void dss_collect_irq_stats(u32 irqstatus, unsigned *irq_arr) 510{ 511 int b; 512 for (b = 0; b < 32; ++b) { 513 if (irqstatus & (1 << b)) 514 irq_arr[b]++; 515 } 516} 517#endif 518 519#endif