Lines Matching +full:vga +full:- +full:format
1 // SPDX-License-Identifier: GPL-2.0-only
9 * Copyright (c) 2001 - 2008 Paul Mundt <lethal@linux-sh.org>
13 * here are some hacked-up formulas:
19 * values, I could just add mode- specific offsets to get the correct mode
22 * left_margin = diwstart_h - borderstart_h;
23 * right_margin = borderstop_h - (diwstart_h + xres);
24 * upper_margin = diwstart_v - borderstart_v;
25 * lower_margin = borderstop_v - (diwstart_h + yres);
27 * hsync_len = borderstart_h + (hsync_total - borderstop_h);
28 * vsync_len = borderstart_v + (vsync_total - borderstop_v);
38 * borderstop_h = borderstart_h + hsync_total - hsync_len;
40 * diwstart_v = borderstart_v - upper_margin;
63 #include <mach-dreamcast/mach/sysasic.h>
82 #define DISP_BASE par->mmio_base
97 /* Pixel clocks, one for TV output, doubled for VGA output */
101 /* This is for 60Hz - the VTOTAL is doubled for interlaced modes */
118 { CT_VGA, "VGA" }, { CT_RGB, "RGB" }, { CT_COMPOSITE, "COMPOSITE" },
122 { VO_PAL, "PAL" }, { VO_NTSC, "NTSC" }, { VO_VGA, "VGA" },
142 unsigned char is_lowres; /* Is horizontal pixel-doubling enabled? */
169 .height = -1,
170 .width = -1,
201 * PAL-M and PAL-N, but from what I've read both modes parallel PAL and
215 /* 640x480 @ 60hz (VGA) */
232 struct pvr2fb_par *par = (struct pvr2fb_par *)fb_info->par; in pvr2fb_set_pal_type()
234 fb_writel(type, par->mmio_base + 0x108); in pvr2fb_set_pal_type()
241 fb_writel(val, par->mmio_base + 0x1000 + (4 * regno)); in pvr2fb_set_pal_entry()
246 do_blank = blank ? blank : -1; in pvr2fb_blank()
257 switch (var->bits_per_pixel) { in set_color_bitfields()
260 var->red.offset = 11; var->red.length = 5; in set_color_bitfields()
261 var->green.offset = 5; var->green.length = 6; in set_color_bitfields()
262 var->blue.offset = 0; var->blue.length = 5; in set_color_bitfields()
263 var->transp.offset = 0; var->transp.length = 0; in set_color_bitfields()
266 var->red.offset = 16; var->red.length = 8; in set_color_bitfields()
267 var->green.offset = 8; var->green.length = 8; in set_color_bitfields()
268 var->blue.offset = 0; var->blue.length = 8; in set_color_bitfields()
269 var->transp.offset = 0; var->transp.length = 0; in set_color_bitfields()
273 var->red.offset = 16; var->red.length = 8; in set_color_bitfields()
274 var->green.offset = 8; var->green.length = 8; in set_color_bitfields()
275 var->blue.offset = 0; var->blue.length = 8; in set_color_bitfields()
276 var->transp.offset = 24; var->transp.length = 8; in set_color_bitfields()
285 struct pvr2fb_par *par = (struct pvr2fb_par *)info->par; in pvr2fb_setcolreg()
288 if (regno > info->cmap.len) in pvr2fb_setcolreg()
293 * expected that the palette format has been set by the time we get in pvr2fb_setcolreg()
296 switch (info->var.bits_per_pixel) { in pvr2fb_setcolreg()
315 pr_debug("Invalid bit depth %d?!?\n", info->var.bits_per_pixel); in pvr2fb_setcolreg()
320 ((u32*)(info->pseudo_palette))[regno] = tmp; in pvr2fb_setcolreg()
326 * Determine the cable type and initialize the cable output format. Don't do
342 /* Now select the output format (either composite or other) */ in pvr2_init_cable()
357 struct pvr2fb_par *par = (struct pvr2fb_par *)info->par; in pvr2fb_set_par()
358 struct fb_var_screeninfo *var = &info->var; in pvr2fb_set_par()
363 * XXX: It's possible that a user could use a VGA box, change the cable in pvr2fb_set_par()
364 * type in hardware (i.e. switch from VGA<->composite), then change in pvr2fb_set_par()
366 * automagically change the output format to cope, but currently I in pvr2fb_set_par()
367 * don't have a VGA box to make sure this works properly. in pvr2fb_set_par()
373 var->vmode &= FB_VMODE_MASK; in pvr2fb_set_par()
374 if (var->vmode & FB_VMODE_INTERLACED && video_output != VO_VGA) in pvr2fb_set_par()
375 par->is_interlaced = 1; in pvr2fb_set_par()
380 if (var->vmode & FB_VMODE_DOUBLE && video_output == VO_VGA) in pvr2fb_set_par()
381 par->is_doublescan = 1; in pvr2fb_set_par()
383 par->hsync_total = var->left_margin + var->xres + var->right_margin + in pvr2fb_set_par()
384 var->hsync_len; in pvr2fb_set_par()
385 par->vsync_total = var->upper_margin + var->yres + var->lower_margin + in pvr2fb_set_par()
386 var->vsync_len; in pvr2fb_set_par()
388 if (var->sync & FB_SYNC_BROADCAST) { in pvr2fb_set_par()
389 vtotal = par->vsync_total; in pvr2fb_set_par()
390 if (par->is_interlaced) in pvr2fb_set_par()
394 /* XXX: Check hardware for PAL-compatibility */ in pvr2fb_set_par()
395 par->borderstart_h = 116; in pvr2fb_set_par()
396 par->borderstart_v = 44; in pvr2fb_set_par()
399 par->borderstart_h = 126; in pvr2fb_set_par()
400 par->borderstart_v = 18; in pvr2fb_set_par()
403 /* VGA mode */ in pvr2fb_set_par()
406 * XXX: We have a little freedom in VGA modes, what ranges in pvr2fb_set_par()
409 par->borderstart_h = 126; in pvr2fb_set_par()
410 par->borderstart_v = 40; in pvr2fb_set_par()
414 par->diwstart_h = par->borderstart_h + var->left_margin; in pvr2fb_set_par()
415 par->diwstart_v = par->borderstart_v + var->upper_margin; in pvr2fb_set_par()
416 par->borderstop_h = par->diwstart_h + var->xres + in pvr2fb_set_par()
417 var->right_margin; in pvr2fb_set_par()
418 par->borderstop_v = par->diwstart_v + var->yres + in pvr2fb_set_par()
419 var->lower_margin; in pvr2fb_set_par()
421 if (!par->is_interlaced) in pvr2fb_set_par()
422 par->borderstop_v /= 2; in pvr2fb_set_par()
423 if (info->var.xres < 640) in pvr2fb_set_par()
424 par->is_lowres = 1; in pvr2fb_set_par()
426 line_length = get_line_length(var->xres_virtual, var->bits_per_pixel); in pvr2fb_set_par()
427 par->disp_start = info->fix.smem_start + (line_length * var->yoffset) * line_length; in pvr2fb_set_par()
428 info->fix.line_length = line_length; in pvr2fb_set_par()
434 struct pvr2fb_par *par = (struct pvr2fb_par *)info->par; in pvr2fb_check_var()
438 if (var->pixclock != TV_CLK && var->pixclock != VGA_CLK) { in pvr2fb_check_var()
439 pr_debug("Invalid pixclock value %d\n", var->pixclock); in pvr2fb_check_var()
440 return -EINVAL; in pvr2fb_check_var()
443 if (var->xres < 320) in pvr2fb_check_var()
444 var->xres = 320; in pvr2fb_check_var()
445 if (var->yres < 240) in pvr2fb_check_var()
446 var->yres = 240; in pvr2fb_check_var()
447 if (var->xres_virtual < var->xres) in pvr2fb_check_var()
448 var->xres_virtual = var->xres; in pvr2fb_check_var()
449 if (var->yres_virtual < var->yres) in pvr2fb_check_var()
450 var->yres_virtual = var->yres; in pvr2fb_check_var()
452 if (var->bits_per_pixel <= 16) in pvr2fb_check_var()
453 var->bits_per_pixel = 16; in pvr2fb_check_var()
454 else if (var->bits_per_pixel <= 24) in pvr2fb_check_var()
455 var->bits_per_pixel = 24; in pvr2fb_check_var()
456 else if (var->bits_per_pixel <= 32) in pvr2fb_check_var()
457 var->bits_per_pixel = 32; in pvr2fb_check_var()
461 if (var->vmode & FB_VMODE_YWRAP) { in pvr2fb_check_var()
462 if (var->xoffset || var->yoffset >= var->yres_virtual) { in pvr2fb_check_var()
463 var->xoffset = var->yoffset = 0; in pvr2fb_check_var()
465 if (var->xoffset > var->xres_virtual - var->xres || in pvr2fb_check_var()
466 var->yoffset > var->yres_virtual - var->yres) in pvr2fb_check_var()
467 var->xoffset = var->yoffset = 0; in pvr2fb_check_var()
470 var->xoffset = var->yoffset = 0; in pvr2fb_check_var()
477 if (var->yres < 480 && video_output == VO_VGA) in pvr2fb_check_var()
478 var->vmode |= FB_VMODE_DOUBLE; in pvr2fb_check_var()
481 var->sync |= FB_SYNC_BROADCAST; in pvr2fb_check_var()
482 var->vmode |= FB_VMODE_INTERLACED; in pvr2fb_check_var()
484 var->sync &= ~FB_SYNC_BROADCAST; in pvr2fb_check_var()
485 var->vmode &= ~FB_VMODE_INTERLACED; in pvr2fb_check_var()
486 var->vmode |= FB_VMODE_NONINTERLACED; in pvr2fb_check_var()
489 if ((var->activate & FB_ACTIVATE_MASK) != FB_ACTIVATE_TEST) { in pvr2fb_check_var()
490 var->right_margin = par->borderstop_h - in pvr2fb_check_var()
491 (par->diwstart_h + var->xres); in pvr2fb_check_var()
492 var->left_margin = par->diwstart_h - par->borderstart_h; in pvr2fb_check_var()
493 var->hsync_len = par->borderstart_h + in pvr2fb_check_var()
494 (par->hsync_total - par->borderstop_h); in pvr2fb_check_var()
496 var->upper_margin = par->diwstart_v - par->borderstart_v; in pvr2fb_check_var()
497 var->lower_margin = par->borderstop_v - in pvr2fb_check_var()
498 (par->diwstart_v + var->yres); in pvr2fb_check_var()
499 var->vsync_len = par->borderstop_v + in pvr2fb_check_var()
500 (par->vsync_total - par->borderstop_v); in pvr2fb_check_var()
503 hsync_total = var->left_margin + var->xres + var->right_margin + in pvr2fb_check_var()
504 var->hsync_len; in pvr2fb_check_var()
505 vtotal = var->upper_margin + var->yres + var->lower_margin + in pvr2fb_check_var()
506 var->vsync_len; in pvr2fb_check_var()
508 if (var->sync & FB_SYNC_BROADCAST) { in pvr2fb_check_var()
509 if (var->vmode & FB_VMODE_INTERLACED) in pvr2fb_check_var()
516 return -EINVAL; in pvr2fb_check_var()
522 return -EINVAL; in pvr2fb_check_var()
528 line_length = get_line_length(var->xres_virtual, var->bits_per_pixel); in pvr2fb_check_var()
529 if (line_length * var->yres_virtual > info->fix.smem_len) in pvr2fb_check_var()
530 return -ENOMEM; in pvr2fb_check_var()
537 struct pvr2fb_par *par = (struct pvr2fb_par *) info->par; in pvr2_update_display()
538 struct fb_var_screeninfo *var = &info->var; in pvr2_update_display()
541 fb_writel(par->disp_start, DISP_DIWADDRL); in pvr2_update_display()
542 fb_writel(par->disp_start + in pvr2_update_display()
543 get_line_length(var->xoffset+var->xres, var->bits_per_pixel), in pvr2_update_display()
555 struct pvr2fb_par *par = (struct pvr2fb_par *) info->par; in pvr2_init_display()
556 struct fb_var_screeninfo *var = &info->var; in pvr2_init_display()
558 unsigned int bytesperpixel = var->bits_per_pixel >> 3; in pvr2_init_display()
561 fb_writel((par->vsync_total << 16) | par->hsync_total, DISP_SYNCSIZE); in pvr2_init_display()
566 if (video_output != VO_VGA && par->is_interlaced) in pvr2_init_display()
567 diw_modulo += info->fix.line_length / 4; in pvr2_init_display()
568 diw_height = (par->is_interlaced ? var->yres / 2 : var->yres); in pvr2_init_display()
569 diw_width = get_line_length(var->xres, var->bits_per_pixel) / 4; in pvr2_init_display()
570 fb_writel((diw_modulo << 20) | (--diw_height << 10) | --diw_width, in pvr2_init_display()
574 fb_writel(par->disp_start, DISP_DIWADDRL); in pvr2_init_display()
575 fb_writel(par->disp_start + in pvr2_init_display()
576 get_line_length(var->xoffset+var->xres, var->bits_per_pixel), in pvr2_init_display()
580 fb_writel((par->borderstart_h << 16) | par->borderstop_h, DISP_BRDRHORZ); in pvr2_init_display()
581 fb_writel((par->borderstart_v << 16) | par->borderstop_v, DISP_BRDRVERT); in pvr2_init_display()
585 fb_writel(par->diwstart_h, DISP_DIWHSTRT); in pvr2_init_display()
586 fb_writel((par->diwstart_v << 16) | par->diwstart_v, DISP_DIWVSTRT); in pvr2_init_display()
589 fb_writel((0x16 << 16) | par->is_lowres, DISP_DIWCONF); in pvr2_init_display()
591 /* clock doubler (for VGA), scan doubler, display enable */ in pvr2_init_display()
593 (par->is_doublescan << 1) | 1, DISP_DIWMODE); in pvr2_init_display()
596 fb_writel(fb_readl(DISP_DIWMODE) | (--bytesperpixel << 2), DISP_DIWMODE); in pvr2_init_display()
601 fb_writel(0x100 | ((par->is_interlaced /*|4*/) << 4), DISP_SYNCCONF); in pvr2_init_display()
650 nr_pages = (count + PAGE_SIZE - 1) >> PAGE_SHIFT; in pvr2fb_write()
654 return -ENOMEM; in pvr2fb_write()
662 * -errno value was returned from GUP. in pvr2fb_write()
668 * Use -EINVAL to represent a mildly desperate guess at in pvr2fb_write()
672 ret = -EINVAL; in pvr2fb_write()
679 dst = (unsigned long)fb_info->screen_base + *ppos; in pvr2fb_write()
684 /* Half-assed contig check */ in pvr2fb_write()
687 if ((*ppos + len) > fb_info->fix.smem_len) { in pvr2fb_write()
688 ret = -ENOSPC; in pvr2fb_write()
699 /* Not contiguous, writeout per-page instead.. */ in pvr2fb_write()
701 if ((*ppos + (i << PAGE_SHIFT)) > fb_info->fix.smem_len) { in pvr2fb_write()
702 ret = -ENOSPC; in pvr2fb_write()
747 return -1; in pvr2_get_param_val()
769 * registration. It's expected that the board-specific init code has
773 * default from the modedb. For board-specific modelines, simply define
774 * a per-board modedb.
777 * always going to be VGA for the PCI-based PVR2 boards, but we leave this
778 * in for flexibility anyways. Who knows, maybe someone has tv-out on a
779 * PCI-based version of these things ;-)
786 fb_info->screen_base = ioremap(pvr2_fix.smem_start, in pvr2fb_common_init()
789 if (!fb_info->screen_base) { in pvr2fb_common_init()
794 par->mmio_base = ioremap(pvr2_fix.mmio_start, in pvr2fb_common_init()
796 if (!par->mmio_base) { in pvr2fb_common_init()
801 fb_memset(fb_info->screen_base, 0, pvr2_fix.smem_len); in pvr2fb_common_init()
806 fb_info->fbops = &pvr2fb_ops; in pvr2fb_common_init()
807 fb_info->fix = pvr2_fix; in pvr2fb_common_init()
808 fb_info->par = currentpar; in pvr2fb_common_init()
809 fb_info->pseudo_palette = currentpar->palette; in pvr2fb_common_init()
810 fb_info->flags = FBINFO_DEFAULT | FBINFO_HWACCEL_YPAN; in pvr2fb_common_init()
818 if (!fb_find_mode(&fb_info->var, fb_info, mode_option, pvr2_modedb, in pvr2fb_common_init()
820 fb_info->var = pvr2_var; in pvr2fb_common_init()
822 fb_alloc_cmap(&fb_info->cmap, 256, 0); in pvr2fb_common_init()
826 /*Must write PIXDEPTH to register before anything is displayed - so force init */ in pvr2fb_common_init()
829 modememused = get_line_length(fb_info->var.xres_virtual, in pvr2fb_common_init()
830 fb_info->var.bits_per_pixel); in pvr2fb_common_init()
831 modememused *= fb_info->var.yres_virtual; in pvr2fb_common_init()
833 rev = fb_readl(par->mmio_base + 0x04); in pvr2fb_common_init()
836 fb_info->fix.id, (rev >> 4) & 0x0f, rev & 0x0f, in pvr2fb_common_init()
838 (unsigned long)(fb_info->fix.smem_len >> 10)); in pvr2fb_common_init()
839 fb_info(fb_info, "Mode %dx%d-%d pitch = %ld cable: %s video output: %s\n", in pvr2fb_common_init()
840 fb_info->var.xres, fb_info->var.yres, in pvr2fb_common_init()
841 fb_info->var.bits_per_pixel, in pvr2fb_common_init()
842 get_line_length(fb_info->var.xres, fb_info->var.bits_per_pixel), in pvr2fb_common_init()
849 pvr2fb_map = sq_remap(fb_info->fix.smem_start, fb_info->fix.smem_len, in pvr2fb_common_init()
850 fb_info->fix.id, PAGE_SHARED); in pvr2fb_common_init()
859 if (fb_info->screen_base) in pvr2fb_common_init()
860 iounmap(fb_info->screen_base); in pvr2fb_common_init()
861 if (par->mmio_base) in pvr2fb_common_init()
862 iounmap(par->mmio_base); in pvr2fb_common_init()
864 return -ENXIO; in pvr2fb_common_init()
871 return -ENXIO; in pvr2fb_dc_init()
875 fb_info->monspecs.hfmin = 30000; in pvr2fb_dc_init()
876 fb_info->monspecs.hfmax = 70000; in pvr2fb_dc_init()
877 fb_info->monspecs.vfmin = 60; in pvr2fb_dc_init()
878 fb_info->monspecs.vfmax = 60; in pvr2fb_dc_init()
880 /* Not VGA, using a TV (taken from acornfb) */ in pvr2fb_dc_init()
881 fb_info->monspecs.hfmin = 15469; in pvr2fb_dc_init()
882 fb_info->monspecs.hfmax = 15781; in pvr2fb_dc_init()
883 fb_info->monspecs.vfmin = 49; in pvr2fb_dc_init()
884 fb_info->monspecs.vfmax = 51; in pvr2fb_dc_init()
909 return -EBUSY; in pvr2fb_dc_init()
915 return -EBUSY; in pvr2fb_dc_init()
924 if (fb_info->screen_base) { in pvr2fb_dc_exit()
925 iounmap(fb_info->screen_base); in pvr2fb_dc_exit()
926 fb_info->screen_base = NULL; in pvr2fb_dc_exit()
928 if (currentpar->mmio_base) { in pvr2fb_dc_exit()
929 iounmap(currentpar->mmio_base); in pvr2fb_dc_exit()
930 currentpar->mmio_base = NULL; in pvr2fb_dc_exit()
971 fb_info->device = &pdev->dev; in pvr2fb_pci_probe()
978 if (fb_info->screen_base) { in pvr2fb_pci_remove()
979 iounmap(fb_info->screen_base); in pvr2fb_pci_remove()
980 fb_info->screen_base = NULL; in pvr2fb_pci_remove()
982 if (currentpar->mmio_base) { in pvr2fb_pci_remove()
983 iounmap(currentpar->mmio_base); in pvr2fb_pci_remove()
984 currentpar->mmio_base = NULL; in pvr2fb_pci_remove()
1019 * cable:composite|rgb|vga Override the video cable type
1020 * output:NTSC|PAL|VGA Override the video output format
1022 * <xres>x<yres>[-<bpp>][@<refresh>] or,
1023 * <name>[-<bpp>][@<refresh>] Startup using this video mode
1081 int i, ret = -ENODEV; in pvr2fb_init()
1087 return -ENODEV; in pvr2fb_init()
1093 return -ENOMEM; in pvr2fb_init()
1095 currentpar = fb_info->par; in pvr2fb_init()
1100 if (!pvr_board->init) in pvr2fb_init()
1103 ret = pvr_board->init(); in pvr2fb_init()
1107 pvr_board->name); in pvr2fb_init()
1123 if (pvr_board->exit) in pvr2fb_exit()
1124 pvr_board->exit(); in pvr2fb_exit()
1138 MODULE_AUTHOR("Paul Mundt <lethal@linux-sh.org>, M. R. Brown <mrbrown@0xd6.org>");