Lines Matching refs:var
153 struct fb_var_screeninfo *var, in atmel_lcdfb_update_dma2d() argument
165 struct fb_var_screeninfo *var, in atmel_lcdfb_update_dma2d() argument
171 pixeloff = (var->xoffset * info->var.bits_per_pixel) & 0x1f; in atmel_lcdfb_update_dma2d()
173 dma2dcfg = (info->var.xres_virtual - info->var.xres) in atmel_lcdfb_update_dma2d()
174 * info->var.bits_per_pixel / 8; in atmel_lcdfb_update_dma2d()
397 struct fb_var_screeninfo *var) in atmel_lcdfb_update_dma() argument
403 dma_addr = (fix->smem_start + var->yoffset * fix->line_length in atmel_lcdfb_update_dma()
404 + var->xoffset * info->var.bits_per_pixel / 8); in atmel_lcdfb_update_dma()
411 atmel_lcdfb_update_dma2d(sinfo, var, info); in atmel_lcdfb_update_dma()
432 struct fb_var_screeninfo *var = &info->var; in atmel_lcdfb_alloc_video_memory() local
435 smem_len = (var->xres_virtual * var->yres_virtual in atmel_lcdfb_alloc_video_memory()
436 * ((var->bits_per_pixel + 7) / 8)); in atmel_lcdfb_alloc_video_memory()
451 static const struct fb_videomode *atmel_lcdfb_choose_mode(struct fb_var_screeninfo *var, in atmel_lcdfb_choose_mode() argument
457 fb_var_to_videomode(&varfbmode, var); in atmel_lcdfb_choose_mode()
460 fb_videomode_to_var(var, fbmode); in atmel_lcdfb_choose_mode()
488 static int atmel_lcdfb_check_var(struct fb_var_screeninfo *var, in atmel_lcdfb_check_var() argument
500 if (!(var->pixclock && var->bits_per_pixel)) { in atmel_lcdfb_check_var()
502 if (!atmel_lcdfb_choose_mode(var, info)) { in atmel_lcdfb_check_var()
508 dev_dbg(dev, " resolution: %ux%u\n", var->xres, var->yres); in atmel_lcdfb_check_var()
509 dev_dbg(dev, " pixclk: %lu KHz\n", PICOS2KHZ(var->pixclock)); in atmel_lcdfb_check_var()
510 dev_dbg(dev, " bpp: %u\n", var->bits_per_pixel); in atmel_lcdfb_check_var()
513 if (PICOS2KHZ(var->pixclock) > clk_value_khz) { in atmel_lcdfb_check_var()
514 dev_err(dev, "%lu KHz pixel clock is too fast\n", PICOS2KHZ(var->pixclock)); in atmel_lcdfb_check_var()
519 if (var->xres > var->xres_virtual) in atmel_lcdfb_check_var()
520 var->xres_virtual = var->xres; in atmel_lcdfb_check_var()
522 if (var->yres > var->yres_virtual) in atmel_lcdfb_check_var()
523 var->yres_virtual = var->yres; in atmel_lcdfb_check_var()
526 var->xres = (var->xres + 3) & ~3UL; in atmel_lcdfb_check_var()
527 var->xres_virtual = (var->xres_virtual + 3) & ~3UL; in atmel_lcdfb_check_var()
529 var->red.msb_right = var->green.msb_right = var->blue.msb_right = 0; in atmel_lcdfb_check_var()
530 var->transp.msb_right = 0; in atmel_lcdfb_check_var()
531 var->transp.offset = var->transp.length = 0; in atmel_lcdfb_check_var()
532 var->xoffset = var->yoffset = 0; in atmel_lcdfb_check_var()
535 unsigned int smem_len = (var->xres_virtual * var->yres_virtual in atmel_lcdfb_check_var()
536 * ((var->bits_per_pixel + 7) / 8)); in atmel_lcdfb_check_var()
545 var->vsync_len = min_t(u32, var->vsync_len, in atmel_lcdfb_check_var()
547 var->upper_margin = min_t(u32, var->upper_margin, in atmel_lcdfb_check_var()
549 var->lower_margin = min_t(u32, var->lower_margin, in atmel_lcdfb_check_var()
551 var->right_margin = min_t(u32, var->right_margin, in atmel_lcdfb_check_var()
553 var->hsync_len = min_t(u32, var->hsync_len, in atmel_lcdfb_check_var()
555 var->left_margin = min_t(u32, var->left_margin, in atmel_lcdfb_check_var()
559 var->vsync_len = max_t(u32, var->vsync_len, 1); in atmel_lcdfb_check_var()
560 var->right_margin = max_t(u32, var->right_margin, 1); in atmel_lcdfb_check_var()
561 var->hsync_len = max_t(u32, var->hsync_len, 1); in atmel_lcdfb_check_var()
562 var->left_margin = max_t(u32, var->left_margin, 1); in atmel_lcdfb_check_var()
564 switch (var->bits_per_pixel) { in atmel_lcdfb_check_var()
569 var->red.offset = var->green.offset = var->blue.offset = 0; in atmel_lcdfb_check_var()
570 var->red.length = var->green.length = var->blue.length in atmel_lcdfb_check_var()
571 = var->bits_per_pixel; in atmel_lcdfb_check_var()
576 var->green.length = 5; in atmel_lcdfb_check_var()
578 var->green.length = 6; in atmel_lcdfb_check_var()
582 var->red.offset = var->green.length + 5; in atmel_lcdfb_check_var()
583 var->blue.offset = 0; in atmel_lcdfb_check_var()
586 var->red.offset = 0; in atmel_lcdfb_check_var()
587 var->blue.offset = var->green.length + 5; in atmel_lcdfb_check_var()
589 var->green.offset = 5; in atmel_lcdfb_check_var()
590 var->red.length = var->blue.length = 5; in atmel_lcdfb_check_var()
593 var->transp.offset = 24; in atmel_lcdfb_check_var()
594 var->transp.length = 8; in atmel_lcdfb_check_var()
599 var->red.offset = 16; in atmel_lcdfb_check_var()
600 var->blue.offset = 0; in atmel_lcdfb_check_var()
603 var->red.offset = 0; in atmel_lcdfb_check_var()
604 var->blue.offset = 16; in atmel_lcdfb_check_var()
606 var->green.offset = 8; in atmel_lcdfb_check_var()
607 var->red.length = var->green.length = var->blue.length = 8; in atmel_lcdfb_check_var()
611 var->bits_per_pixel); in atmel_lcdfb_check_var()
657 info->var.xres, info->var.yres, in atmel_lcdfb_set_par()
658 info->var.xres_virtual, info->var.yres_virtual); in atmel_lcdfb_set_par()
662 if (info->var.bits_per_pixel == 1) in atmel_lcdfb_set_par()
664 else if (info->var.bits_per_pixel <= 8) in atmel_lcdfb_set_par()
669 bits_per_line = info->var.xres_virtual * info->var.bits_per_pixel; in atmel_lcdfb_set_par()
674 atmel_lcdfb_update_dma(info, &info->var); in atmel_lcdfb_set_par()
677 value = (info->var.yres * info->var.xres * info->var.bits_per_pixel) / 32; in atmel_lcdfb_set_par()
689 value = DIV_ROUND_UP(clk_value_khz, PICOS2KHZ(info->var.pixclock)); in atmel_lcdfb_set_par()
700 info->var.pixclock = in atmel_lcdfb_set_par()
703 PICOS2KHZ(info->var.pixclock)); in atmel_lcdfb_set_par()
710 if (!(info->var.sync & FB_SYNC_HOR_HIGH_ACT)) in atmel_lcdfb_set_par()
712 if (!(info->var.sync & FB_SYNC_VERT_HIGH_ACT)) in atmel_lcdfb_set_par()
715 switch (info->var.bits_per_pixel) { in atmel_lcdfb_set_par()
730 value = (info->var.vsync_len - 1) << ATMEL_LCDC_VPW_OFFSET; in atmel_lcdfb_set_par()
731 value |= info->var.upper_margin << ATMEL_LCDC_VBP_OFFSET; in atmel_lcdfb_set_par()
732 value |= info->var.lower_margin; in atmel_lcdfb_set_par()
737 value = (info->var.right_margin - 1) << ATMEL_LCDC_HFP_OFFSET; in atmel_lcdfb_set_par()
738 value |= (info->var.hsync_len - 1) << ATMEL_LCDC_HPW_OFFSET; in atmel_lcdfb_set_par()
739 value |= (info->var.left_margin - 1); in atmel_lcdfb_set_par()
744 hozval_linesz = compute_hozval(sinfo, info->var.xres); in atmel_lcdfb_set_par()
748 value |= info->var.yres - 1; in atmel_lcdfb_set_par()
817 if (info->var.grayscale) in atmel_lcdfb_setcolreg()
826 val = chan_to_field(red, &info->var.red); in atmel_lcdfb_setcolreg()
827 val |= chan_to_field(green, &info->var.green); in atmel_lcdfb_setcolreg()
828 val |= chan_to_field(blue, &info->var.blue); in atmel_lcdfb_setcolreg()
878 static int atmel_lcdfb_pan_display(struct fb_var_screeninfo *var, in atmel_lcdfb_pan_display() argument
883 atmel_lcdfb_update_dma(info, var); in atmel_lcdfb_pan_display()
955 info->var.activate |= FB_ACTIVATE_FORCE | FB_ACTIVATE_NOW; in atmel_lcdfb_init_fbinfo()
1030 struct fb_var_screeninfo *var = &info->var; in atmel_lcdfb_of_init() local
1051 ret = of_property_read_u32(display_np, "bits-per-pixel", &var->bits_per_pixel); in atmel_lcdfb_of_init()
1203 info->var.bits_per_pixel = pdata->default_bpp ? pdata->default_bpp : 16; in atmel_lcdfb_probe()
1239 fb_videomode_to_var(&info->var, &modelist->mode); in atmel_lcdfb_probe()
1241 atmel_lcdfb_check_var(&info->var, info); in atmel_lcdfb_probe()