帧缓冲区fb在内存中,要实现fb同步显示需要设定DMA操作。

设定LCD的DMA操作,要在开始操作LCD之前。

common/lcd.c中定义lcd_init() -->

driver/video/atmel_lcdfb.c定义lcd_ctrl_init().

lcd_ctrl_init()定义了DMA与mm的联系。

67 void lcd_ctrl_init(void *lcdbase)
 68 {
 69     unsigned long value;
 70
 71     /* Turn off the LCD controller and the DMA controller */
 72     lcdc_writel(panel_info.mmio, ATMEL_LCDC_PWRCON,
 73             1 << ATMEL_LCDC_GUARDT_OFFSET);
 74
 75     /* Wait for the LCDC core to become idle */
 76     while (lcdc_readl(panel_info.mmio, ATMEL_LCDC_PWRCON) & ATMEL_LCDC_BUSY)
 77         udelay(10);
 78
 79     lcdc_writel(panel_info.mmio, ATMEL_LCDC_DMACON, 0);
 80
 81     /* Reset LCDC DMA */
 82     lcdc_writel(panel_info.mmio, ATMEL_LCDC_DMACON, ATMEL_LCDC_DMARST);
 83
 84     /* ...set frame size and burst length = 8 words (?) */
 85     value = (panel_info.vl_col * panel_info.vl_row *
 86          NBITS(panel_info.vl_bpix)) / 32;
 87     value |= ((ATMEL_LCDC_DMA_BURST_LEN - 1) << ATMEL_LCDC_BLENGTH_OFFSET);
 88     lcdc_writel(panel_info.mmio, ATMEL_LCDC_DMAFRMCFG, value);
 89
 90     /* Set pixel clock */
 91     value = get_lcdc_clk_rate(0) / panel_info.vl_clk;
 92     if (get_lcdc_clk_rate(0) % panel_info.vl_clk)
 93         value++;
 94     value = (value / 2) - 1;
 95
 96     if (!value) {
 97         lcdc_writel(panel_info.mmio, ATMEL_LCDC_LCDCON1, ATMEL_LCDC_BYPASS);
 98     } else
 99         lcdc_writel(panel_info.mmio, ATMEL_LCDC_LCDCON1,
100                 value << ATMEL_LCDC_CLKVAL_OFFSET);
101
102     /* Initialize control register 2 */
103 #ifdef CONFIG_AVR32
104     value = ATMEL_LCDC_MEMOR_BIG | ATMEL_LCDC_CLKMOD_ALWAYSACTIVE;
105 #else
106     value = ATMEL_LCDC_MEMOR_LITTLE | ATMEL_LCDC_CLKMOD_ALWAYSACTIVE;
107 #endif
108     if (panel_info.vl_tft)
109         value |= ATMEL_LCDC_DISTYPE_TFT;
110
111     if (!(panel_info.vl_sync & ATMEL_LCDC_INVLINE_INVERTED))
112         value |= ATMEL_LCDC_INVLINE_INVERTED;
113     if (!(panel_info.vl_sync & ATMEL_LCDC_INVFRAME_INVERTED))
114         value |= ATMEL_LCDC_INVFRAME_INVERTED;
115     value |= (panel_info.vl_bpix << 5);
116     lcdc_writel(panel_info.mmio, ATMEL_LCDC_LCDCON2, value);
117
118     /* Vertical timing */
119     value = (panel_info.vl_vsync_len - 1) << ATMEL_LCDC_VPW_OFFSET;
120     value |= panel_info.vl_upper_margin << ATMEL_LCDC_VBP_OFFSET;
121     value |= panel_info.vl_lower_margin;
122     lcdc_writel(panel_info.mmio, ATMEL_LCDC_TIM1, value);
123
124     /* Horizontal timing */
125     value = (panel_info.vl_right_margin - 1) << ATMEL_LCDC_HFP_OFFSET;
126     value |= (panel_info.vl_hsync_len - 1) << ATMEL_LCDC_HPW_OFFSET;
127     value |= (panel_info.vl_left_margin - 1);
128     lcdc_writel(panel_info.mmio, ATMEL_LCDC_TIM2, value);
129
130     /* Display size */
131     value = (panel_info.vl_col - 1) << ATMEL_LCDC_HOZVAL_OFFSET;
132     value |= panel_info.vl_row - 1;
133     lcdc_writel(panel_info.mmio, ATMEL_LCDC_LCDFRMCFG, value);
134
135     /* FIFO Threshold: Use formula from data sheet */
136     value = ATMEL_LCDC_FIFO_SIZE - (2 * ATMEL_LCDC_DMA_BURST_LEN + 3);
137     lcdc_writel(panel_info.mmio, ATMEL_LCDC_FIFO, value);
138
139     /* Toggle LCD_MODE every frame */
140     lcdc_writel(panel_info.mmio, ATMEL_LCDC_MVAL, 0);
141
142     /* Disable all interrupts */
143     lcdc_writel(panel_info.mmio, ATMEL_LCDC_IDR, ~0UL);
144
145     /* Set contrast */
146     value = ATMEL_LCDC_PS_DIV8 |
147         ATMEL_LCDC_POL_POSITIVE |
148         ATMEL_LCDC_ENA_PWMENABLE;
149     lcdc_writel(panel_info.mmio, ATMEL_LCDC_CONTRAST_CTR, value);
150     lcdc_writel(panel_info.mmio, ATMEL_LCDC_CONTRAST_VAL, ATMEL_LCDC_CVAL_DEFAULT);
151
152     /* Set framebuffer DMA base address and pixel offset */
153     lcdc_writel(panel_info.mmio, ATMEL_LCDC_DMABADDR1, (u_long)lcdbase);
154
155     lcdc_writel(panel_info.mmio, ATMEL_LCDC_DMACON, ATMEL_LCDC_DMAEN);
156     lcdc_writel(panel_info.mmio, ATMEL_LCDC_PWRCON,
157             (1 << ATMEL_LCDC_GUARDT_OFFSET) | ATMEL_LCDC_PWR);
158 }

uboot中fb实现的更多相关文章

  1. Uboot中支持lcd和hdmi显示不同的logo图片【转】

    本文转载自:http://blog.csdn.net/u010865783/article/details/54953315 在lcd为竖屏,hdmi显示横屏的情况下,如果按照默认的uboot显示框架 ...

  2. uboot中添加FIQ中断及相关问题

    本文主要说明了在uboot中添加FIQ中断时遇到的问题以及对应的解决办法. 首先交代一下项目的软硬件环境.硬件方面,使用s3c2440作为主控芯片,外接串口.网卡等设备.软件方面,主控芯片上电后运行u ...

  3. u-boot中nandflash初始化流程分析(转)

    u-boot中nandflash初始化流程分析(转) 原文地址http://zhuairlunjj.blog.163.com/blog/static/80050945201092011249136/ ...

  4. (四)ubuntu学习前传—uboot中对Flash和DDR的管理

    1.uboot阶段Flash的分区 (1)所谓分区,就是说对Flash进行分块管理.(2)PC机等产品中,因为大家都是在操作系统下使用硬盘的,整个硬盘由操作系统统一管理,操作系统会使用文件系统帮我们管 ...

  5. uboot中gd的定义和使用

    近期在做uboot中nand启动相关的工作,遇到一个问题一直纠结着.如今最终明确了这个问题,想想还有好多兄弟在某个黑暗的角落里或者某台电脑前纠结着呢,所以赶紧写下来以供查阅. uboot versio ...

  6. u-boot中分区和内核MTD分区关系

    一.u-boot中环境变量与uImage中MTD的分区关系 分区只是内核的概念,就是说A-B地址放内核,C-D地址放文件系统,(也就是规定哪个地址区间放内核或者文件系统)等等. 一般我们只需要分3-4 ...

  7. 关于Yaffs2在u-boot中的支持

    开发板是一块2G的MLC的NandFlash,页大小8k+512,为其移植u-boot到yaffs2这了.以前在Mini2440上移植过2k+64的slc的NandFlash的Yaffs2支持,当然也 ...

  8. uboot中raise:Signal #8 caught的根本原因

    在移植uboot时编译一切正常,但uboot启动中载入自己写的网卡驱动出现故障,一直在打印raise:Signal #8 caught google  百度了一番,也有非常多人遇到了这个问题,大家都说 ...

  9. 分析uboot中 make xxx_config过程

    make xxx_config实质上就是调用了 首先看MKCONFIG: [注意]SRCTREE=源文件下的目录 之后的语句: @$(MKCONFIG) $(@:_config=) arm arm92 ...

随机推荐

  1. 如何用python的装饰器定义一个像C++一样的强类型函数

        Python作为一个动态的脚本语言,其函数在定义时是不需要指出参数的类型,也不需要指出函数是否有返回值.本文将介绍如何使用python的装饰器来定义一个像C++那样的强类型函数.接下去,先介绍 ...

  2. Flask接通微信公众号

    import hashlib import xml.etree.ElementTree as ET from flask import Flask, request import time app = ...

  3. WordPress网站搬家全过程 亲身体验WordPress搬家,总结几点

    需要移动的文件主要是网站文件和数据库文件,如果是简单的wordpress   操作就是:备份网站文件,导出数据库文件,上传网站文件,导入数据库文件,移动网站文件,修改wordpress的wp-conf ...

  4. 用浏览器访问WCF

    在开发的时候,为客户端编写代码访问WCF的方式,我们应该比较熟悉,主要是添加一个代理,然后通过这个代理进行访问. 如果用浏览器访问WCF呢?(其实最终是想在JS里面访问)用浏览器访问.测试Web Se ...

  5. .NET CORE WebApi Post跨域提交

    参考博客:https://www.cnblogs.com/chongyao/p/8652743.html 搭建一个 .NET CORE 的 WebApi 想前后端分离, 于是为了简单做了个demo站点 ...

  6. Unix环境高级编程(一)文件I/O

    Unix系统中大多数文件I/O只需用到五个函数:open.read.write.lseek.close.本章说介绍的I/O是不带缓冲的,即:每个read和write都调用内核中的一个系统调用.不是IS ...

  7. js实现多物体运动框架并兼容各浏览器

    首先,我们须要知道在js中获取对象的宽度如offsetWidth等.可能会存在一些小小的bug.原因之中的一个在于offsetWidth只不过获取盒子模型中内容的部分宽度.并不包括内边距,边框和外边距 ...

  8. Windwos配置Maven环境变量

    下载Maven插件:http://maven.apache.org/download.cgi 添加环境变量: MAVEN_HOMEE:\Program Files\Apache Software Fo ...

  9. nexus代理地址整理

    为给大家提供方便构建开源软件,分享下自己研究一些开源软件的时候,为方便构建搭建的nexus仓库以及代理地 名称 地址 apache-content-releases https://repositor ...

  10. Qt Quick + OpenGL + Bullet初次測试

    Qt Quick + OpenGL + Bullet初次測试 眼下Qt的Quick模块已经表现得很出色,并且可以预留接口来渲染OpenGL场景.一般来说,已经可以满足大部分编程须要了.这次呢.尝试使用 ...