diff options
-rw-r--r-- | drivers/video/omap2/dss/dispc.c | 23 | ||||
-rw-r--r-- | drivers/video/omap2/dss/dss.h | 36 | ||||
-rw-r--r-- | include/video/omapdss.h | 39 |
3 files changed, 63 insertions, 35 deletions
diff --git a/drivers/video/omap2/dss/dispc.c b/drivers/video/omap2/dss/dispc.c index 67548839ff51..fedbd2c8e97a 100644 --- a/drivers/video/omap2/dss/dispc.c +++ b/drivers/video/omap2/dss/dispc.c | |||
@@ -494,6 +494,7 @@ int dispc_runtime_get(void) | |||
494 | WARN_ON(r < 0); | 494 | WARN_ON(r < 0); |
495 | return r < 0 ? r : 0; | 495 | return r < 0 ? r : 0; |
496 | } | 496 | } |
497 | EXPORT_SYMBOL(dispc_runtime_get); | ||
497 | 498 | ||
498 | void dispc_runtime_put(void) | 499 | void dispc_runtime_put(void) |
499 | { | 500 | { |
@@ -504,11 +505,13 @@ void dispc_runtime_put(void) | |||
504 | r = pm_runtime_put_sync(&dispc.pdev->dev); | 505 | r = pm_runtime_put_sync(&dispc.pdev->dev); |
505 | WARN_ON(r < 0 && r != -ENOSYS); | 506 | WARN_ON(r < 0 && r != -ENOSYS); |
506 | } | 507 | } |
508 | EXPORT_SYMBOL(dispc_runtime_put); | ||
507 | 509 | ||
508 | u32 dispc_mgr_get_vsync_irq(enum omap_channel channel) | 510 | u32 dispc_mgr_get_vsync_irq(enum omap_channel channel) |
509 | { | 511 | { |
510 | return mgr_desc[channel].vsync_irq; | 512 | return mgr_desc[channel].vsync_irq; |
511 | } | 513 | } |
514 | EXPORT_SYMBOL(dispc_mgr_get_vsync_irq); | ||
512 | 515 | ||
513 | u32 dispc_mgr_get_framedone_irq(enum omap_channel channel) | 516 | u32 dispc_mgr_get_framedone_irq(enum omap_channel channel) |
514 | { | 517 | { |
@@ -517,11 +520,13 @@ u32 dispc_mgr_get_framedone_irq(enum omap_channel channel) | |||
517 | 520 | ||
518 | return mgr_desc[channel].framedone_irq; | 521 | return mgr_desc[channel].framedone_irq; |
519 | } | 522 | } |
523 | EXPORT_SYMBOL(dispc_mgr_get_framedone_irq); | ||
520 | 524 | ||
521 | u32 dispc_mgr_get_sync_lost_irq(enum omap_channel channel) | 525 | u32 dispc_mgr_get_sync_lost_irq(enum omap_channel channel) |
522 | { | 526 | { |
523 | return mgr_desc[channel].sync_lost_irq; | 527 | return mgr_desc[channel].sync_lost_irq; |
524 | } | 528 | } |
529 | EXPORT_SYMBOL(dispc_mgr_get_sync_lost_irq); | ||
525 | 530 | ||
526 | u32 dispc_wb_get_framedone_irq(void) | 531 | u32 dispc_wb_get_framedone_irq(void) |
527 | { | 532 | { |
@@ -532,6 +537,7 @@ bool dispc_mgr_go_busy(enum omap_channel channel) | |||
532 | { | 537 | { |
533 | return mgr_fld_read(channel, DISPC_MGR_FLD_GO) == 1; | 538 | return mgr_fld_read(channel, DISPC_MGR_FLD_GO) == 1; |
534 | } | 539 | } |
540 | EXPORT_SYMBOL(dispc_mgr_go_busy); | ||
535 | 541 | ||
536 | void dispc_mgr_go(enum omap_channel channel) | 542 | void dispc_mgr_go(enum omap_channel channel) |
537 | { | 543 | { |
@@ -542,6 +548,7 @@ void dispc_mgr_go(enum omap_channel channel) | |||
542 | 548 | ||
543 | mgr_fld_write(channel, DISPC_MGR_FLD_GO, 1); | 549 | mgr_fld_write(channel, DISPC_MGR_FLD_GO, 1); |
544 | } | 550 | } |
551 | EXPORT_SYMBOL(dispc_mgr_go); | ||
545 | 552 | ||
546 | bool dispc_wb_go_busy(void) | 553 | bool dispc_wb_go_busy(void) |
547 | { | 554 | { |
@@ -945,6 +952,7 @@ void dispc_ovl_set_channel_out(enum omap_plane plane, enum omap_channel channel) | |||
945 | } | 952 | } |
946 | dispc_write_reg(DISPC_OVL_ATTRIBUTES(plane), val); | 953 | dispc_write_reg(DISPC_OVL_ATTRIBUTES(plane), val); |
947 | } | 954 | } |
955 | EXPORT_SYMBOL(dispc_ovl_set_channel_out); | ||
948 | 956 | ||
949 | static enum omap_channel dispc_ovl_get_channel_out(enum omap_plane plane) | 957 | static enum omap_channel dispc_ovl_get_channel_out(enum omap_plane plane) |
950 | { | 958 | { |
@@ -2359,6 +2367,7 @@ int dispc_ovl_check(enum omap_plane plane, enum omap_channel channel, | |||
2359 | &five_taps, x_predecim, y_predecim, pos_x, | 2367 | &five_taps, x_predecim, y_predecim, pos_x, |
2360 | oi->rotation_type, false); | 2368 | oi->rotation_type, false); |
2361 | } | 2369 | } |
2370 | EXPORT_SYMBOL(dispc_ovl_check); | ||
2362 | 2371 | ||
2363 | static int dispc_ovl_setup_common(enum omap_plane plane, | 2372 | static int dispc_ovl_setup_common(enum omap_plane plane, |
2364 | enum omap_overlay_caps caps, u32 paddr, u32 p_uv_addr, | 2373 | enum omap_overlay_caps caps, u32 paddr, u32 p_uv_addr, |
@@ -2539,6 +2548,7 @@ int dispc_ovl_setup(enum omap_plane plane, const struct omap_overlay_info *oi, | |||
2539 | 2548 | ||
2540 | return r; | 2549 | return r; |
2541 | } | 2550 | } |
2551 | EXPORT_SYMBOL(dispc_ovl_setup); | ||
2542 | 2552 | ||
2543 | int dispc_wb_setup(const struct omap_dss_writeback_info *wi, | 2553 | int dispc_wb_setup(const struct omap_dss_writeback_info *wi, |
2544 | bool mem_to_mem, const struct omap_video_timings *mgr_timings) | 2554 | bool mem_to_mem, const struct omap_video_timings *mgr_timings) |
@@ -2599,11 +2609,13 @@ int dispc_ovl_enable(enum omap_plane plane, bool enable) | |||
2599 | 2609 | ||
2600 | return 0; | 2610 | return 0; |
2601 | } | 2611 | } |
2612 | EXPORT_SYMBOL(dispc_ovl_enable); | ||
2602 | 2613 | ||
2603 | bool dispc_ovl_enabled(enum omap_plane plane) | 2614 | bool dispc_ovl_enabled(enum omap_plane plane) |
2604 | { | 2615 | { |
2605 | return REG_GET(DISPC_OVL_ATTRIBUTES(plane), 0, 0); | 2616 | return REG_GET(DISPC_OVL_ATTRIBUTES(plane), 0, 0); |
2606 | } | 2617 | } |
2618 | EXPORT_SYMBOL(dispc_ovl_enabled); | ||
2607 | 2619 | ||
2608 | void dispc_mgr_enable(enum omap_channel channel, bool enable) | 2620 | void dispc_mgr_enable(enum omap_channel channel, bool enable) |
2609 | { | 2621 | { |
@@ -2611,11 +2623,13 @@ void dispc_mgr_enable(enum omap_channel channel, bool enable) | |||
2611 | /* flush posted write */ | 2623 | /* flush posted write */ |
2612 | mgr_fld_read(channel, DISPC_MGR_FLD_ENABLE); | 2624 | mgr_fld_read(channel, DISPC_MGR_FLD_ENABLE); |
2613 | } | 2625 | } |
2626 | EXPORT_SYMBOL(dispc_mgr_enable); | ||
2614 | 2627 | ||
2615 | bool dispc_mgr_is_enabled(enum omap_channel channel) | 2628 | bool dispc_mgr_is_enabled(enum omap_channel channel) |
2616 | { | 2629 | { |
2617 | return !!mgr_fld_read(channel, DISPC_MGR_FLD_ENABLE); | 2630 | return !!mgr_fld_read(channel, DISPC_MGR_FLD_ENABLE); |
2618 | } | 2631 | } |
2632 | EXPORT_SYMBOL(dispc_mgr_is_enabled); | ||
2619 | 2633 | ||
2620 | void dispc_wb_enable(bool enable) | 2634 | void dispc_wb_enable(bool enable) |
2621 | { | 2635 | { |
@@ -2712,6 +2726,7 @@ void dispc_mgr_setup(enum omap_channel channel, | |||
2712 | dispc_mgr_set_cpr_coef(channel, &info->cpr_coefs); | 2726 | dispc_mgr_set_cpr_coef(channel, &info->cpr_coefs); |
2713 | } | 2727 | } |
2714 | } | 2728 | } |
2729 | EXPORT_SYMBOL(dispc_mgr_setup); | ||
2715 | 2730 | ||
2716 | static void dispc_mgr_set_tft_data_lines(enum omap_channel channel, u8 data_lines) | 2731 | static void dispc_mgr_set_tft_data_lines(enum omap_channel channel, u8 data_lines) |
2717 | { | 2732 | { |
@@ -2788,6 +2803,7 @@ void dispc_mgr_set_lcd_config(enum omap_channel channel, | |||
2788 | 2803 | ||
2789 | dispc_mgr_set_lcd_type_tft(channel); | 2804 | dispc_mgr_set_lcd_type_tft(channel); |
2790 | } | 2805 | } |
2806 | EXPORT_SYMBOL(dispc_mgr_set_lcd_config); | ||
2791 | 2807 | ||
2792 | static bool _dispc_mgr_size_ok(u16 width, u16 height) | 2808 | static bool _dispc_mgr_size_ok(u16 width, u16 height) |
2793 | { | 2809 | { |
@@ -2926,6 +2942,7 @@ void dispc_mgr_set_timings(enum omap_channel channel, | |||
2926 | 2942 | ||
2927 | dispc_mgr_set_size(channel, t.x_res, t.y_res); | 2943 | dispc_mgr_set_size(channel, t.x_res, t.y_res); |
2928 | } | 2944 | } |
2945 | EXPORT_SYMBOL(dispc_mgr_set_timings); | ||
2929 | 2946 | ||
2930 | static void dispc_mgr_set_lcd_divisor(enum omap_channel channel, u16 lck_div, | 2947 | static void dispc_mgr_set_lcd_divisor(enum omap_channel channel, u16 lck_div, |
2931 | u16 pck_div) | 2948 | u16 pck_div) |
@@ -3389,16 +3406,19 @@ u32 dispc_read_irqstatus(void) | |||
3389 | { | 3406 | { |
3390 | return dispc_read_reg(DISPC_IRQSTATUS); | 3407 | return dispc_read_reg(DISPC_IRQSTATUS); |
3391 | } | 3408 | } |
3409 | EXPORT_SYMBOL(dispc_read_irqstatus); | ||
3392 | 3410 | ||
3393 | void dispc_clear_irqstatus(u32 mask) | 3411 | void dispc_clear_irqstatus(u32 mask) |
3394 | { | 3412 | { |
3395 | dispc_write_reg(DISPC_IRQSTATUS, mask); | 3413 | dispc_write_reg(DISPC_IRQSTATUS, mask); |
3396 | } | 3414 | } |
3415 | EXPORT_SYMBOL(dispc_clear_irqstatus); | ||
3397 | 3416 | ||
3398 | u32 dispc_read_irqenable(void) | 3417 | u32 dispc_read_irqenable(void) |
3399 | { | 3418 | { |
3400 | return dispc_read_reg(DISPC_IRQENABLE); | 3419 | return dispc_read_reg(DISPC_IRQENABLE); |
3401 | } | 3420 | } |
3421 | EXPORT_SYMBOL(dispc_read_irqenable); | ||
3402 | 3422 | ||
3403 | void dispc_write_irqenable(u32 mask) | 3423 | void dispc_write_irqenable(u32 mask) |
3404 | { | 3424 | { |
@@ -3409,6 +3429,7 @@ void dispc_write_irqenable(u32 mask) | |||
3409 | 3429 | ||
3410 | dispc_write_reg(DISPC_IRQENABLE, mask); | 3430 | dispc_write_reg(DISPC_IRQENABLE, mask); |
3411 | } | 3431 | } |
3432 | EXPORT_SYMBOL(dispc_write_irqenable); | ||
3412 | 3433 | ||
3413 | void dispc_enable_sidle(void) | 3434 | void dispc_enable_sidle(void) |
3414 | { | 3435 | { |
@@ -3584,11 +3605,13 @@ int dispc_request_irq(irq_handler_t handler, void *dev_id) | |||
3584 | return devm_request_irq(&dispc.pdev->dev, dispc.irq, handler, | 3605 | return devm_request_irq(&dispc.pdev->dev, dispc.irq, handler, |
3585 | IRQF_SHARED, "OMAP DISPC", dev_id); | 3606 | IRQF_SHARED, "OMAP DISPC", dev_id); |
3586 | } | 3607 | } |
3608 | EXPORT_SYMBOL(dispc_request_irq); | ||
3587 | 3609 | ||
3588 | void dispc_free_irq(void *dev_id) | 3610 | void dispc_free_irq(void *dev_id) |
3589 | { | 3611 | { |
3590 | devm_free_irq(&dispc.pdev->dev, dispc.irq, dev_id); | 3612 | devm_free_irq(&dispc.pdev->dev, dispc.irq, dev_id); |
3591 | } | 3613 | } |
3614 | EXPORT_SYMBOL(dispc_free_irq); | ||
3592 | 3615 | ||
3593 | /* DISPC HW IP initialisation */ | 3616 | /* DISPC HW IP initialisation */ |
3594 | static int __init omap_dispchw_probe(struct platform_device *pdev) | 3617 | static int __init omap_dispchw_probe(struct platform_device *pdev) |
diff --git a/drivers/video/omap2/dss/dss.h b/drivers/video/omap2/dss/dss.h index 1d8483cbe395..ebe9e08b2a91 100644 --- a/drivers/video/omap2/dss/dss.h +++ b/drivers/video/omap2/dss/dss.h | |||
@@ -365,16 +365,6 @@ void dpi_uninit_platform_driver(void) __exit; | |||
365 | int dispc_init_platform_driver(void) __init; | 365 | int dispc_init_platform_driver(void) __init; |
366 | void dispc_uninit_platform_driver(void) __exit; | 366 | void dispc_uninit_platform_driver(void) __exit; |
367 | void dispc_dump_clocks(struct seq_file *s); | 367 | void dispc_dump_clocks(struct seq_file *s); |
368 | u32 dispc_read_irqstatus(void); | ||
369 | void dispc_clear_irqstatus(u32 mask); | ||
370 | u32 dispc_read_irqenable(void); | ||
371 | void dispc_write_irqenable(u32 mask); | ||
372 | |||
373 | int dispc_request_irq(irq_handler_t handler, void *dev_id); | ||
374 | void dispc_free_irq(void *dev_id); | ||
375 | |||
376 | int dispc_runtime_get(void); | ||
377 | void dispc_runtime_put(void); | ||
378 | 368 | ||
379 | void dispc_enable_sidle(void); | 369 | void dispc_enable_sidle(void); |
380 | void dispc_disable_sidle(void); | 370 | void dispc_disable_sidle(void); |
@@ -398,29 +388,7 @@ void dispc_ovl_set_fifo_threshold(enum omap_plane plane, u32 low, u32 high); | |||
398 | void dispc_ovl_compute_fifo_thresholds(enum omap_plane plane, | 388 | void dispc_ovl_compute_fifo_thresholds(enum omap_plane plane, |
399 | u32 *fifo_low, u32 *fifo_high, bool use_fifomerge, | 389 | u32 *fifo_low, u32 *fifo_high, bool use_fifomerge, |
400 | bool manual_update); | 390 | bool manual_update); |
401 | int dispc_ovl_setup(enum omap_plane plane, const struct omap_overlay_info *oi, | 391 | |
402 | bool replication, const struct omap_video_timings *mgr_timings, | ||
403 | bool mem_to_mem); | ||
404 | int dispc_ovl_enable(enum omap_plane plane, bool enable); | ||
405 | bool dispc_ovl_enabled(enum omap_plane plane); | ||
406 | void dispc_ovl_set_channel_out(enum omap_plane plane, | ||
407 | enum omap_channel channel); | ||
408 | int dispc_ovl_check(enum omap_plane plane, enum omap_channel channel, | ||
409 | const struct omap_overlay_info *oi, | ||
410 | const struct omap_video_timings *timings, | ||
411 | int *x_predecim, int *y_predecim); | ||
412 | |||
413 | u32 dispc_mgr_get_vsync_irq(enum omap_channel channel); | ||
414 | u32 dispc_mgr_get_framedone_irq(enum omap_channel channel); | ||
415 | u32 dispc_mgr_get_sync_lost_irq(enum omap_channel channel); | ||
416 | bool dispc_mgr_go_busy(enum omap_channel channel); | ||
417 | void dispc_mgr_go(enum omap_channel channel); | ||
418 | void dispc_mgr_enable(enum omap_channel channel, bool enable); | ||
419 | bool dispc_mgr_is_enabled(enum omap_channel channel); | ||
420 | void dispc_mgr_set_lcd_config(enum omap_channel channel, | ||
421 | const struct dss_lcd_mgr_config *config); | ||
422 | void dispc_mgr_set_timings(enum omap_channel channel, | ||
423 | const struct omap_video_timings *timings); | ||
424 | unsigned long dispc_mgr_lclk_rate(enum omap_channel channel); | 392 | unsigned long dispc_mgr_lclk_rate(enum omap_channel channel); |
425 | unsigned long dispc_mgr_pclk_rate(enum omap_channel channel); | 393 | unsigned long dispc_mgr_pclk_rate(enum omap_channel channel); |
426 | unsigned long dispc_core_clk_rate(void); | 394 | unsigned long dispc_core_clk_rate(void); |
@@ -428,8 +396,6 @@ void dispc_mgr_set_clock_div(enum omap_channel channel, | |||
428 | const struct dispc_clock_info *cinfo); | 396 | const struct dispc_clock_info *cinfo); |
429 | int dispc_mgr_get_clock_div(enum omap_channel channel, | 397 | int dispc_mgr_get_clock_div(enum omap_channel channel, |
430 | struct dispc_clock_info *cinfo); | 398 | struct dispc_clock_info *cinfo); |
431 | void dispc_mgr_setup(enum omap_channel channel, | ||
432 | const struct omap_overlay_manager_info *info); | ||
433 | 399 | ||
434 | u32 dispc_wb_get_framedone_irq(void); | 400 | u32 dispc_wb_get_framedone_irq(void); |
435 | bool dispc_wb_go_busy(void); | 401 | bool dispc_wb_go_busy(void); |
diff --git a/include/video/omapdss.h b/include/video/omapdss.h index 8c9df4867273..caefa093337d 100644 --- a/include/video/omapdss.h +++ b/include/video/omapdss.h | |||
@@ -21,6 +21,7 @@ | |||
21 | #include <linux/list.h> | 21 | #include <linux/list.h> |
22 | #include <linux/kobject.h> | 22 | #include <linux/kobject.h> |
23 | #include <linux/device.h> | 23 | #include <linux/device.h> |
24 | #include <linux/interrupt.h> | ||
24 | 25 | ||
25 | #define DISPC_IRQ_FRAMEDONE (1 << 0) | 26 | #define DISPC_IRQ_FRAMEDONE (1 << 0) |
26 | #define DISPC_IRQ_VSYNC (1 << 1) | 27 | #define DISPC_IRQ_VSYNC (1 << 1) |
@@ -784,6 +785,44 @@ typedef void (*omap_dispc_isr_t) (void *arg, u32 mask); | |||
784 | int omap_dispc_register_isr(omap_dispc_isr_t isr, void *arg, u32 mask); | 785 | int omap_dispc_register_isr(omap_dispc_isr_t isr, void *arg, u32 mask); |
785 | int omap_dispc_unregister_isr(omap_dispc_isr_t isr, void *arg, u32 mask); | 786 | int omap_dispc_unregister_isr(omap_dispc_isr_t isr, void *arg, u32 mask); |
786 | 787 | ||
788 | u32 dispc_read_irqstatus(void); | ||
789 | void dispc_clear_irqstatus(u32 mask); | ||
790 | u32 dispc_read_irqenable(void); | ||
791 | void dispc_write_irqenable(u32 mask); | ||
792 | |||
793 | int dispc_request_irq(irq_handler_t handler, void *dev_id); | ||
794 | void dispc_free_irq(void *dev_id); | ||
795 | |||
796 | int dispc_runtime_get(void); | ||
797 | void dispc_runtime_put(void); | ||
798 | |||
799 | void dispc_mgr_enable(enum omap_channel channel, bool enable); | ||
800 | bool dispc_mgr_is_enabled(enum omap_channel channel); | ||
801 | u32 dispc_mgr_get_vsync_irq(enum omap_channel channel); | ||
802 | u32 dispc_mgr_get_framedone_irq(enum omap_channel channel); | ||
803 | u32 dispc_mgr_get_sync_lost_irq(enum omap_channel channel); | ||
804 | bool dispc_mgr_go_busy(enum omap_channel channel); | ||
805 | void dispc_mgr_go(enum omap_channel channel); | ||
806 | void dispc_mgr_set_lcd_config(enum omap_channel channel, | ||
807 | const struct dss_lcd_mgr_config *config); | ||
808 | void dispc_mgr_set_timings(enum omap_channel channel, | ||
809 | const struct omap_video_timings *timings); | ||
810 | void dispc_mgr_setup(enum omap_channel channel, | ||
811 | const struct omap_overlay_manager_info *info); | ||
812 | |||
813 | int dispc_ovl_check(enum omap_plane plane, enum omap_channel channel, | ||
814 | const struct omap_overlay_info *oi, | ||
815 | const struct omap_video_timings *timings, | ||
816 | int *x_predecim, int *y_predecim); | ||
817 | |||
818 | int dispc_ovl_enable(enum omap_plane plane, bool enable); | ||
819 | bool dispc_ovl_enabled(enum omap_plane plane); | ||
820 | void dispc_ovl_set_channel_out(enum omap_plane plane, | ||
821 | enum omap_channel channel); | ||
822 | int dispc_ovl_setup(enum omap_plane plane, const struct omap_overlay_info *oi, | ||
823 | bool replication, const struct omap_video_timings *mgr_timings, | ||
824 | bool mem_to_mem); | ||
825 | |||
787 | #define to_dss_driver(x) container_of((x), struct omap_dss_driver, driver) | 826 | #define to_dss_driver(x) container_of((x), struct omap_dss_driver, driver) |
788 | #define to_dss_device(x) container_of((x), struct omap_dss_device, dev) | 827 | #define to_dss_device(x) container_of((x), struct omap_dss_device, dev) |
789 | 828 | ||