Lines Matching +full:display +full:- +full:timings

1 // SPDX-License-Identifier: GPL-2.0-only
3 * linux/drivers/video/omap2/omapfb-main.c
16 #include <linux/dma-mapping.h>
56 struct fb_var_screeninfo *var = &fbi->var; in draw_pixel()
57 struct fb_fix_screeninfo *fix = &fbi->fix; in draw_pixel()
58 void __iomem *addr = fbi->screen_base; in draw_pixel()
59 const unsigned bytespp = var->bits_per_pixel >> 3; in draw_pixel()
60 const unsigned line_len = fix->line_length / bytespp; in draw_pixel()
66 if (var->bits_per_pixel == 16) { in draw_pixel()
75 } else if (var->bits_per_pixel == 24) { in draw_pixel()
82 } else if (var->bits_per_pixel == 32) { in draw_pixel()
91 struct fb_var_screeninfo *var = &fbi->var; in fill_fb()
92 const short w = var->xres_virtual; in fill_fb()
93 const short h = var->yres_virtual; in fill_fb()
94 void __iomem *addr = fbi->screen_base; in fill_fb()
100 DBG("fill_fb %dx%d, line_len %d bytes\n", w, h, fbi->fix.line_length); in fill_fb()
106 else if (x < 20 && (y > 20 && y < h - 20)) in fill_fb()
108 else if (y < 20 && (x > 20 && x < w - 20)) in fill_fb()
110 else if (x > w - 20 && (y > 20 && y < h - 20)) in fill_fb()
112 else if (y > h - 20 && (x > 20 && x < w - 20)) in fill_fb()
114 else if (x == 20 || x == w - 20 || in fill_fb()
115 y == 20 || y == h - 20) in fill_fb()
117 else if (x == y || w - x == h - y) in fill_fb()
119 else if (w - x == y || x == h - y) in fill_fb()
121 else if (x > 20 && y > 20 && x < w - 20 && y < h - 20) { in fill_fb()
125 if (var->bits_per_pixel == 16) { in fill_fb()
152 const struct vrfb *vrfb = &ofbi->region->vrfb; in omapfb_get_vrfb_offset()
160 offset = vrfb->yoffset; in omapfb_get_vrfb_offset()
163 offset = vrfb->yoffset * OMAP_VRFB_LINE_LEN + vrfb->xoffset; in omapfb_get_vrfb_offset()
166 offset = vrfb->xoffset * OMAP_VRFB_LINE_LEN; in omapfb_get_vrfb_offset()
173 offset *= vrfb->bytespp; in omapfb_get_vrfb_offset()
180 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) { in omapfb_get_region_rot_paddr()
181 return ofbi->region->vrfb.paddr[rot] in omapfb_get_region_rot_paddr()
184 return ofbi->region->paddr; in omapfb_get_region_rot_paddr()
190 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) in omapfb_get_region_paddr()
191 return ofbi->region->vrfb.paddr[0]; in omapfb_get_region_paddr()
193 return ofbi->region->paddr; in omapfb_get_region_paddr()
198 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) in omapfb_get_region_vaddr()
199 return ofbi->region->vrfb.vaddr[0]; in omapfb_get_region_vaddr()
201 return ofbi->region->vaddr; in omapfb_get_region_vaddr()
267 return f1->length == f2->length && in cmp_component()
268 f1->offset == f2->offset && in cmp_component()
269 f1->msb_right == f2->msb_right; in cmp_component()
275 if (var->bits_per_pixel == 0 || in cmp_var_to_colormode()
276 var->red.length == 0 || in cmp_var_to_colormode()
277 var->blue.length == 0 || in cmp_var_to_colormode()
278 var->green.length == 0) in cmp_var_to_colormode()
281 return var->bits_per_pixel == color->bits_per_pixel && in cmp_var_to_colormode()
282 cmp_component(&var->red, &color->red) && in cmp_var_to_colormode()
283 cmp_component(&var->green, &color->green) && in cmp_var_to_colormode()
284 cmp_component(&var->blue, &color->blue) && in cmp_var_to_colormode()
285 cmp_component(&var->transp, &color->transp); in cmp_var_to_colormode()
291 var->bits_per_pixel = color->bits_per_pixel; in assign_colormode_to_var()
292 var->nonstd = color->nonstd; in assign_colormode_to_var()
293 var->red = color->red; in assign_colormode_to_var()
294 var->green = color->green; in assign_colormode_to_var()
295 var->blue = color->blue; in assign_colormode_to_var()
296 var->transp = color->transp; in assign_colormode_to_var()
306 if (var->nonstd) { in fb_mode_to_dss_mode()
309 if (var->nonstd == m->nonstd) { in fb_mode_to_dss_mode()
311 *mode = m->dssmode; in fb_mode_to_dss_mode()
316 return -EINVAL; in fb_mode_to_dss_mode()
324 *mode = m->dssmode; in fb_mode_to_dss_mode()
331 switch (var->bits_per_pixel) { in fb_mode_to_dss_mode()
357 return -EINVAL; in fb_mode_to_dss_mode()
362 if (dssmode == m->dssmode) { in fb_mode_to_dss_mode()
364 *mode = m->dssmode; in fb_mode_to_dss_mode()
369 return -EINVAL; in fb_mode_to_dss_mode()
380 if (var->xres_virtual == 0) in check_fb_res_bounds()
381 var->xres_virtual = var->xres; in check_fb_res_bounds()
383 if (var->yres_virtual == 0) in check_fb_res_bounds()
384 var->yres_virtual = var->yres; in check_fb_res_bounds()
386 if (var->xres_virtual < xres_min || var->yres_virtual < yres_min) in check_fb_res_bounds()
387 return -EINVAL; in check_fb_res_bounds()
389 if (var->xres < xres_min) in check_fb_res_bounds()
390 var->xres = xres_min; in check_fb_res_bounds()
391 if (var->yres < yres_min) in check_fb_res_bounds()
392 var->yres = yres_min; in check_fb_res_bounds()
393 if (var->xres > xres_max) in check_fb_res_bounds()
394 var->xres = xres_max; in check_fb_res_bounds()
395 if (var->yres > yres_max) in check_fb_res_bounds()
396 var->yres = yres_max; in check_fb_res_bounds()
398 if (var->xres > var->xres_virtual) in check_fb_res_bounds()
399 var->xres = var->xres_virtual; in check_fb_res_bounds()
400 if (var->yres > var->yres_virtual) in check_fb_res_bounds()
401 var->yres = var->yres_virtual; in check_fb_res_bounds()
410 var->yres_virtual = max_frame_size / in shrink_height()
411 (var->xres_virtual * var->bits_per_pixel >> 3); in shrink_height()
413 if (var->yres_virtual < OMAPFB_PLANE_YRES_MIN) in shrink_height()
414 var->yres_virtual = OMAPFB_PLANE_YRES_MIN; in shrink_height()
416 if (var->yres > var->yres_virtual) in shrink_height()
417 var->yres = var->yres_virtual; in shrink_height()
424 var->xres_virtual = max_frame_size / var->yres_virtual / in shrink_width()
425 (var->bits_per_pixel >> 3); in shrink_width()
427 if (var->xres_virtual < OMAPFB_PLANE_XRES_MIN) in shrink_width()
428 var->xres_virtual = OMAPFB_PLANE_XRES_MIN; in shrink_width()
430 if (var->xres > var->xres_virtual) in shrink_width()
431 var->xres = var->xres_virtual; in shrink_width()
437 unsigned long min_phys_size = omap_vrfb_min_phys_size(var->xres_virtual, in check_vrfb_fb_size()
438 var->yres_virtual, var->bits_per_pixel >> 3); in check_vrfb_fb_size()
440 return min_phys_size > region_size ? -EINVAL : 0; in check_vrfb_fb_size()
446 unsigned long max_frame_size = ofbi->region->size; in check_fb_size()
447 int bytespp = var->bits_per_pixel >> 3; in check_fb_size()
448 unsigned long line_size = var->xres_virtual * bytespp; in check_fb_size()
450 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) { in check_fb_size()
454 max_frame_size, var->xres_virtual, bytespp) * in check_fb_size()
459 return -EINVAL; in check_fb_size()
467 if (line_size * var->yres_virtual > max_frame_size) in check_fb_size()
470 if (line_size * var->yres_virtual > max_frame_size) { in check_fb_size()
472 line_size = var->xres_virtual * bytespp; in check_fb_size()
475 if (line_size * var->yres_virtual > max_frame_size) { in check_fb_size()
477 return -EINVAL; in check_fb_size()
493 struct omapfb2_mem_region *rg = ofbi->region; in setup_vrfb_rotation()
494 struct vrfb *vrfb = &rg->vrfb; in setup_vrfb_rotation()
495 struct fb_var_screeninfo *var = &fbi->var; in setup_vrfb_rotation()
496 struct fb_fix_screeninfo *fix = &fbi->fix; in setup_vrfb_rotation()
503 if (!rg->size || ofbi->rotation_type != OMAP_DSS_ROT_VRFB) in setup_vrfb_rotation()
512 bytespp = var->bits_per_pixel >> 3; in setup_vrfb_rotation()
523 if (yuv_mode != vrfb->yuv_mode) in setup_vrfb_rotation()
525 else if (bytespp != vrfb->bytespp) in setup_vrfb_rotation()
527 else if (vrfb->xres != var->xres_virtual || in setup_vrfb_rotation()
528 vrfb->yres != var->yres_virtual) in setup_vrfb_rotation()
531 if (vrfb->vaddr[0] && reconf) { in setup_vrfb_rotation()
532 fbi->screen_base = NULL; in setup_vrfb_rotation()
533 fix->smem_start = 0; in setup_vrfb_rotation()
534 fix->smem_len = 0; in setup_vrfb_rotation()
535 iounmap(vrfb->vaddr[0]); in setup_vrfb_rotation()
536 vrfb->vaddr[0] = NULL; in setup_vrfb_rotation()
540 if (vrfb->vaddr[0]) in setup_vrfb_rotation()
543 omap_vrfb_setup(&rg->vrfb, rg->paddr, in setup_vrfb_rotation()
544 var->xres_virtual, in setup_vrfb_rotation()
545 var->yres_virtual, in setup_vrfb_rotation()
549 r = omap_vrfb_map_angle(vrfb, var->yres_virtual, 0); in setup_vrfb_rotation()
554 fbi->screen_base = ofbi->region->vrfb.vaddr[0]; in setup_vrfb_rotation()
556 fix->smem_start = ofbi->region->vrfb.paddr[0]; in setup_vrfb_rotation()
558 switch (var->nonstd) { in setup_vrfb_rotation()
561 fix->line_length = in setup_vrfb_rotation()
562 (OMAP_VRFB_LINE_LEN * var->bits_per_pixel) >> 2; in setup_vrfb_rotation()
565 fix->line_length = in setup_vrfb_rotation()
566 (OMAP_VRFB_LINE_LEN * var->bits_per_pixel) >> 3; in setup_vrfb_rotation()
570 fix->smem_len = var->yres_virtual * fix->line_length; in setup_vrfb_rotation()
582 if (dssmode == mode->dssmode) { in dss_mode_to_fb_mode()
587 return -ENOENT; in dss_mode_to_fb_mode()
592 struct fb_fix_screeninfo *fix = &fbi->fix; in set_fb_fix()
593 struct fb_var_screeninfo *var = &fbi->var; in set_fb_fix()
595 struct omapfb2_mem_region *rg = ofbi->region; in set_fb_fix()
600 fbi->screen_base = (char __iomem *)omapfb_get_region_vaddr(ofbi); in set_fb_fix()
603 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) { in set_fb_fix()
604 switch (var->nonstd) { in set_fb_fix()
607 fix->line_length = in set_fb_fix()
608 (OMAP_VRFB_LINE_LEN * var->bits_per_pixel) >> 2; in set_fb_fix()
611 fix->line_length = in set_fb_fix()
612 (OMAP_VRFB_LINE_LEN * var->bits_per_pixel) >> 3; in set_fb_fix()
616 fix->smem_len = var->yres_virtual * fix->line_length; in set_fb_fix()
618 fix->line_length = in set_fb_fix()
619 (var->xres_virtual * var->bits_per_pixel) >> 3; in set_fb_fix()
620 fix->smem_len = rg->size; in set_fb_fix()
623 fix->smem_start = omapfb_get_region_paddr(ofbi); in set_fb_fix()
625 fix->type = FB_TYPE_PACKED_PIXELS; in set_fb_fix()
627 if (var->nonstd) in set_fb_fix()
628 fix->visual = FB_VISUAL_PSEUDOCOLOR; in set_fb_fix()
630 switch (var->bits_per_pixel) { in set_fb_fix()
635 fix->visual = FB_VISUAL_TRUECOLOR; in set_fb_fix()
642 fix->visual = FB_VISUAL_PSEUDOCOLOR; in set_fb_fix()
647 fix->accel = FB_ACCEL_NONE; in set_fb_fix()
649 fix->xpanstep = 1; in set_fb_fix()
650 fix->ypanstep = 1; in set_fb_fix()
657 struct omap_dss_device *display = fb2display(fbi); in check_fb_var() local
662 DBG("check_fb_var %d\n", ofbi->id); in check_fb_var()
664 WARN_ON(!atomic_read(&ofbi->region->lock_count)); in check_fb_var()
672 for (i = 0; i < ofbi->num_overlays; ++i) { in check_fb_var()
673 if ((ofbi->overlays[i]->supported_modes & mode) == 0) { in check_fb_var()
675 return -EINVAL; in check_fb_var()
679 if (var->rotate > 3) in check_fb_var()
680 return -EINVAL; in check_fb_var()
683 return -EINVAL; in check_fb_var()
686 if (ofbi->region->size != 0 && check_fb_size(ofbi, var)) in check_fb_var()
687 return -EINVAL; in check_fb_var()
689 if (var->xres + var->xoffset > var->xres_virtual) in check_fb_var()
690 var->xoffset = var->xres_virtual - var->xres; in check_fb_var()
691 if (var->yres + var->yoffset > var->yres_virtual) in check_fb_var()
692 var->yoffset = var->yres_virtual - var->yres; in check_fb_var()
695 var->xres, var->yres, in check_fb_var()
696 var->xres_virtual, var->yres_virtual); in check_fb_var()
698 if (display && display->driver->get_dimensions) { in check_fb_var()
700 display->driver->get_dimensions(display, &w, &h); in check_fb_var()
701 var->width = DIV_ROUND_CLOSEST(w, 1000); in check_fb_var()
702 var->height = DIV_ROUND_CLOSEST(h, 1000); in check_fb_var()
704 var->height = -1; in check_fb_var()
705 var->width = -1; in check_fb_var()
708 var->grayscale = 0; in check_fb_var()
710 if (display && display->driver->get_timings) { in check_fb_var()
711 struct omap_video_timings timings; in check_fb_var() local
712 display->driver->get_timings(display, &timings); in check_fb_var()
715 var->pixclock = timings.pixelclock != 0 ? in check_fb_var()
716 KHZ2PICOS(timings.pixelclock / 1000) : in check_fb_var()
718 var->left_margin = timings.hbp; in check_fb_var()
719 var->right_margin = timings.hfp; in check_fb_var()
720 var->upper_margin = timings.vbp; in check_fb_var()
721 var->lower_margin = timings.vfp; in check_fb_var()
722 var->hsync_len = timings.hsw; in check_fb_var()
723 var->vsync_len = timings.vsw; in check_fb_var()
724 var->sync |= timings.hsync_level == OMAPDSS_SIG_ACTIVE_HIGH ? in check_fb_var()
726 var->sync |= timings.vsync_level == OMAPDSS_SIG_ACTIVE_HIGH ? in check_fb_var()
728 var->vmode = timings.interlace ? in check_fb_var()
731 var->pixclock = 0; in check_fb_var()
732 var->left_margin = 0; in check_fb_var()
733 var->right_margin = 0; in check_fb_var()
734 var->upper_margin = 0; in check_fb_var()
735 var->lower_margin = 0; in check_fb_var()
736 var->hsync_len = 0; in check_fb_var()
737 var->vsync_len = 0; in check_fb_var()
738 var->sync = 0; in check_fb_var()
739 var->vmode = FB_VMODE_NONINTERLACED; in check_fb_var()
746 * ---------------------------------------------------------------------------
748 * ---------------------------------------------------------------------------
765 offset = var->yoffset * fix->line_length + in calc_rotation_offset_dma()
766 var->xoffset * (var->bits_per_pixel >> 3); in calc_rotation_offset_dma()
777 offset = (var->yres_virtual - var->yres) * in calc_rotation_offset_vrfb()
778 fix->line_length; in calc_rotation_offset_vrfb()
780 offset = (var->yres_virtual - var->yres) * in calc_rotation_offset_vrfb()
781 (var->bits_per_pixel >> 3); in calc_rotation_offset_vrfb()
786 offset += var->yoffset * fix->line_length + in calc_rotation_offset_vrfb()
787 var->xoffset * (var->bits_per_pixel >> 3); in calc_rotation_offset_vrfb()
789 offset -= var->yoffset * fix->line_length + in calc_rotation_offset_vrfb()
790 var->xoffset * (var->bits_per_pixel >> 3); in calc_rotation_offset_vrfb()
792 offset -= var->xoffset * fix->line_length + in calc_rotation_offset_vrfb()
793 var->yoffset * (var->bits_per_pixel >> 3); in calc_rotation_offset_vrfb()
795 offset += var->xoffset * fix->line_length + in calc_rotation_offset_vrfb()
796 var->yoffset * (var->bits_per_pixel >> 3); in calc_rotation_offset_vrfb()
809 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) in omapfb_calc_addr()
814 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) in omapfb_calc_addr()
823 var->xoffset, var->yoffset, offset); in omapfb_calc_addr()
836 struct fb_var_screeninfo *var = &fbi->var; in omapfb_setup_overlay()
837 struct fb_fix_screeninfo *fix = &fbi->fix; in omapfb_setup_overlay()
844 int rotation = var->rotate; in omapfb_setup_overlay()
847 WARN_ON(!atomic_read(&ofbi->region->lock_count)); in omapfb_setup_overlay()
849 for (i = 0; i < ofbi->num_overlays; i++) { in omapfb_setup_overlay()
850 if (ovl != ofbi->overlays[i]) in omapfb_setup_overlay()
853 rotation = (rotation + ofbi->rotation[i]) % 4; in omapfb_setup_overlay()
857 DBG("setup_overlay %d, posx %d, posy %d, outw %d, outh %d\n", ofbi->id, in omapfb_setup_overlay()
861 xres = var->yres; in omapfb_setup_overlay()
862 yres = var->xres; in omapfb_setup_overlay()
864 xres = var->xres; in omapfb_setup_overlay()
865 yres = var->yres; in omapfb_setup_overlay()
868 if (ofbi->region->size) in omapfb_setup_overlay()
877 switch (var->nonstd) { in omapfb_setup_overlay()
880 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) { in omapfb_setup_overlay()
881 screen_width = fix->line_length in omapfb_setup_overlay()
882 / (var->bits_per_pixel >> 2); in omapfb_setup_overlay()
887 screen_width = fix->line_length / (var->bits_per_pixel >> 3); in omapfb_setup_overlay()
891 ovl->get_overlay_info(ovl, &info); in omapfb_setup_overlay()
893 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) in omapfb_setup_overlay()
896 mirror = ofbi->mirror; in omapfb_setup_overlay()
903 info.rotation_type = ofbi->rotation_type; in omapfb_setup_overlay()
912 r = ovl->set_overlay_info(ovl, &info); in omapfb_setup_overlay()
914 DBG("ovl->setup_overlay_info failed\n"); in omapfb_setup_overlay()
930 struct fb_var_screeninfo *var = &fbi->var; in omapfb_apply_changes()
941 WARN_ON(!atomic_read(&ofbi->region->lock_count)); in omapfb_apply_changes()
943 for (i = 0; i < ofbi->num_overlays; i++) { in omapfb_apply_changes()
944 ovl = ofbi->overlays[i]; in omapfb_apply_changes()
946 DBG("apply_changes, fb %d, ovl %d\n", ofbi->id, ovl->id); in omapfb_apply_changes()
948 if (ofbi->region->size == 0) { in omapfb_apply_changes()
951 if (!init && ovl->manager) in omapfb_apply_changes()
952 ovl->manager->apply(ovl->manager); in omapfb_apply_changes()
956 if (init || (ovl->caps & OMAP_DSS_OVL_CAP_SCALE) == 0) { in omapfb_apply_changes()
957 int rotation = (var->rotate + ofbi->rotation[i]) % 4; in omapfb_apply_changes()
960 outw = var->yres; in omapfb_apply_changes()
961 outh = var->xres; in omapfb_apply_changes()
963 outw = var->xres; in omapfb_apply_changes()
964 outh = var->yres; in omapfb_apply_changes()
968 ovl->get_overlay_info(ovl, &info); in omapfb_apply_changes()
978 ovl->get_overlay_info(ovl, &info); in omapfb_apply_changes()
987 if (!init && ovl->manager) in omapfb_apply_changes()
988 ovl->manager->apply(ovl->manager); in omapfb_apply_changes()
1003 DBG("check_var(%d)\n", FB2OFB(fbi)->id); in omapfb_check_var()
1005 omapfb_get_mem_region(ofbi->region); in omapfb_check_var()
1009 omapfb_put_mem_region(ofbi->region); in omapfb_check_var()
1014 /* set the video mode according to info->var */
1020 DBG("set_par(%d)\n", FB2OFB(fbi)->id); in omapfb_set_par()
1022 omapfb_get_mem_region(ofbi->region); in omapfb_set_par()
1033 omapfb_put_mem_region(ofbi->region); in omapfb_set_par()
1045 DBG("pan_display(%d)\n", FB2OFB(fbi)->id); in omapfb_pan_display()
1047 if (var->xoffset == fbi->var.xoffset && in omapfb_pan_display()
1048 var->yoffset == fbi->var.yoffset) in omapfb_pan_display()
1051 new_var = fbi->var; in omapfb_pan_display()
1052 new_var.xoffset = var->xoffset; in omapfb_pan_display()
1053 new_var.yoffset = var->yoffset; in omapfb_pan_display()
1055 fbi->var = new_var; in omapfb_pan_display()
1057 omapfb_get_mem_region(ofbi->region); in omapfb_pan_display()
1061 omapfb_put_mem_region(ofbi->region); in omapfb_pan_display()
1068 struct omapfb2_mem_region *rg = vma->vm_private_data; in mmap_user_open()
1071 atomic_inc(&rg->map_count); in mmap_user_open()
1077 struct omapfb2_mem_region *rg = vma->vm_private_data; in mmap_user_close()
1080 atomic_dec(&rg->map_count); in mmap_user_close()
1092 struct fb_fix_screeninfo *fix = &fbi->fix; in omapfb_mmap()
1098 vma->vm_page_prot = pgprot_decrypted(vma->vm_page_prot); in omapfb_mmap()
1100 rg = omapfb_get_mem_region(ofbi->region); in omapfb_mmap()
1103 len = fix->smem_len; in omapfb_mmap()
1106 vma->vm_pgoff << PAGE_SHIFT); in omapfb_mmap()
1108 vma->vm_page_prot = pgprot_writecombine(vma->vm_page_prot); in omapfb_mmap()
1109 vma->vm_ops = &mmap_user_ops; in omapfb_mmap()
1110 vma->vm_private_data = rg; in omapfb_mmap()
1117 atomic_inc(&rg->map_count); in omapfb_mmap()
1124 omapfb_put_mem_region(ofbi->region); in omapfb_mmap()
1137 /*struct omapfb2_device *fbdev = ofbi->fbdev;*/ in _setcolreg()
1138 struct fb_var_screeninfo *var = &fbi->var; in _setcolreg()
1143 /*switch (plane->color_mode) {*/ in _setcolreg()
1148 r = -EINVAL; in _setcolreg()
1155 if (fbdev->ctrl->setcolreg) in _setcolreg()
1156 r = fbdev->ctrl->setcolreg(regno, red, green, blue, in _setcolreg()
1159 r = -EINVAL; in _setcolreg()
1167 pal = ((red >> (16 - var->red.length)) << in _setcolreg()
1168 var->red.offset) | in _setcolreg()
1169 ((green >> (16 - var->green.length)) << in _setcolreg()
1170 var->green.offset) | in _setcolreg()
1171 (blue >> (16 - var->blue.length)); in _setcolreg()
1172 ((u32 *)(fbi->pseudo_palette))[regno] = pal; in _setcolreg()
1197 red = cmap->red; in omapfb_setcmap()
1198 green = cmap->green; in omapfb_setcmap()
1199 blue = cmap->blue; in omapfb_setcmap()
1200 transp = cmap->transp; in omapfb_setcmap()
1201 index = cmap->start; in omapfb_setcmap()
1203 for (count = 0; count < cmap->len; count++) { in omapfb_setcmap()
1207 count == cmap->len - 1); in omapfb_setcmap()
1218 struct omapfb2_device *fbdev = ofbi->fbdev; in omapfb_blank()
1219 struct omap_dss_device *display = fb2display(fbi); in omapfb_blank() local
1223 if (!display) in omapfb_blank()
1224 return -EINVAL; in omapfb_blank()
1228 d = get_display_data(fbdev, display); in omapfb_blank()
1232 if (display->state == OMAP_DSS_DISPLAY_ACTIVE) in omapfb_blank()
1235 r = display->driver->enable(display); in omapfb_blank()
1237 if ((display->caps & OMAP_DSS_DISPLAY_CAP_MANUAL_UPDATE) && in omapfb_blank()
1238 d->update_mode == OMAPFB_AUTO_UPDATE && in omapfb_blank()
1239 !d->auto_update_work_enabled) in omapfb_blank()
1240 omapfb_start_auto_update(fbdev, display); in omapfb_blank()
1250 if (display->state != OMAP_DSS_DISPLAY_ACTIVE) in omapfb_blank()
1253 if (d->auto_update_work_enabled) in omapfb_blank()
1254 omapfb_stop_auto_update(fbdev, display); in omapfb_blank()
1256 display->driver->disable(display); in omapfb_blank()
1261 r = -EINVAL; in omapfb_blank()
1301 struct omapfb2_device *fbdev = ofbi->fbdev; in omapfb_free_fbmem()
1304 rg = ofbi->region; in omapfb_free_fbmem()
1306 if (rg->token == NULL) in omapfb_free_fbmem()
1309 WARN_ON(atomic_read(&rg->map_count)); in omapfb_free_fbmem()
1311 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) { in omapfb_free_fbmem()
1313 if (rg->vrfb.vaddr[0]) { in omapfb_free_fbmem()
1314 iounmap(rg->vrfb.vaddr[0]); in omapfb_free_fbmem()
1315 rg->vrfb.vaddr[0] = NULL; in omapfb_free_fbmem()
1318 omap_vrfb_release_ctx(&rg->vrfb); in omapfb_free_fbmem()
1321 dma_free_attrs(fbdev->dev, rg->size, rg->token, rg->dma_handle, in omapfb_free_fbmem()
1322 rg->attrs); in omapfb_free_fbmem()
1324 rg->token = NULL; in omapfb_free_fbmem()
1325 rg->vaddr = NULL; in omapfb_free_fbmem()
1326 rg->paddr = 0; in omapfb_free_fbmem()
1327 rg->alloc = 0; in omapfb_free_fbmem()
1328 rg->size = 0; in omapfb_free_fbmem()
1333 memset(&fbi->var, 0, sizeof(fbi->var)); in clear_fb_info()
1334 memset(&fbi->fix, 0, sizeof(fbi->fix)); in clear_fb_info()
1335 strscpy(fbi->fix.id, MODULE_NAME, sizeof(fbi->fix.id)); in clear_fb_info()
1344 for (i = 0; i < fbdev->num_fbs; i++) { in omapfb_free_all_fbmem()
1345 struct fb_info *fbi = fbdev->fbs[i]; in omapfb_free_all_fbmem()
1357 struct omapfb2_device *fbdev = ofbi->fbdev; in omapfb_alloc_fbmem()
1364 rg = ofbi->region; in omapfb_alloc_fbmem()
1366 rg->paddr = 0; in omapfb_alloc_fbmem()
1367 rg->vaddr = NULL; in omapfb_alloc_fbmem()
1368 memset(&rg->vrfb, 0, sizeof rg->vrfb); in omapfb_alloc_fbmem()
1369 rg->size = 0; in omapfb_alloc_fbmem()
1370 rg->type = 0; in omapfb_alloc_fbmem()
1371 rg->alloc = false; in omapfb_alloc_fbmem()
1372 rg->map = false; in omapfb_alloc_fbmem()
1378 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) in omapfb_alloc_fbmem()
1381 DBG("allocating %lu bytes for fb %d\n", size, ofbi->id); in omapfb_alloc_fbmem()
1383 token = dma_alloc_attrs(fbdev->dev, size, &dma_handle, in omapfb_alloc_fbmem()
1387 dev_err(fbdev->dev, "failed to allocate framebuffer\n"); in omapfb_alloc_fbmem()
1388 return -ENOMEM; in omapfb_alloc_fbmem()
1394 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) { in omapfb_alloc_fbmem()
1395 r = omap_vrfb_request_ctx(&rg->vrfb); in omapfb_alloc_fbmem()
1397 dma_free_attrs(fbdev->dev, size, token, dma_handle, in omapfb_alloc_fbmem()
1399 dev_err(fbdev->dev, "vrfb create ctx failed\n"); in omapfb_alloc_fbmem()
1404 rg->attrs = attrs; in omapfb_alloc_fbmem()
1405 rg->token = token; in omapfb_alloc_fbmem()
1406 rg->dma_handle = dma_handle; in omapfb_alloc_fbmem()
1408 rg->paddr = (unsigned long)dma_handle; in omapfb_alloc_fbmem()
1409 rg->vaddr = (void __iomem *)token; in omapfb_alloc_fbmem()
1410 rg->size = size; in omapfb_alloc_fbmem()
1411 rg->alloc = 1; in omapfb_alloc_fbmem()
1416 /* allocate fbmem using display resolution as reference */
1421 struct omapfb2_device *fbdev = ofbi->fbdev; in omapfb_alloc_fbmem_display()
1422 struct omap_dss_device *display; in omapfb_alloc_fbmem_display() local
1425 display = fb2display(fbi); in omapfb_alloc_fbmem_display()
1427 if (!display) in omapfb_alloc_fbmem_display()
1430 switch (omapfb_get_recommended_bpp(fbdev, display)) { in omapfb_alloc_fbmem_display()
1445 display->driver->get_resolution(display, &w, &h); in omapfb_alloc_fbmem_display()
1447 if (ofbi->rotation_type == OMAP_DSS_ROT_VRFB) { in omapfb_alloc_fbmem_display()
1451 DBG("adjusting fb mem size for VRFB, %u -> %lu\n", in omapfb_alloc_fbmem_display()
1480 return -EINVAL; in omapfb_parse_vram_param()
1483 return -EINVAL; in omapfb_parse_vram_param()
1486 return -EINVAL; in omapfb_parse_vram_param()
1491 return -EINVAL; in omapfb_parse_vram_param()
1499 return -EINVAL; in omapfb_parse_vram_param()
1513 return -EINVAL; in omapfb_parse_vram_param()
1534 dev_err(fbdev->dev, "failed to parse vram parameter\n"); in omapfb_allocate_all_fbs()
1540 for (i = 0; i < fbdev->num_fbs; i++) { in omapfb_allocate_all_fbs()
1544 r = omapfb_alloc_fbmem_display(fbdev->fbs[i], in omapfb_allocate_all_fbs()
1552 for (i = 0; i < fbdev->num_fbs; i++) { in omapfb_allocate_all_fbs()
1553 struct omapfb_info *ofbi = FB2OFB(fbdev->fbs[i]); in omapfb_allocate_all_fbs()
1555 rg = ofbi->region; in omapfb_allocate_all_fbs()
1559 rg->paddr, in omapfb_allocate_all_fbs()
1560 rg->vaddr, in omapfb_allocate_all_fbs()
1561 rg->size); in omapfb_allocate_all_fbs()
1572 .width = fbi->var.xres_virtual, in omapfb_clear_fb()
1573 .height = fbi->var.yres_virtual, in omapfb_clear_fb()
1584 struct omapfb2_device *fbdev = ofbi->fbdev; in omapfb_realloc_fbmem()
1585 struct omapfb2_mem_region *rg = ofbi->region; in omapfb_realloc_fbmem()
1586 unsigned long old_size = rg->size; in omapfb_realloc_fbmem()
1587 unsigned long old_paddr = rg->paddr; in omapfb_realloc_fbmem()
1588 int old_type = rg->type; in omapfb_realloc_fbmem()
1592 return -EINVAL; in omapfb_realloc_fbmem()
1612 if (rg->size == 0) in omapfb_realloc_fbmem()
1622 DBG("initializing fb %d\n", ofbi->id); in omapfb_realloc_fbmem()
1635 memcpy(&new_var, &fbi->var, sizeof(new_var)); in omapfb_realloc_fbmem()
1639 memcpy(&fbi->var, &new_var, sizeof(fbi->var)); in omapfb_realloc_fbmem()
1667 dssdev = d->dssdev; in omapfb_auto_update_work()
1668 dssdrv = dssdev->driver; in omapfb_auto_update_work()
1669 fbdev = d->fbdev; in omapfb_auto_update_work()
1671 if (!dssdrv || !dssdrv->update) in omapfb_auto_update_work()
1674 if (dssdrv->sync) in omapfb_auto_update_work()
1675 dssdrv->sync(dssdev); in omapfb_auto_update_work()
1677 dssdrv->get_resolution(dssdev, &w, &h); in omapfb_auto_update_work()
1678 dssdrv->update(dssdev, 0, 0, w, h); in omapfb_auto_update_work()
1683 queue_delayed_work(fbdev->auto_update_wq, in omapfb_auto_update_work()
1684 &d->auto_update_work, HZ / freq); in omapfb_auto_update_work()
1688 struct omap_dss_device *display) in omapfb_start_auto_update() argument
1692 if (fbdev->auto_update_wq == NULL) { in omapfb_start_auto_update()
1698 dev_err(fbdev->dev, "Failed to create workqueue for " in omapfb_start_auto_update()
1699 "auto-update\n"); in omapfb_start_auto_update()
1703 fbdev->auto_update_wq = wq; in omapfb_start_auto_update()
1706 d = get_display_data(fbdev, display); in omapfb_start_auto_update()
1708 INIT_DELAYED_WORK(&d->auto_update_work, omapfb_auto_update_work); in omapfb_start_auto_update()
1710 d->auto_update_work_enabled = true; in omapfb_start_auto_update()
1712 omapfb_auto_update_work(&d->auto_update_work.work); in omapfb_start_auto_update()
1716 struct omap_dss_device *display) in omapfb_stop_auto_update() argument
1720 d = get_display_data(fbdev, display); in omapfb_stop_auto_update()
1722 cancel_delayed_work_sync(&d->auto_update_work); in omapfb_stop_auto_update()
1724 d->auto_update_work_enabled = false; in omapfb_stop_auto_update()
1727 /* initialize fb_info, var, fix to something sane based on the display */
1730 struct fb_var_screeninfo *var = &fbi->var; in omapfb_fb_init()
1731 struct omap_dss_device *display = fb2display(fbi); in omapfb_fb_init() local
1735 fbi->fbops = &omapfb_ops; in omapfb_fb_init()
1736 fbi->pseudo_palette = fbdev->pseudo_palette; in omapfb_fb_init()
1738 if (ofbi->region->size == 0) { in omapfb_fb_init()
1743 var->nonstd = 0; in omapfb_fb_init()
1744 var->bits_per_pixel = 0; in omapfb_fb_init()
1746 var->rotate = def_rotate; in omapfb_fb_init()
1748 if (display) { in omapfb_fb_init()
1750 int rotation = (var->rotate + ofbi->rotation[0]) % 4; in omapfb_fb_init()
1752 display->driver->get_resolution(display, &w, &h); in omapfb_fb_init()
1756 var->xres = h; in omapfb_fb_init()
1757 var->yres = w; in omapfb_fb_init()
1759 var->xres = w; in omapfb_fb_init()
1760 var->yres = h; in omapfb_fb_init()
1763 var->xres_virtual = var->xres; in omapfb_fb_init()
1764 var->yres_virtual = var->yres; in omapfb_fb_init()
1766 if (!var->bits_per_pixel) { in omapfb_fb_init()
1767 switch (omapfb_get_recommended_bpp(fbdev, display)) { in omapfb_fb_init()
1769 var->bits_per_pixel = 16; in omapfb_fb_init()
1772 var->bits_per_pixel = 32; in omapfb_fb_init()
1775 dev_err(fbdev->dev, "illegal display " in omapfb_fb_init()
1777 return -EINVAL; in omapfb_fb_init()
1781 /* if there's no display, let's just guess some basic values */ in omapfb_fb_init()
1782 var->xres = 320; in omapfb_fb_init()
1783 var->yres = 240; in omapfb_fb_init()
1784 var->xres_virtual = var->xres; in omapfb_fb_init()
1785 var->yres_virtual = var->yres; in omapfb_fb_init()
1786 if (!var->bits_per_pixel) in omapfb_fb_init()
1787 var->bits_per_pixel = 16; in omapfb_fb_init()
1799 r = fb_alloc_cmap(&fbi->cmap, 256, 0); in omapfb_fb_init()
1801 dev_err(fbdev->dev, "unable to allocate color map memory\n"); in omapfb_fb_init()
1809 fb_dealloc_cmap(&fbi->cmap); in fbinfo_cleanup()
1822 for (i = 0; i < fbdev->num_overlays; i++) { in omapfb_free_resources()
1823 struct omap_overlay *ovl = fbdev->overlays[i]; in omapfb_free_resources()
1825 ovl->disable(ovl); in omapfb_free_resources()
1827 if (ovl->manager) in omapfb_free_resources()
1828 ovl->unset_manager(ovl); in omapfb_free_resources()
1831 for (i = 0; i < fbdev->num_fbs; i++) in omapfb_free_resources()
1832 unregister_framebuffer(fbdev->fbs[i]); in omapfb_free_resources()
1837 for (i = 0; i < fbdev->num_fbs; i++) { in omapfb_free_resources()
1838 fbinfo_cleanup(fbdev, fbdev->fbs[i]); in omapfb_free_resources()
1839 framebuffer_release(fbdev->fbs[i]); in omapfb_free_resources()
1842 for (i = 0; i < fbdev->num_displays; i++) { in omapfb_free_resources()
1843 struct omap_dss_device *dssdev = fbdev->displays[i].dssdev; in omapfb_free_resources()
1845 if (fbdev->displays[i].auto_update_work_enabled) in omapfb_free_resources()
1848 if (dssdev->state != OMAP_DSS_DISPLAY_DISABLED) in omapfb_free_resources()
1849 dssdev->driver->disable(dssdev); in omapfb_free_resources()
1851 dssdev->driver->disconnect(dssdev); in omapfb_free_resources()
1856 if (fbdev->auto_update_wq != NULL) { in omapfb_free_resources()
1857 destroy_workqueue(fbdev->auto_update_wq); in omapfb_free_resources()
1858 fbdev->auto_update_wq = NULL; in omapfb_free_resources()
1861 dev_set_drvdata(fbdev->dev, NULL); in omapfb_free_resources()
1868 fbdev->num_fbs = 0; in omapfb_create_framebuffers()
1878 fbdev->dev); in omapfb_create_framebuffers()
1880 return -ENOMEM; in omapfb_create_framebuffers()
1884 fbdev->fbs[i] = fbi; in omapfb_create_framebuffers()
1887 ofbi->fbdev = fbdev; in omapfb_create_framebuffers()
1888 ofbi->id = i; in omapfb_create_framebuffers()
1890 ofbi->region = &fbdev->regions[i]; in omapfb_create_framebuffers()
1891 ofbi->region->id = i; in omapfb_create_framebuffers()
1892 init_rwsem(&ofbi->region->lock); in omapfb_create_framebuffers()
1895 ofbi->rotation_type = def_vrfb ? OMAP_DSS_ROT_VRFB : in omapfb_create_framebuffers()
1897 ofbi->mirror = def_mirror; in omapfb_create_framebuffers()
1899 fbdev->num_fbs++; in omapfb_create_framebuffers()
1905 for (i = 0; i < min(fbdev->num_fbs, fbdev->num_overlays); i++) { in omapfb_create_framebuffers()
1906 struct omapfb_info *ofbi = FB2OFB(fbdev->fbs[i]); in omapfb_create_framebuffers()
1908 ofbi->overlays[0] = fbdev->overlays[i]; in omapfb_create_framebuffers()
1909 ofbi->num_overlays = 1; in omapfb_create_framebuffers()
1915 dev_err(fbdev->dev, "failed to allocate fbmem\n"); in omapfb_create_framebuffers()
1922 for (i = 0; i < fbdev->num_fbs; i++) { in omapfb_create_framebuffers()
1923 struct fb_info *fbi = fbdev->fbs[i]; in omapfb_create_framebuffers()
1926 omapfb_get_mem_region(ofbi->region); in omapfb_create_framebuffers()
1928 omapfb_put_mem_region(ofbi->region); in omapfb_create_framebuffers()
1931 dev_err(fbdev->dev, "failed to setup fb_info\n"); in omapfb_create_framebuffers()
1936 for (i = 0; i < fbdev->num_fbs; i++) { in omapfb_create_framebuffers()
1937 struct fb_info *fbi = fbdev->fbs[i]; in omapfb_create_framebuffers()
1940 if (ofbi->region->size == 0) in omapfb_create_framebuffers()
1948 for (i = 0; i < fbdev->num_fbs; i++) { in omapfb_create_framebuffers()
1949 r = register_framebuffer(fbdev->fbs[i]); in omapfb_create_framebuffers()
1951 dev_err(fbdev->dev, in omapfb_create_framebuffers()
1959 for (i = 0; i < fbdev->num_fbs; i++) { in omapfb_create_framebuffers()
1960 struct fb_info *fbi = fbdev->fbs[i]; in omapfb_create_framebuffers()
1963 omapfb_get_mem_region(ofbi->region); in omapfb_create_framebuffers()
1965 omapfb_put_mem_region(ofbi->region); in omapfb_create_framebuffers()
1968 dev_err(fbdev->dev, "failed to change mode\n"); in omapfb_create_framebuffers()
1974 if (fbdev->num_fbs > 0) { in omapfb_create_framebuffers()
1975 struct omapfb_info *ofbi = FB2OFB(fbdev->fbs[0]); in omapfb_create_framebuffers()
1977 if (ofbi->num_overlays > 0) { in omapfb_create_framebuffers()
1978 struct omap_overlay *ovl = ofbi->overlays[0]; in omapfb_create_framebuffers()
1980 ovl->manager->apply(ovl->manager); in omapfb_create_framebuffers()
1985 dev_err(fbdev->dev, in omapfb_create_framebuffers()
1998 struct omap_dss_device *display, in omapfb_mode_to_timings() argument
1999 struct omap_video_timings *timings, u8 *bpp) in omapfb_mode_to_timings() argument
2008 *timings = omap_dss_pal_timings; in omapfb_mode_to_timings()
2012 *timings = omap_dss_ntsc_timings; in omapfb_mode_to_timings()
2028 r = -ENOMEM; in omapfb_mode_to_timings()
2034 r = -ENOMEM; in omapfb_mode_to_timings()
2040 r = -ENOMEM; in omapfb_mode_to_timings()
2044 fbi->fbops = fbops; in omapfb_mode_to_timings()
2048 r = -EINVAL; in omapfb_mode_to_timings()
2052 if (display->driver->get_timings) { in omapfb_mode_to_timings()
2053 display->driver->get_timings(display, timings); in omapfb_mode_to_timings()
2055 timings->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE; in omapfb_mode_to_timings()
2056 timings->de_level = OMAPDSS_SIG_ACTIVE_HIGH; in omapfb_mode_to_timings()
2057 timings->sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE; in omapfb_mode_to_timings()
2060 timings->pixelclock = PICOS2KHZ(var->pixclock) * 1000; in omapfb_mode_to_timings()
2061 timings->hbp = var->left_margin; in omapfb_mode_to_timings()
2062 timings->hfp = var->right_margin; in omapfb_mode_to_timings()
2063 timings->vbp = var->upper_margin; in omapfb_mode_to_timings()
2064 timings->vfp = var->lower_margin; in omapfb_mode_to_timings()
2065 timings->hsw = var->hsync_len; in omapfb_mode_to_timings()
2066 timings->vsw = var->vsync_len; in omapfb_mode_to_timings()
2067 timings->x_res = var->xres; in omapfb_mode_to_timings()
2068 timings->y_res = var->yres; in omapfb_mode_to_timings()
2069 timings->hsync_level = var->sync & FB_SYNC_HOR_HIGH_ACT ? in omapfb_mode_to_timings()
2072 timings->vsync_level = var->sync & FB_SYNC_VERT_HIGH_ACT ? in omapfb_mode_to_timings()
2075 timings->interlace = var->vmode & FB_VMODE_INTERLACED; in omapfb_mode_to_timings()
2077 switch (var->bits_per_pixel) { in omapfb_mode_to_timings()
2099 struct omap_dss_device *display, char *mode_str) in omapfb_set_def_mode() argument
2103 struct omap_video_timings timings, temp_timings; in omapfb_set_def_mode() local
2106 r = omapfb_mode_to_timings(mode_str, display, &timings, &bpp); in omapfb_set_def_mode()
2110 d = get_display_data(fbdev, display); in omapfb_set_def_mode()
2111 d->bpp_override = bpp; in omapfb_set_def_mode()
2113 if (display->driver->check_timings) { in omapfb_set_def_mode()
2114 r = display->driver->check_timings(display, &timings); in omapfb_set_def_mode()
2119 if (display->driver->get_timings) { in omapfb_set_def_mode()
2120 display->driver->get_timings(display, &temp_timings); in omapfb_set_def_mode()
2122 if (temp_timings.x_res != timings.x_res || in omapfb_set_def_mode()
2123 temp_timings.y_res != timings.y_res) in omapfb_set_def_mode()
2124 return -EINVAL; in omapfb_set_def_mode()
2128 if (display->driver->set_timings) in omapfb_set_def_mode()
2129 display->driver->set_timings(display, &timings); in omapfb_set_def_mode()
2139 BUG_ON(dssdev->driver->get_recommended_bpp == NULL); in omapfb_get_recommended_bpp()
2143 if (d->bpp_override != 0) in omapfb_get_recommended_bpp()
2144 return d->bpp_override; in omapfb_get_recommended_bpp()
2146 return dssdev->driver->get_recommended_bpp(dssdev); in omapfb_get_recommended_bpp()
2156 return -ENOMEM; in omapfb_parse_def_modes()
2161 struct omap_dss_device *display; in omapfb_parse_def_modes() local
2166 r = -EINVAL; in omapfb_parse_def_modes()
2174 display = NULL; in omapfb_parse_def_modes()
2175 for (i = 0; i < fbdev->num_displays; ++i) { in omapfb_parse_def_modes()
2176 if (strcmp(fbdev->displays[i].dssdev->name, in omapfb_parse_def_modes()
2178 display = fbdev->displays[i].dssdev; in omapfb_parse_def_modes()
2183 if (!display) { in omapfb_parse_def_modes()
2184 r = -EINVAL; in omapfb_parse_def_modes()
2188 r = omapfb_set_def_mode(fbdev, display, mode_str); in omapfb_parse_def_modes()
2199 struct omap_dss_device *display, in fb_videomode_to_omap_timings() argument
2202 if (display->driver->get_timings) { in fb_videomode_to_omap_timings()
2203 display->driver->get_timings(display, t); in fb_videomode_to_omap_timings()
2205 t->data_pclk_edge = OMAPDSS_DRIVE_SIG_RISING_EDGE; in fb_videomode_to_omap_timings()
2206 t->de_level = OMAPDSS_SIG_ACTIVE_HIGH; in fb_videomode_to_omap_timings()
2207 t->sync_pclk_edge = OMAPDSS_DRIVE_SIG_FALLING_EDGE; in fb_videomode_to_omap_timings()
2210 t->x_res = m->xres; in fb_videomode_to_omap_timings()
2211 t->y_res = m->yres; in fb_videomode_to_omap_timings()
2212 t->pixelclock = PICOS2KHZ(m->pixclock) * 1000; in fb_videomode_to_omap_timings()
2213 t->hsw = m->hsync_len; in fb_videomode_to_omap_timings()
2214 t->hfp = m->right_margin; in fb_videomode_to_omap_timings()
2215 t->hbp = m->left_margin; in fb_videomode_to_omap_timings()
2216 t->vsw = m->vsync_len; in fb_videomode_to_omap_timings()
2217 t->vfp = m->lower_margin; in fb_videomode_to_omap_timings()
2218 t->vbp = m->upper_margin; in fb_videomode_to_omap_timings()
2219 t->hsync_level = m->sync & FB_SYNC_HOR_HIGH_ACT ? in fb_videomode_to_omap_timings()
2222 t->vsync_level = m->sync & FB_SYNC_VERT_HIGH_ACT ? in fb_videomode_to_omap_timings()
2225 t->interlace = m->vmode & FB_VMODE_INTERLACED; in fb_videomode_to_omap_timings()
2228 static int omapfb_find_best_mode(struct omap_dss_device *display, in omapfb_find_best_mode() argument
2229 struct omap_video_timings *timings) in omapfb_find_best_mode() argument
2235 if (!display->driver->read_edid) in omapfb_find_best_mode()
2236 return -ENODEV; in omapfb_find_best_mode()
2241 return -ENOMEM; in omapfb_find_best_mode()
2243 r = display->driver->read_edid(display, edid, len); in omapfb_find_best_mode()
2249 r = -ENOMEM; in omapfb_find_best_mode()
2255 best_idx = -1; in omapfb_find_best_mode()
2257 for (i = 0; i < specs->modedb_len; ++i) { in omapfb_find_best_mode()
2261 m = &specs->modedb[i]; in omapfb_find_best_mode()
2263 if (m->pixclock == 0) in omapfb_find_best_mode()
2267 if (m->xres == 2880 || m->xres == 1440) in omapfb_find_best_mode()
2270 if (m->vmode & FB_VMODE_INTERLACED || in omapfb_find_best_mode()
2271 m->vmode & FB_VMODE_DOUBLE) in omapfb_find_best_mode()
2274 fb_videomode_to_omap_timings(m, display, &t); in omapfb_find_best_mode()
2276 r = display->driver->check_timings(display, &t); in omapfb_find_best_mode()
2283 if (best_idx == -1) { in omapfb_find_best_mode()
2284 r = -ENOENT; in omapfb_find_best_mode()
2288 fb_videomode_to_omap_timings(&specs->modedb[best_idx], display, in omapfb_find_best_mode()
2289 timings); in omapfb_find_best_mode()
2294 fb_destroy_modedb(specs->modedb); in omapfb_find_best_mode()
2305 struct omap_dss_driver *dssdrv = dssdev->driver; in omapfb_init_display()
2309 r = dssdrv->enable(dssdev); in omapfb_init_display()
2311 dev_warn(fbdev->dev, "Failed to enable display '%s'\n", in omapfb_init_display()
2312 dssdev->name); in omapfb_init_display()
2318 d->fbdev = fbdev; in omapfb_init_display()
2320 if (dssdev->caps & OMAP_DSS_DISPLAY_CAP_MANUAL_UPDATE) { in omapfb_init_display()
2325 d->update_mode = OMAPFB_AUTO_UPDATE; in omapfb_init_display()
2327 d->update_mode = OMAPFB_MANUAL_UPDATE; in omapfb_init_display()
2330 if (dssdrv->enable_te) { in omapfb_init_display()
2331 r = dssdrv->enable_te(dssdev, 1); in omapfb_init_display()
2333 dev_err(fbdev->dev, "Failed to set TE\n"); in omapfb_init_display()
2338 dssdrv->get_resolution(dssdev, &w, &h); in omapfb_init_display()
2339 r = dssdrv->update(dssdev, 0, 0, w, h); in omapfb_init_display()
2341 dev_err(fbdev->dev, in omapfb_init_display()
2342 "Failed to update display\n"); in omapfb_init_display()
2346 d->update_mode = OMAPFB_AUTO_UPDATE; in omapfb_init_display()
2358 r = def_dssdev->driver->connect(def_dssdev); in omapfb_init_connections()
2360 dev_err(fbdev->dev, "failed to connect default display\n"); in omapfb_init_connections()
2364 for (i = 0; i < fbdev->num_displays; ++i) { in omapfb_init_connections()
2365 struct omap_dss_device *dssdev = fbdev->displays[i].dssdev; in omapfb_init_connections()
2374 dssdev->driver->connect(dssdev); in omapfb_init_connections()
2380 dev_err(fbdev->dev, "no ovl manager for the default display\n"); in omapfb_init_connections()
2381 return -EINVAL; in omapfb_init_connections()
2384 for (i = 0; i < fbdev->num_overlays; i++) { in omapfb_init_connections()
2385 struct omap_overlay *ovl = fbdev->overlays[i]; in omapfb_init_connections()
2387 if (ovl->manager) in omapfb_init_connections()
2388 ovl->unset_manager(ovl); in omapfb_init_connections()
2390 r = ovl->set_manager(ovl, mgr); in omapfb_init_connections()
2392 dev_warn(fbdev->dev, in omapfb_init_connections()
2394 ovl->name, mgr->name); in omapfb_init_connections()
2407 * Search with the display name from the user or the board file, in omapfb_find_default_display()
2408 * comparing to display names and aliases in omapfb_find_default_display()
2414 for (i = 0; i < fbdev->num_displays; ++i) { in omapfb_find_default_display()
2417 dssdev = fbdev->displays[i].dssdev; in omapfb_find_default_display()
2419 if (dssdev->name && strcmp(def_name, dssdev->name) == 0) in omapfb_find_default_display()
2422 if (strcmp(def_name, dssdev->alias) == 0) in omapfb_find_default_display()
2431 for (i = 0; i < fbdev->num_displays; ++i) { in omapfb_find_default_display()
2435 dssdev = fbdev->displays[i].dssdev; in omapfb_find_default_display()
2437 if (dssdev->dev->of_node == NULL) in omapfb_find_default_display()
2440 id = of_alias_get_id(dssdev->dev->of_node, "display"); in omapfb_find_default_display()
2445 /* return the first display we have in the list */ in omapfb_find_default_display()
2446 return fbdev->displays[0].dssdev; in omapfb_find_default_display()
2460 return -EPROBE_DEFER; in omapfb_probe()
2462 if (pdev->num_resources != 0) { in omapfb_probe()
2463 dev_err(&pdev->dev, "probed for an unknown device\n"); in omapfb_probe()
2464 r = -ENODEV; in omapfb_probe()
2468 fbdev = devm_kzalloc(&pdev->dev, sizeof(struct omapfb2_device), in omapfb_probe()
2471 r = -ENOMEM; in omapfb_probe()
2477 dev_warn(&pdev->dev, "VRFB is not supported on this hardware, " in omapfb_probe()
2485 mutex_init(&fbdev->mtx); in omapfb_probe()
2487 fbdev->dev = &pdev->dev; in omapfb_probe()
2490 fbdev->num_displays = 0; in omapfb_probe()
2497 if (!dssdev->driver) { in omapfb_probe()
2498 dev_warn(&pdev->dev, "no driver for display: %s\n", in omapfb_probe()
2499 dssdev->name); in omapfb_probe()
2504 d = &fbdev->displays[fbdev->num_displays++]; in omapfb_probe()
2505 d->dssdev = dssdev; in omapfb_probe()
2506 if (dssdev->caps & OMAP_DSS_DISPLAY_CAP_MANUAL_UPDATE) in omapfb_probe()
2507 d->update_mode = OMAPFB_MANUAL_UPDATE; in omapfb_probe()
2509 d->update_mode = OMAPFB_AUTO_UPDATE; in omapfb_probe()
2512 if (fbdev->num_displays == 0) { in omapfb_probe()
2513 dev_err(&pdev->dev, "no displays\n"); in omapfb_probe()
2514 r = -EPROBE_DEFER; in omapfb_probe()
2518 fbdev->num_overlays = omap_dss_get_num_overlays(); in omapfb_probe()
2519 for (i = 0; i < fbdev->num_overlays; i++) in omapfb_probe()
2520 fbdev->overlays[i] = omap_dss_get_overlay(i); in omapfb_probe()
2522 fbdev->num_managers = omap_dss_get_num_overlay_managers(); in omapfb_probe()
2523 for (i = 0; i < fbdev->num_managers; i++) in omapfb_probe()
2524 fbdev->managers[i] = omap_dss_get_overlay_manager(i); in omapfb_probe()
2528 dev_err(fbdev->dev, "failed to find default display\n"); in omapfb_probe()
2529 r = -EPROBE_DEFER; in omapfb_probe()
2535 dev_err(fbdev->dev, "failed to init overlay connections\n"); in omapfb_probe()
2541 dev_warn(&pdev->dev, "cannot parse default modes\n"); in omapfb_probe()
2542 } else if (def_display && def_display->driver->set_timings && in omapfb_probe()
2543 def_display->driver->check_timings) { in omapfb_probe()
2549 def_display->driver->set_timings(def_display, &t); in omapfb_probe()
2556 for (i = 0; i < fbdev->num_managers; i++) { in omapfb_probe()
2558 mgr = fbdev->managers[i]; in omapfb_probe()
2559 r = mgr->apply(mgr); in omapfb_probe()
2561 dev_warn(fbdev->dev, "failed to apply dispc config\n"); in omapfb_probe()
2564 DBG("mgr->apply'ed\n"); in omapfb_probe()
2569 dev_err(fbdev->dev, in omapfb_probe()
2571 "display\n"); in omapfb_probe()
2579 dev_err(fbdev->dev, "failed to create sysfs entries\n"); in omapfb_probe()
2586 def_display->driver->get_resolution(def_display, &w, &h); in omapfb_probe()
2588 dev_info(fbdev->dev, "using display '%s' mode %dx%d\n", in omapfb_probe()
2589 def_display->name, w, h); in omapfb_probe()
2598 dev_err(&pdev->dev, "failed to setup omapfb\n"); in omapfb_probe()