uboot中fb实现
帧缓冲区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实现的更多相关文章
- Uboot中支持lcd和hdmi显示不同的logo图片【转】
本文转载自:http://blog.csdn.net/u010865783/article/details/54953315 在lcd为竖屏,hdmi显示横屏的情况下,如果按照默认的uboot显示框架 ...
- uboot中添加FIQ中断及相关问题
本文主要说明了在uboot中添加FIQ中断时遇到的问题以及对应的解决办法. 首先交代一下项目的软硬件环境.硬件方面,使用s3c2440作为主控芯片,外接串口.网卡等设备.软件方面,主控芯片上电后运行u ...
- u-boot中nandflash初始化流程分析(转)
u-boot中nandflash初始化流程分析(转) 原文地址http://zhuairlunjj.blog.163.com/blog/static/80050945201092011249136/ ...
- (四)ubuntu学习前传—uboot中对Flash和DDR的管理
1.uboot阶段Flash的分区 (1)所谓分区,就是说对Flash进行分块管理.(2)PC机等产品中,因为大家都是在操作系统下使用硬盘的,整个硬盘由操作系统统一管理,操作系统会使用文件系统帮我们管 ...
- uboot中gd的定义和使用
近期在做uboot中nand启动相关的工作,遇到一个问题一直纠结着.如今最终明确了这个问题,想想还有好多兄弟在某个黑暗的角落里或者某台电脑前纠结着呢,所以赶紧写下来以供查阅. uboot versio ...
- u-boot中分区和内核MTD分区关系
一.u-boot中环境变量与uImage中MTD的分区关系 分区只是内核的概念,就是说A-B地址放内核,C-D地址放文件系统,(也就是规定哪个地址区间放内核或者文件系统)等等. 一般我们只需要分3-4 ...
- 关于Yaffs2在u-boot中的支持
开发板是一块2G的MLC的NandFlash,页大小8k+512,为其移植u-boot到yaffs2这了.以前在Mini2440上移植过2k+64的slc的NandFlash的Yaffs2支持,当然也 ...
- uboot中raise:Signal #8 caught的根本原因
在移植uboot时编译一切正常,但uboot启动中载入自己写的网卡驱动出现故障,一直在打印raise:Signal #8 caught google 百度了一番,也有非常多人遇到了这个问题,大家都说 ...
- 分析uboot中 make xxx_config过程
make xxx_config实质上就是调用了 首先看MKCONFIG: [注意]SRCTREE=源文件下的目录 之后的语句: @$(MKCONFIG) $(@:_config=) arm arm92 ...
随机推荐
- Swift3 获取版本号,比较版本大小
Swift获取应用版本号:version 1.获取本地版本号 /// 获取本地版本号 func getLocalVersion() -> String { var localVersion:St ...
- IT常用设备及服务器安全公告或漏洞地址pa安全预警微软安全公告 HP 安全公告AIX 安全公告REDHAT安全公告ORACLE 安全公告F5 安全公告 Cisco 安全公告Juniper 安全公告 VMware 安全公告IOS 安全公告
IT常用设备及服务器安全公告或漏洞地址: 微软安全公告 https://technet.microsoft.com/en-us/library/security/MS14-085 HP 安全公告 ht ...
- eclipse容易卡死或者较慢的解决方案
http://blog.sina.com.cn/s/blog_5c6c4dc90100lg8n.html 问题: Eclipse经常卡住或Building workspace等待,感觉很不爽,很多朋友 ...
- Hadoop Archives
原文地址:http://hadoop.apache.org/docs/r1.0.4/cn/hadoop_archives.html 什么是Hadoop archives? 如何创建archive? 如 ...
- CentOS 6.7下配置 yum 安装 Nginx。
第一步,在/etc/yum.repos.d/目录下创建一个源配置文件nginx.repo: cd /etc/yum.repos.d/ vim nginx.repo 填写如下内容: [nginx]nam ...
- Flume多Sink方案修正
在实际项目中采用http://www.cnblogs.com/moonandstar08/p/6091384.html方案进行布署时,由于系统产生的消费比较大按照原方案进行布署时,随着国外局点不断增加 ...
- 转 python 读取中文文件名/中文路径
python直接读取中文路径的文件时失败,可做如下处理: inpath = 'D:/work/yuanxx/在线导航/驾车导航/walk_log/20130619_172355.txt' uipath ...
- DBA_Oracle Erp R12系统文件结构(概念)
20150609 Created By BaoXinjian
- 进程间通信机制(管道、信号、共享内存/信号量/消息队列)、线程间通信机制(互斥锁、条件变量、posix匿名信号量)
注:本分类下文章大多整理自<深入分析linux内核源代码>一书,另有参考其他一些资料如<linux内核完全剖析>.<linux c 编程一站式学习>等,只是为了更好 ...
- Linux内核中锁机制之信号量、读写信号量
在上一篇博文中笔者分析了关于内存屏障.读写自旋锁以及顺序锁的相关内容,本篇博文将着重讨论有关信号量.读写信号量的内容. 六.信号量 关于信号量的内容,实际上它是与自旋锁类似的概念,只有得到信号量的进程 ...