日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

第十九章、TIny4412 U-BOOT移植十九 LCD移植

發(fā)布時間:2023/12/31 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 第十九章、TIny4412 U-BOOT移植十九 LCD移植 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

這一篇主要參考博文,流程差不多,只是代碼內(nèi)容得自己寫

http://5istt.com/cookies/blog/?post=122

《s5pv-u-boot-2011.06之增加LCD顯示功能.PDF》的文檔

?

其實我一直就只想學一點東西,當時心太大了,就直接買了Tiny4412,才發(fā)現(xiàn)這是一塊硬骨頭,網(wǎng)上資料少的可憐,FriendlyARM給的資料基本就是代碼,說明性、講原理的東西也沒有。看了好久才發(fā)現(xiàn)其給的U-BOOT是不帶LCD顯示功能的,我就想給這個U-BOOT增加LCD顯示功能,我所有的學習過程,都是為了增加LCD功能而開展的。這一篇雖然也有參考別人成份,但絕大多數(shù)內(nèi)容都是我最近這段時間分析U-BOOT后,也進行相關(guān)裸機程序后(裸機代碼的實現(xiàn)我有一篇相關(guān)的說明文檔),有了一定的感覺,才順利完成的。

下面依據(jù)《s5pv-u -boot-2011.06之增加LCD顯示功能》的實現(xiàn)過程,來說明一下:我增加LCD功能的過程。

?

《s5pv-u-boot-2011.06之增加LCD顯示功能》上說,其主要完成 U-Boot 層可以在 LCD 上顯示字符,而且對于軟件分層的 U-Boot 來說,只要將底層驅(qū)動移植過來并調(diào)整好初始化參數(shù)就可以在LCD上顯示console。下圖17-1是LCD 驅(qū)動軟件分層執(zhí)行流程示意。可以看到 LCD 在執(zhí)行時最終調(diào)用的是底層的 board_video_init() 函數(shù),其主要作用是對 LCD控制寄存器進行初始化。可由用戶根據(jù)實際 LCD 硬件編寫。

這個功能的移植修改了5 個文件。

圖19-1、LCD 驅(qū)動軟件分層執(zhí)行流程示意


廢話不多說,開始按步驟說明吧:

我用的U-Boot代碼就是光盤中FriendlyARM提供的uboot_tiny4412-20130729.tgz。我的所有編輯操作都是在windows環(huán)境下,應(yīng)用sourcein sight等工具進行的,最后才到linux環(huán)境下面進行編譯。

第一步:增加底層頭文件

復(fù)制LCD裸機程序下的字庫文件,font_8x16.h,font_10x18.h,font_sun12x22.h到\uboot_tiny4412-lcd\include\下,這三個字庫文件是從Linux源碼下提取出來的。具體說明可參看我裸機LCD程序說明文檔。

接著,在\uboot_tiny4412-lcd\include\目錄下添加一個驅(qū)動程序所需的頭文件,文件名為zth_tiny4412_lcd.h,此文件是從我的LCD裸機程序里復(fù)制過來的。zth_tiny4412_lcd.h內(nèi)容如下,大家可以將其粘貼過去。

/****************************************

NAME:LCD.h

TRAD:

PROJECT:

CREATER:Zhang Taohua

DATA:2014-06-07

MAIL :zthvivid@163.com

DESCRIPTION:

?*****************************************/

?

#ifndef __LCD_H

#define __LCD_H

?

extern void lcd_init(void);

extern void lcd_draw_pixel(introw, int col, int color);

extern void lcd_clear_screen(intcolor);

extern void lcd_draw_hline(introw, int col1, int col2, int color);

extern void lcd_draw_vline(intcol, int row1, int row2, int color);

extern void lcd_draw_cross(introw, int col, int halflen, int color);

extern void led_blink(intlink_times);??

extern void delay(unsigned longcount);

extern void draw_point(int x, inty, int r, int g, int b);

//extern void memset_int(unsignedint * s, int c,unsigned int count);

extern void lcd_draw_bmp(constunsigned char gImage_bmp[]);

extern voidlcd_draw_char(unsigned char c);

?

#define readb(a)?????????????????? (*(volatile unsigned char*)(a))

#define readw(a)????????????????? (*(volatile unsigned short*)(a))

#define readl(a)??????????????????? (*(volatile unsigned int*)(a))

?

#define writeb(v,a)??????? (*(volatile unsigned char *)(a) = (v))

#define writew(v,a)????????????? (*(volatile unsigned short *)(a) =(v))

#define writel(v,a)???????? (*(volatile unsigned int *)(a) = (v))

?

//FONT

//#define FONT8_16? 1

//#define FONT10_18 1

#define FONT12_22? 1

?

#define FONT_STATIC_ROW 8

?

#if FONT8_16

#define FONT_ROW 8

#define FONT_COL 16

#endif

?

#if FONT10_18

#define FONT_ROW 10

#define FONT_COL? 18

#endif

?

#if FONT12_22?

#define FONT_ROW 12

#define FONT_COL? 22

#endif

?

//PICTURE

#define PICTURE_WIDTH

#define PICTURE_HEIGHT

?

//LCD Clock Relate Register

#define CLK_DIV_LCD (*(volatileunsigned int *)0x1003c534)

#define CLK_SRC_MASK_LCD(*(volatile unsigned int *)0x1003c334)

#define CLK_GATE_IP_LCD(*(volatile unsigned int *)0x1003c934)

#define CLK_SRC_LCD0 (*(volatileunsigned int *)0x1003c234)

?

//Framer Buffer Address And Size

?

//#define LCD_VIDEO_ADDR???? (0x54000000)????

//#define ?????? VIDEO_MEM_SIZE?0x200000??????? /* 800x480x24bit =0X119400 bytes */

?

//LED IO Control Regiester

#define GPM4CON ???? (*(volatile unsigned long *) 0x110002E0)

#define GPM4DAT??????? (*(volatile unsigned long *) 0x110002E4)

//LCD OP Control Regiester

#define GPF0CON??????? (*(volatile unsigned int *)0x11400180)

#define GPF0DAT???????? (*(volatile unsigned int *)0x11400184)

#define GPF0PUD??????? (*(volatile unsigned int *)0x11400188)

#define GPF0DRV??????? (*(volatile unsigned int *)0x1140018C)

?

#define GPF1CON ????? (*(volatile unsigned int *)0x114001a0)

#define GPF1DAT? ???? (*(volatileunsigned int *)0x114001a4)

#define GPF1PUD ?????? (*(volatile unsigned int *)0x114001a8)

#define GPF1DRV ?????? (*(volatile unsigned int *)0x114001ac)

?

#define GPF2CON??????? (*(volatile unsigned int *)0x114001c0)

#define GPF2DAT?? ??? (*(volatileunsigned int *)0x114001c4)

#define GPF2PUD ?????? (*(volatile unsigned int *)0x114001c8)

#define GPF2DRV ?????? (*(volatile unsigned int *)0x114001cc)

?

#define GPF3CON ????? (*(volatile unsigned int *)0x114001e0)

#define GPF3DAT? ???? (*(volatileunsigned int *)0x114001e4)

#define GPF3PUD ?????? (*(volatile unsigned int *)0x114001e8)

#define GPF3DRV ?????? (*(volatile unsigned int *)0x114001ec)

?

#define LCDBLK_CFG (*(volatileunsigned int *)0x10010210)

#define LCDBLK_CFG2 (*(volatileunsigned int *)0x10010214)

?

//LCD Control Register

#define LCD_BASE 0x11C00000

?

#define VIDCON0 ?????? (*(volatile unsigned int *)(LCD_BASE +0x0000))

#define VIDCON1 ?????? (*(volatile unsigned int *)(LCD_BASE +0x0004))

#define VIDCON2 ?????? (*(volatile unsigned int *)(LCD_BASE +0x0008))

#define VIDCON3 ?????? (*(volatile unsigned int *)(LCD_BASE +0x000C))

#define VIDTCON0 ???? (*(volatile unsigned int *)(LCD_BASE +0x0010))

#define VIDTCON1 ???? (*(volatile unsigned int *)(LCD_BASE +0x0014))

#define VIDTCON2 ???? (*(volatile unsigned int *)(LCD_BASE +0x0018))

#define VIDTCON3 ???? (*(volatile unsigned int *)(LCD_BASE +0x001C))

#define WINCON0 ????? (*(volatile unsigned int *)(LCD_BASE +0x0020))

#define WINCON1 ????? (*(volatile unsigned int *)(LCD_BASE +0x0024))

#define WINCON2 ????? (*(volatile unsigned int *)(LCD_BASE +0x0028))

#define WINCON3 ????? (*(volatile unsigned int *)(LCD_BASE + 0x002C))

#define WINCON4 ????? (*(volatile unsigned int *)(LCD_BASE +0x0030))

#define SHADOWCON ????? (*(volatile unsigned int *)(LCD_BASE +0x0034))

#define WINCHMAP2 (*(volatile unsigned int *)(LCD_BASE + 0x003C))

#define VIDOSD0A ???? (*(volatile unsigned int *)(LCD_BASE +0x0040))

#define VIDOSD0B ???? (*(volatile unsigned int *)(LCD_BASE +0x0044))

#define VIDOSD0C ???? (*(volatile unsigned int *)(LCD_BASE +0x0048))

#define VIDOSD1A ???? (*(volatile unsigned int *)(LCD_BASE +0x0050))

#define VIDOSD1B ???? (*(volatile unsigned int *)(LCD_BASE +0x0054))

#define VIDOSD1C ???? (*(volatile unsigned int *)(LCD_BASE +0x0058))

#define VIDOSD1D ??? (*(volatile unsigned int *)(LCD_BASE +0x005C))

#define VIDOSD2A ???? (*(volatile unsigned int *)(LCD_BASE +0x0060))

#define VIDOSD2B ???? (*(volatile unsigned int *)(LCD_BASE +0x0064))

#define VIDOSD2C ???? (*(volatile unsigned int *)(LCD_BASE +0x0068))

#define VIDOSD2D ??? (*(volatile unsigned int *)(LCD_BASE +0x006C))

#define VIDOSD3A ???? (*(volatile unsigned int *)(LCD_BASE +0x0070))

#define VIDOSD3B ???? (*(volatile unsigned int *)(LCD_BASE +0x0074))

#define VIDOSD3C ???? (*(volatile unsigned int *)(LCD_BASE +0x0078))

#define VIDOSD4A ???? (*(volatile unsigned int *)(LCD_BASE +0x0080))

#define VIDOSD4B ???? (*(volatile unsigned int *)(LCD_BASE +0x0084))

#define VIDOSD4C ???? (*(volatile unsigned int *)(LCD_BASE +0x0088))

#define VIDW00ADD0B0 ?? (*(volatile unsigned int *)(LCD_BASE +0x00A0))

#define VIDW00ADD0B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00A4))

#define VIDW00ADD0B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20A0))

#define VIDW01ADD0B0 ?? (*(volatile unsigned int *)(LCD_BASE +0x00A8))

#define VIDW01ADD0B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00AC))

#define VIDW01ADD0B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20A8))

#define VIDW02ADD0B0 ?? (*(volatile unsigned int *)(LCD_BASE +0x00B0))

#define VIDW02ADD0B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00B4))

#define VIDW02ADD0B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20B0))

#define VIDW03ADD0B0 ?? (*(volatile unsigned int *)(LCD_BASE + 0x00B8))

#define VIDW03ADD0B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00BC))

#define VIDW03ADD0B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20B8))

#define VIDW04ADD0B0 ?? (*(volatile unsigned int *)(LCD_BASE +0x00C0))

#define VIDW04ADD0B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00C4))

#define VIDW04ADD0B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20C0))

#define VIDW00ADD1B0 ?? (*(volatile unsigned int *)(LCD_BASE +0x00D0))

#define VIDW00ADD1B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00D4))

#define VIDW00ADD1B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20D0))

#define VIDW01ADD1B0 ?? (*(volatile unsigned int *)(LCD_BASE +0x00D8))

#define VIDW01ADD1B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00DC))

#define VIDW01ADD1B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20D8))

#define VIDW02ADD1B0 ?? (*(volatile unsigned int *)(LCD_BASE +0x00E0))

#define VIDW02ADD1B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00E4))

#define VIDW02ADD1B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20E0))

#define VIDW03ADD1B0 ?? (*(volatile unsigned int *)(LCD_BASE +0x00E8))

#define VIDW03ADD1B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00EC))

#define VIDW03ADD1B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20E8))

#define VIDW04ADD1B0 ?? (*(volatile unsigned int *)(LCD_BASE + 0x00F0))

#define VIDW04ADD1B1 ?? (*(volatile unsigned int *)(LCD_BASE +0x00F4))

#define VIDW04ADD1B2 ?? (*(volatile unsigned int *)(LCD_BASE +0x20F0))

#define VIDW00ADD2 ?????? (*(volatile unsigned int *)(LCD_BASE +0x0100))

#define VIDW01ADD2 ?????? (*(volatile unsigned int *)(LCD_BASE +0x0104))

#define VIDW02ADD2 ?????? (*(volatile unsigned int *)(LCD_BASE +0x0108))

#define VIDW03ADD2 ?????? (*(volatile unsigned int *)(LCD_BASE +0x010C))

#define VIDW04ADD2 ?????? (*(volatile unsigned int *)(LCD_BASE +0x0110))

#define VIDINTCON0 (*(volatile unsigned int *)(LCD_BASE + 0x0130))

#define VIDINTCON1 (*(volatile unsigned int *)(LCD_BASE + 0x0134))

#define W1KEYCON0 (*(volatile unsigned int *)(LCD_BASE + 0x0140))

#define VIDW0ALPHA0 ??? (*(volatile unsigned int *)(LCD_BASE +0x021C))

#define VIDW0ALPHA1 ??? (*(volatile unsigned int *)(LCD_BASE +0x0220))

#define VIDW1ALPHA0 ??? (*(volatile unsigned int *)(LCD_BASE +0x0224))

#define VIDW1ALPHA1 ??? (*(volatile unsigned int *)(LCD_BASE +0x0228))

#define VIDW2ALPHA0 ??? (*(volatile unsigned int *)(LCD_BASE +0x022C))

#define VIDW2ALPHA1 ??? (*(volatile unsigned int *)(LCD_BASE +0x0230))

#define VIDW3ALPHA0 ??? (*(volatile unsigned int *)(LCD_BASE +0x0234))

#define VIDW3ALPHA1 ??? (*(volatile unsigned int *)(LCD_BASE +0x0238))

#define VIDW4ALPHA0 ??? (*(volatile unsigned int *)(LCD_BASE +0x023C))

#define VIDW4ALPHA1 ??? (*(volatile unsigned int *)(LCD_BASE +0x0240))

??

/*

??*<Exyons 4412 datasheet pg1874 pg1848(時序)> <S700-AT070TN92 pg13(時序)>

??*VIDTCON0:

??*?????? ?? [23:16]:?VBPD + 1 <------> tvpw (1 - 20)?13

??*?????? ?? [15:8]: VFPD + 1 <------> tvfp 22

??*?????? ?? [7:0]: VSPW??? +1 <------> tvb - tvpw = 23 - 13 = 10

??* */

#define VBPD??????????????????????????? (22)? //12?22

#define VFPD????????????????????? (21)

#define VSPW??????????????????????????? (0)? //9???0

?

?/*<Exyons 4412 datasheet pg1874 pg1848(時序)> <S700-AT070TN92 pg13(時序)>

*VIDTCON1:

*??????????? [23:16]:? HBPD + 1 <------> thpw (1 - 40)? 36

*??????????? [15:8]:?? HFPD + 1 <------> thfp 210

*??????????? [7:0]:????? ?HSPW + 1 <------> thb - thpw= 46 - 36 = 10

* */

#define HBPD???????????????????? (45)? //35 45

#define HFPD?????????????? (209)

#define HSPW???????????????????? (0)? //9? 0

?

#define ROW?????????????????????? (480)

#define COL??????????????????????? (800)

#define HOZVAL???????????????? (COL-1)

#define LINEVAL??????????????? (ROW-1)// 479

?

/*

?*?Register offsets

*/

#define EXYNOS_WINCON(x)??????????????????????? (x * 0x04)

#define EXYNOS_VIDOSD(x)???????????????????????? (x * 0x10)

#define EXYNOS_BUFFER_OFFSET(x)?????????? (x * 0x08)

#define EXYNOS_BUFFER_SIZE(x)?????????????????????? (x * 0x04)

?

/*

?* Bit Definitions

*/

?

/* VIDCON0 */

#defineEXYNOS_VIDCON0_DSI_DISABLE???????????????? (0<< 30)

#define EXYNOS_VIDCON0_DSI_ENABLE????????????????? (1 << 30)

#defineEXYNOS_VIDCON0_SCAN_PROGRESSIVE?????????????????? (0<< 29)

#define EXYNOS_VIDCON0_SCAN_INTERLACE??????????????? (1 << 29)

#define EXYNOS_VIDCON0_SCAN_MASK?????????????????? (1 << 29)

#define EXYNOS_VIDCON0_VIDOUT_RGB????????????????? (0 << 26)

#define EXYNOS_VIDCON0_VIDOUT_ITU?????????????????? (1 << 26)

#defineEXYNOS_VIDCON0_VIDOUT_I80LDI0?????????????????? (2<< 26)

#defineEXYNOS_VIDCON0_VIDOUT_I80LDI1?????????????????? (3<< 26)

#defineEXYNOS_VIDCON0_VIDOUT_WB_RGB???????????????? (4<< 26)

#defineEXYNOS_VIDCON0_VIDOUT_WB_I80LDI0??????????? (6<< 26)

#defineEXYNOS_VIDCON0_VIDOUT_WB_I80LDI1??????????? (7<< 26)

#defineEXYNOS_VIDCON0_VIDOUT_MASK?????????????? (7<< 26)

#defineEXYNOS_VIDCON0_PNRMODE_RGB_P???????????????? (0<< 17)

#defineEXYNOS_VIDCON0_PNRMODE_BGR_P???????????????? (1<< 17)

#defineEXYNOS_VIDCON0_PNRMODE_RGB_S???????????????? (2<< 17)

#defineEXYNOS_VIDCON0_PNRMODE_BGR_S???????????????? (3<< 17)

#defineEXYNOS_VIDCON0_PNRMODE_MASK????????????????? (3<< 17)

#defineEXYNOS_VIDCON0_PNRMODE_SHIFT????????????????? (17)

#define EXYNOS_VIDCON0_CLKVALUP_ALWAYS??????????????????? (0 << 16)

#defineEXYNOS_VIDCON0_CLKVALUP_START_FRAME????????? (1<< 16)

#defineEXYNOS_VIDCON0_CLKVALUP_MASK???????????????? (1<< 16)

#defineEXYNOS_VIDCON0_CLKVAL_F(x)????????????????? (((x)& 0xff) << 6)

#defineEXYNOS_VIDCON0_VCLKEN_NORMAL??????????????? (0<< 5)

#define EXYNOS_VIDCON0_VCLKEN_FREERUN?????????????? (1 << 5)

#defineEXYNOS_VIDCON0_VCLKEN_MASK???????????????????? (1<< 5)

#defineEXYNOS_VIDCON0_CLKDIR_DIRECTED?????????????? (0<< 4)

#defineEXYNOS_VIDCON0_CLKDIR_DIVIDED???????????????? (1<< 4)

#defineEXYNOS_VIDCON0_CLKDIR_MASK?????????????? (1<< 4)

#define EXYNOS_VIDCON0_CLKSEL_HCLK??????????????? (0 << 2)

#defineEXYNOS_VIDCON0_CLKSEL_SCLK??????????????? (1<< 2)

#defineEXYNOS_VIDCON0_CLKSEL_MASK?????????????? (1<< 2)

#defineEXYNOS_VIDCON0_ENVID_ENABLE??????????????????? (1<< 1)

#defineEXYNOS_VIDCON0_ENVID_DISABLE?????????????????? (0<< 1)

#defineEXYNOS_VIDCON0_ENVID_F_ENABLE???????? (1<< 0)

#defineEXYNOS_VIDCON0_ENVID_F_DISABLE??????? (0<< 0)

?

/* VIDCON1 */

#defineEXYNOS_VIDCON1_VCLK_HOLD?????????????????????? (0 << 9)

#defineEXYNOS_VIDCON1_VCLK_RUNNING??????????????????? ???? (1 << 9)

#defineEXYNOS_VIDCON1_VCLK_RUNNING_DIS_VDEN (3<< 9)

#define EXYNOS_VIDCON1_IVCLK_FALLING_EDGE? (0 << 7)

#defineEXYNOS_VIDCON1_IVCLK_RISING_EDGE?????????? (1<< 7)

#defineEXYNOS_VIDCON1_IHSYNC_NORMAL????????? (0<< 6)

#defineEXYNOS_VIDCON1_IHSYNC_INVERT?????????????????? (1<< 6)

#defineEXYNOS_VIDCON1_IVSYNC_NORMAL????????? (0<< 5)

#defineEXYNOS_VIDCON1_IVSYNC_INVERT?????????????????? (1<< 5)

#defineEXYNOS_VIDCON1_IVDEN_NORMAL?????????????????? (0<< 4)

#defineEXYNOS_VIDCON1_IVDEN_INVERT???????????????????? (1<< 4)

?

/* VIDCON2 */

#defineEXYNOS_VIDCON2_EN601_DISABLE??????????????????? (0<< 23)

#defineEXYNOS_VIDCON2_EN601_ENABLE???????????????????? (1<< 23)

#define EXYNOS_VIDCON2_EN601_MASK????????????????? (1 << 23)

#define EXYNOS_VIDCON2_WB_DISABLE????????????????? (0 << 15)

#define EXYNOS_VIDCON2_WB_ENABLE?????????????????? (1 << 15)

#define EXYNOS_VIDCON2_WB_MASK????????????????????? (1 << 15)

#defineEXYNOS_VIDCON2_TVFORMATSEL_HW?????????????? (0<< 14)

#defineEXYNOS_VIDCON2_TVFORMATSEL_SW?????????????? (1<< 14)

#define EXYNOS_VIDCON2_TVFORMATSEL_MASK???????????????? (1 << 14)

#defineEXYNOS_VIDCON2_TVFORMATSEL_YUV422??????? (1<< 12)

#defineEXYNOS_VIDCON2_TVFORMATSEL_YUV444??????? (2<< 12)

#defineEXYNOS_VIDCON2_TVFORMATSEL_YUV_MASK??????? (3<< 12)

#defineEXYNOS_VIDCON2_ORGYUV_YCBCR?????????????????? (0<< 8)

#define EXYNOS_VIDCON2_ORGYUV_CBCRY?????????????????? (1 << 8)

#defineEXYNOS_VIDCON2_ORGYUV_MASK??????????????????? (1<< 8)

#defineEXYNOS_VIDCON2_YUVORD_CBCR???????????????????? (0<< 7)

#defineEXYNOS_VIDCON2_YUVORD_CRCB???????????????????? (1<< 7)

#defineEXYNOS_VIDCON2_YUVORD_MASK??????????????????? (1<< 7)

?

/* PRTCON */

#define EXYNOS_PRTCON_UPDATABLE????????????????????? (0 << 11)

#define EXYNOS_PRTCON_PROTECT????????????????????????? (1 << 11)

?

/* VIDTCON0 */

#define EXYNOS_VIDTCON0_VBPDE(x)?????????????? (((x) & 0xff) << 24)

#define EXYNOS_VIDTCON0_VBPD(x)??????????????????????? (((x) & 0xff)<< 16)

#define EXYNOS_VIDTCON0_VFPD(x)??????????????????????? (((x) & 0xff)<< 8)

#define EXYNOS_VIDTCON0_VSPW(x)??????????????????????? (((x) & 0xff)<< 0)

?

/* VIDTCON1 */

#define EXYNOS_VIDTCON1_VFPDE(x)?????????????? (((x) & 0xff) << 24)

#define EXYNOS_VIDTCON1_HBPD(x)??????????????????????? (((x) & 0xff)<< 16)

#define EXYNOS_VIDTCON1_HFPD(x)??????????????????????? (((x) & 0xff)<< 8)

#define EXYNOS_VIDTCON1_HSPW(x)??????????????????????? (((x) & 0xff)<< 0)

?

/* VIDTCON2 */

#defineEXYNOS_VIDTCON2_LINEVAL(x)?????????????????? (((x)& 0x7ff) << 11)

#define EXYNOS_VIDTCON2_HOZVAL(x)?????????????????????????? (((x) & 0x7ff)<< 0)

#defineEXYNOS_VIDTCON2_LINEVAL_E(x)?????????????? ((((x)& 0x800) >> 11) << 23)

#define EXYNOS_VIDTCON2_HOZVAL_E(x)??????????????? ((((x) & 0x800) >> 11)<< 22)

?

/* Window 0~4 Control - WINCONx*/

#defineEXYNOS_WINCON_DATAPATH_DMA???????????????????? (0<< 22)

#defineEXYNOS_WINCON_DATAPATH_LOCAL????????????????? (1<< 22)

#defineEXYNOS_WINCON_DATAPATH_MASK?????????????????? (1<< 22)

#define EXYNOS_WINCON_BUFSEL_0??????????????????????? (0 << 20)

#define EXYNOS_WINCON_BUFSEL_1??????????????????????? (1 << 20)

#define EXYNOS_WINCON_BUFSEL_MASK??????????????? (1 << 20)

#defineEXYNOS_WINCON_BUFSEL_SHIFT??????????????? (20)

#defineEXYNOS_WINCON_BUFAUTO_DISABLE?????????????? (0<< 19)

#defineEXYNOS_WINCON_BUFAUTO_ENABLE??????????????? (1<< 19)

#define EXYNOS_WINCON_BUFAUTO_MASK??????????????????? (1 << 19)

#defineEXYNOS_WINCON_BITSWP_DISABLE????????????????? (0<< 18)

#defineEXYNOS_WINCON_BITSWP_ENABLE?????????????????? (1<< 18)

#defineEXYNOS_WINCON_BITSWP_SHIFT??????????????? (18)

#defineEXYNOS_WINCON_BYTESWP_DISABLE?????????????? (0<< 17)

#defineEXYNOS_WINCON_BYTESWP_ENABLE???????? ?????? (1 << 17)

#defineEXYNOS_WINCON_BYTESWP_SHIFT??????????????????? (17)

#defineEXYNOS_WINCON_HAWSWP_DISABLE??????????????? (0<< 16)

#defineEXYNOS_WINCON_HAWSWP_ENABLE???????????????? (1<< 16)

#defineEXYNOS_WINCON_HAWSWP_SHIFT???????????????????? (16)

#defineEXYNOS_WINCON_WSWP_DISABLE???????????????????? (0<< 15)

#define EXYNOS_WINCON_WSWP_ENABLE?????????????? (1 << 15)

#define EXYNOS_WINCON_WSWP_SHIFT?????????????????? (15)

#define EXYNOS_WINCON_INRGB_RGB??????????????????????????? (0 << 13)

#define EXYNOS_WINCON_INRGB_YUV??????????????????????????? (1 << 13)

#define EXYNOS_WINCON_INRGB_MASK????????????????? (1 << 13)

#defineEXYNOS_WINCON_BURSTLEN_16WORD???????????????????? (0<< 9)

#defineEXYNOS_WINCON_BURSTLEN_8WORD??????????????? (1<< 9)

#defineEXYNOS_WINCON_BURSTLEN_4WORD??????????????? (2<< 9)

#defineEXYNOS_WINCON_BURSTLEN_MASK????????????????? (3<< 9)

#defineEXYNOS_WINCON_ALPHA_MULTI_DISABLE????????????? (0<< 7)

#defineEXYNOS_WINCON_ALPHA_MULTI_ENABLE??????? (1<< 7)

#define EXYNOS_WINCON_BLD_PLANE??????????????????????????? (0 << 6)

#define EXYNOS_WINCON_BLD_PIXEL????????????????????? (1 << 6)

#define EXYNOS_WINCON_BLD_MASK????????????????????? (1 << 6)

#defineEXYNOS_WINCON_BPPMODE_1BPP???????????????????? (0<< 2)

#defineEXYNOS_WINCON_BPPMODE_2BPP???????????????????? (1<< 2)

#defineEXYNOS_WINCON_BPPMODE_4BPP???????????????????? (2<< 2)

#defineEXYNOS_WINCON_BPPMODE_8BPP_PAL??????????????????? (3<< 2)

#defineEXYNOS_WINCON_BPPMODE_8BPP???????????????????? (4<< 2)

#defineEXYNOS_WINCON_BPPMODE_16BPP_565??????????????????? (5<< 2)

#defineEXYNOS_WINCON_BPPMODE_16BPP_A555????????? (6<< 2)

#defineEXYNOS_WINCON_BPPMODE_18BPP_666??????????????????? (8<< 2)

#defineEXYNOS_WINCON_BPPMODE_18BPP_A665????????? (9<< 2)

#defineEXYNOS_WINCON_BPPMODE_24BPP_888??????????????????? (0xb<< 2)

#defineEXYNOS_WINCON_BPPMODE_24BPP_A887????????? (0xc<< 2)

#defineEXYNOS_WINCON_BPPMODE_32BPP??????????????????? (0xd<< 2)

#defineEXYNOS_WINCON_BPPMODE_16BPP_A444????????? (0xe<< 2)

#defineEXYNOS_WINCON_BPPMODE_15BPP_555??????????????????? (0xf<< 2)

#defineEXYNOS_WINCON_BPPMODE_MASK?????????????????? (0xf<< 2)

#defineEXYNOS_WINCON_BPPMODE_SHIFT??????????????????? (2)

#define EXYNOS_WINCON_ALPHA0_SEL?????????????????? (0 << 1)

#define EXYNOS_WINCON_ALPHA1_SEL?????????????????? (1 << 1)

#define EXYNOS_WINCON_ALPHA_SEL_MASK??????????????? (1 << 1)

#defineEXYNOS_WINCON_ENWIN_DISABLE?????????????????? (0<< 0)

#defineEXYNOS_WINCON_ENWIN_ENABLE??????????????????? (1<< 0)

?

/* WINCON1 special */

#define EXYNOS_WINCON1_VP_DISABLE????????????????? (0 << 24)

#define EXYNOS_WINCON1_VP_ENABLE?????????????????? (1 << 24)

#define EXYNOS_WINCON1_LOCALSEL_FIMC1??????????????? (0 << 23)

#defineEXYNOS_WINCON1_LOCALSEL_VP?????????????? (1<< 23)

#defineEXYNOS_WINCON1_LOCALSEL_MASK???????????????? (1<< 23)

?

/* WINSHMAP */

#defineEXYNOS_WINSHMAP_PROTECT(x)??????????????? (((x)& 0x1f) << 10)

#defineEXYNOS_WINSHMAP_CH_ENABLE(x)????????????????? ?????? (1 << (x))

#define EXYNOS_WINSHMAP_CH_DISABLE(x)???????????????? (~(7 << (x)))

#defineEXYNOS_WINSHMAP_LOCAL_ENABLE(x)?????????????????? (0x20<< (x))

#defineEXYNOS_WINSHMAP_LOCAL_DISABLE(x)?????????? (0x20<< (x))

?

/* VIDOSDxA, VIDOSDxB */

#define EXYNOS_VIDOSD_LEFT_X(x)???????????????????????? (((x) & 0x7ff)<< 11)

#define EXYNOS_VIDOSD_TOP_Y(x)?????????????????????????? (((x) & 0x7ff)<< 0)

#define EXYNOS_VIDOSD_RIGHT_X(x)??????????????? (((x) & 0x7ff) << 11)

#define EXYNOS_VIDOSD_BOTTOM_Y(x)?????????????????? (((x) & 0x7ff) <<0)

#defineEXYNOS_VIDOSD_RIGHT_X_E(x)?????????????????? (((x)& 0x1) << 23)

#defineEXYNOS_VIDOSD_BOTTOM_Y_E(x)?????????????? (((x)& 0x1) << 22)

?

/* VIDOSD0C, VIDOSDxD */

#define EXYNOS_VIDOSD_SIZE(x)?????????????????????? (((x) & 0xffffff)<< 0)

?

/* VIDOSDxC (1~4) */

#define EXYNOS_VIDOSD_ALPHA0_R(x)??????????????????? (((x) & 0xf) <<20)

#define EXYNOS_VIDOSD_ALPHA0_G(x)??????????????????? (((x) & 0xf) <<16)

#define EXYNOS_VIDOSD_ALPHA0_B(x)??????????????????? (((x) & 0xf) <<12)

#define EXYNOS_VIDOSD_ALPHA1_R(x)??????????????????? (((x) & 0xf) << 8)

#define EXYNOS_VIDOSD_ALPHA1_G(x)??????????????????? (((x) & 0xf) << 4)

#define EXYNOS_VIDOSD_ALPHA1_B(x)??????????????????? (((x) & 0xf) << 0)

#defineEXYNOS_VIDOSD_ALPHA0_SHIFT???????????????? (12)

#define EXYNOS_VIDOSD_ALPHA1_SHIFT???????????????? (0)

?

/* Start Address */

#defineEXYNOS_VIDADDR_START_VBANK(x)???????????????? (((x)& 0xff) << 24)

#defineEXYNOS_VIDADDR_START_VBASEU(x)??????????????? (((x)& 0xffffff) << 0)

?

/* End Address */

#defineEXYNOS_VIDADDR_END_VBASEL(x)?????????????????? (((x)& 0xffffff) << 0)

?

/* Buffer Size */

#define EXYNOS_VIDADDR_OFFSIZE(x)???????????????????? (((x) & 0x1fff)<< 13)

#defineEXYNOS_VIDADDR_PAGEWIDTH(x)???????????????????? (((x)& 0x1fff) << 0)

#defineEXYNOS_VIDADDR_OFFSIZE_E(x)???????????????? ((((x)& 0x2000) >> 13) << 27)

#defineEXYNOS_VIDADDR_PAGEWIDTH_E(x)???????????????? ((((x)& 0x2000) >> 13) << 26)

?

/* WIN Color Map */

#define EXYNOS_WINMAP_COLOR(x)???????????????????????? ((x) & 0xffffff)

?

/* VIDINTCON0 */

#defineEXYNOS_VIDINTCON0_SYSMAINCON_DISABLE??????? (0<< 19)

#defineEXYNOS_VIDINTCON0_SYSMAINCON_ENABLE???????? (1<< 19)

#defineEXYNOS_VIDINTCON0_SYSSUBCON_DISABLE?????????? (0<< 18)

#defineEXYNOS_VIDINTCON0_SYSSUBCON_ENABLE??????????? (1<< 18)

#defineEXYNOS_VIDINTCON0_SYSIFDONE_DISABLE??????????? (0<< 17)

#defineEXYNOS_VIDINTCON0_SYSIFDONE_ENABLE???????????? (1<< 17)

#defineEXYNOS_VIDINTCON0_FRAMESEL0_BACK????????? (0<< 15)

#define EXYNOS_VIDINTCON0_FRAMESEL0_VSYNC????????????? (1 << 15)

#defineEXYNOS_VIDINTCON0_FRAMESEL0_ACTIVE???????????? (2<< 15)

#defineEXYNOS_VIDINTCON0_FRAMESEL0_FRONT??????? (3<< 15)

#defineEXYNOS_VIDINTCON0_FRAMESEL0_MASK???????? (3<< 15)

#defineEXYNOS_VIDINTCON0_FRAMESEL1_NONE???????? (0<< 13)

#define EXYNOS_VIDINTCON0_FRAMESEL1_BACK????????? (1 << 13)

#defineEXYNOS_VIDINTCON0_FRAMESEL1_VSYNC????????????? (2<< 13)

#defineEXYNOS_VIDINTCON0_FRAMESEL1_FRONT??????? (3<< 13)

#defineEXYNOS_VIDINTCON0_INTFRMEN_DISABLE????????????? (0<< 12)

#defineEXYNOS_VIDINTCON0_INTFRMEN_ENABLE??????? (1<< 12)

#defineEXYNOS_VIDINTCON0_FIFOSEL_WIN4??????????????? (1<< 11)

#defineEXYNOS_VIDINTCON0_FIFOSEL_WIN3??????????????? (1<< 10)

#defineEXYNOS_VIDINTCON0_FIFOSEL_WIN2??????????????? (1<< 9)

#defineEXYNOS_VIDINTCON0_FIFOSEL_WIN1??????????????? (1<< 6)

#defineEXYNOS_VIDINTCON0_FIFOSEL_WIN0??????????????? (1<< 5)

#define EXYNOS_VIDINTCON0_FIFOSEL_ALL?????????????????? (0x73 << 5)

#defineEXYNOS_VIDINTCON0_FIFOSEL_MASK?????????????? (0x73<< 5)

#defineEXYNOS_VIDINTCON0_FIFOLEVEL_25???????????????? (0<< 2)

#defineEXYNOS_VIDINTCON0_FIFOLEVEL_50???????????????? (1<< 2)

#defineEXYNOS_VIDINTCON0_FIFOLEVEL_75???????????????? (2<< 2)

#define EXYNOS_VIDINTCON0_FIFOLEVEL_EMPTY???????? (3 << 2)

#defineEXYNOS_VIDINTCON0_FIFOLEVEL_FULL??????????? (4<< 2)

#defineEXYNOS_VIDINTCON0_FIFOLEVEL_MASK????????? (7<< 2)

#defineEXYNOS_VIDINTCON0_INTFIFO_DISABLE?????????? (0<< 1)

#defineEXYNOS_VIDINTCON0_INTFIFO_ENABLE??????????? (1<< 1)

#define EXYNOS_VIDINTCON0_INT_DISABLE?????????????????? (0 << 0)

#defineEXYNOS_VIDINTCON0_INT_ENABLE??????????????????? (1<< 0)

#defineEXYNOS_VIDINTCON0_INT_MASK??????????????? (1<< 0)

?

/* VIDINTCON1 */

#defineEXYNOS_VIDINTCON1_INTVPPEND???????????????????? (1<< 5)

#defineEXYNOS_VIDINTCON1_INTI80PEND???????????????????? (1<< 2)

#define EXYNOS_VIDINTCON1_INTFRMPEND?????????????????? (1 << 1)

#defineEXYNOS_VIDINTCON1_INTFIFOPEND????????????????? (1<< 0)

?

/* WINMAP */

#define EXYNOS_WINMAP_ENABLE?????????????????????????? (1 << 24)

?

/* WxKEYCON0 (1~4) */

#defineEXYNOS_KEYCON0_KEYBLEN_DISABLE??????????????????? (0<< 26)

#defineEXYNOS_KEYCON0_KEYBLEN_ENABLE???????????????????? (1<< 26)

#defineEXYNOS_KEYCON0_KEY_DISABLE?????????????? (0<< 25)

#define EXYNOS_KEYCON0_KEY_ENABLE??????????????? (1 << 25)

#defineEXYNOS_KEYCON0_DIRCON_MATCH_FG??????????????????? (0<< 24)

#defineEXYNOS_KEYCON0_DIRCON_MATCH_BG?????????????????? (1<< 24)

#define EXYNOS_KEYCON0_COMPKEY(x)???????????????? (((x) & 0xffffff) <<0)

?

/* WxKEYCON1 (1~4) */

#define EXYNOS_KEYCON1_COLVAL(x)???????????????????? (((x) & 0xffffff)<< 0)

?

/* DUALRGB */

#defineEXYNOS_DUALRGB_BYPASS_SINGLE????????????????? (0x00<< 0)

#defineEXYNOS_DUALRGB_BYPASS_DUAL???????????????????? (0x01<< 0)

#define EXYNOS_DUALRGB_MIE_DUAL??????????????????????????? (0x10 << 0)

#define EXYNOS_DUALRGB_MIE_SINGLE????????????????? (0x11 << 0)

#define EXYNOS_DUALRGB_LINESPLIT???????????????????? (0x0 << 2)

#define EXYNOS_DUALRGB_FRAMESPLIT???????????????? (0x1 << 2)

#define EXYNOS_DUALRGB_SUB_CNT(x)?????????????????? ((x & 0xfff) << 4)

#defineEXYNOS_DUALRGB_VDEN_EN_DISABLE??????????????????? (0x0<< 16)

#define EXYNOS_DUALRGB_VDEN_EN_ENABLE???????????????????? (0x1 << 16)

#defineEXYNOS_DUALRGB_MAIN_CNT(x)??????????????? ((x& 0xfff) << 18)

?

/* I80IFCONA0 and I80IFCONA1 */

#define EXYNOS_LCD_CS_SETUP(x)?????????????????????????? (((x) & 0xf)<< 16)

#define EXYNOS_LCD_WR_SETUP(x)????????????????????????? (((x) & 0xf)<< 12)

#define EXYNOS_LCD_WR_ACT(x)?????????????????????? (((x) & 0xf) <<8)

#define EXYNOS_LCD_WR_HOLD(x)?????????????????????????? (((x) & 0xf)<< 4)

#define EXYNOS_RSPOL_LOW????????????????????? (0 << 2)

#define EXYNOS_RSPOL_HIGH??????????????????????????? (1 << 2)

#define EXYNOS_I80IFEN_DISABLE?????????????????????????? (0 << 0)

#define EXYNOS_I80IFEN_ENABLE??????????????????????????? (1 << 0)

?

/* TRIGCON */

#define EXYNOS_I80SOFT_TRIG_EN?????????????????????????? (1 << 0)

#define EXYNOS_I80START_TRIG???????????????????????? (1 << 1)

#defineEXYNOS_I80STATUS_TRIG_DONE????????????????? (1<< 2)

?

/* DP_MIE_CLKCON */

#define EXYNOS_DP_MIE_DISABLE?????????????????????????? (0 << 0)

#define EXYNOS_DP_CLK_ENABLE??????????????????????????? (1 << 1)

#define EXYNOS_MIE_CLK_ENABLE????????????????????????? (3 << 0)

?

#endif

第二步:增加底層驅(qū)動文件

在\uboot_tiny4412-lcd \drivers\video\目錄下添加一個底層驅(qū)動程序文件,文件名為zth_tiny4412_lcd.c,此文件是從我的LCD裸機程序里復(fù)制過來后,進行點點修改的。zth_tiny4412_lcd.c內(nèi)容如下,大家可以將其粘貼過去。

?????? /****************************************

NAME:LCD.C

TRAD:/USER/

PROJECT:

CREATER:Zhang Taohua

DATA:2014-05-07

DESCRIPTION:

?

?LCD relation function

?

?*****************************************/

?

//#include "stdio.h"

#include "videomodes.h"

#include <config.h>

#include <common.h>

#include <video_fb.h>

#include <lcd.h>

#include<zth_tiny4412_lcd.h>

?

#if FONT8_16

#include <font_8x16.h>

#endif

?

#if FONT10_18

#include <font_10x18.h>

#endif

?

?

#if FONT12_22?

#include <font_sun12x22.h>

#endif

?

?

#ifdefined(CONFIG_LCD_EXYNOS4412)//add by zth

?

void delay(unsigned long count)

{

?????? volatileunsigned long j,i = count;

?????? for(;i>0;i--)

????????????? {

???????????????????? for(j=0x20000;j>0;j--){}

????????????? }

}

?

/*void memset_int(unsigned int *s, int c,unsigned int count)

{

?????? unsignedint *xs = (unsigned int *) s;

?

?????? while(count--)

????????????? *xs++= c;

?

?????? //returns;

}

*/

?

?

/****************************************

FUNCTION :led_blink()

PARAMETERS:??? link_times : blink times

REMARKS:

EXAMPLE

?

SEE ALSO:

DATA:

?*****************************************/

?

void led_blink(int link_times)?????????????

{

?????? GPM4CON= 0x00001111;????????????????? //IO SET

?????? inti;

?????? for(i=0;i<= link_times;i++)

?????? {

????????????? GPM4DAT= 0;?????????????????????????? // LED on

????????????? delay(0x2);

????????????? GPM4DAT= 0xf;??????????????????????? // LED off

????????????? delay(0x2);

?????? }

?

}

?

/****************************************

FUNCTION :led_blink()

PARAMETERS:??? link_times : blink times

REMARKS:

EXAMPLE

?

SEE ALSO:

DATA:

?*****************************************/

?

DECLARE_GLOBAL_DATA_PTR;

GraphicDevice smi;

?

//extern voidboard_video_init(GraphicDevice *pGD);

?

?

void *video_hw_init (void)

{

?

??????

??? GraphicDevice *pGD = (GraphicDevice*)&smi;

??? int videomode;

??? unsigned long t1, hsynch, vsynch;

??? char *penv;

??? int tmp, i, bits_per_pixel;

??? struct ctfb_res_modes *res_mode;

??? struct ctfb_res_modes var_mode;

??? int clkval;

?????? unsignedlong long src_clock;

?????? unsignedint cfg = 0, div = 0, remainder, remainder_div;

??????

?

?????? //indicateLCD start Init

??????

?????? printf("addby zth now? now is in zthtiny_fb.c ;video_hw_init() \n ");

?????? printf("modifyby zth, Strat to Init the lCD\r\n");

?

??? /*

???? *SET IO IS LCD

???? *<Exyons 4412 datasheet pg138 pg141pg144 pg147>

???? *

???? * GPF0CON : [31:0] : 0x2

???? * GPF1CON : [31:0] : 0x2

???? * GPF2CON : [31:0] : 0x2

???? * GPF3CON : [31:0] : 0x2

???? * */??????

?

?????? GPF0CON= 0x22222222;????????????????????????

?????? GPF1CON= 0x22222222;

?????? GPF2CON= 0x22222222;

?????? GPF3CON= 0x00222222;

?????? //Set pull-up,down disable

?????? GPF0PUD= 0x0000FFFF;

?????? GPF1PUD= 0x0000FFFF;

?????? GPF2PUD= 0x0000FFFF;

?????? GPF3PUD= 0x00000FFF;

??????

?????? //MAXdrive strength---------//

?????? GPF0DRV= 0x0000FFFF;

?????? GPF1DRV= 0x0000FFFF;

?????? GPF2DRV= 0x0000FFFF;

?????? GPF3DRV= 0x00000FFF;

??? /*

???? *<Exyons 4412 datasheet pg526>

???? *CLK_DIV_LCD:

???? *????????????? [3:0]:FIMD0_RATIO?? 0

???? *????????????? SCLK_FIMD0 =MOUTFIMD0/(FIMD0_RATIO + 1)

???? *???????????????????????? = MOUTFIMD0/1 = 800MHz

???? *????????????? MOUTFIMD0 == SCLKmpll_user_t ==800MHz????? <Exyons 4412 datasheetpg453> LCD0_BLK

???? * */

?????? CLK_DIV_LCD&= ~0xf;

??? /*

???? *<Exyons 4412 datasheet pg501>

???? *CLK_SRC_LCD0:

???? *?????????[3:0]:FIMD0_SEL 0110 ===> SCLKmpll_user_t 選擇時鐘源為SCLKmpll_user_t

???? *

???? * */

?????? CLK_SRC_LCD0&= ~0xf;

?????? CLK_SRC_LCD0|= 6;

?????? //LCD0_SYS_PWR_REG== 7 Don't use

???

???

??? /*<Exyons 4412 datasheet pg1799>

???? *Using the display controller data, youcan select one of the above data paths by setting LCDBLK_CFG Register

???? *(0x1001_0210). For more information,refer to the "System Others" manual.

???? *

???? *

???? * <Exyons 4412 datasheet pg880>

???? * LCDBLK_CFG:

???? *?????????[1] : FIMD of LBLK0 Bypass Selection???1 : FIMD Bypass 使用FIMD接口

???? *

???? * LCDBLK_CFG :

???? *?????????[0]:MIE0_DISPON???? 1 :? PWM outpupt enable

???? *

???? *

???? * */

?????? LCDBLK_CFG|= 1 << 1;

??? LCDBLK_CFG2 |= 1;

?

?????? printf("Video:");

??? tmp = 0;

??? videomode = CONFIG_SYS_DEFAULT_VIDEO_MODE;

??? /* get video mode via environment */

??? if ((penv = getenv ("videomode"))!= NULL) {

??????? /* deceide if it is a string */

??????? if (penv[0] <= '9') {

??????????? videomode = (int) simple_strtoul(penv, NULL, 16);

??????????? tmp = 1;

??????? }

??? } else {

??????? tmp = 1;

??? }

?if (tmp){

??? /* parameter are vesa modes */

??? /* search params */

????? ??for (i = 0; i < VESA_MODES_COUNT; i++) {

??????????? if (vesa_modes[i].vesanr ==videomode)

??????????? break;

??????? }

??????? if (i == VESA_MODES_COUNT) {

???????????????????????? printf ("no VESAMode found, switching to mode 0x%x ", CONFIG_SYS_DEFAULT_VIDEO_MODE);

??????????? i = 0;

??????? }

??????? res_mode =(struct ctfb_res_modes *)&res_mode_init[vesa_modes[i].resindex];

??????? bits_per_pixel =vesa_modes[i].bits_per_pixel;

??? } else {

??????? res_mode = (struct ctfb_res_modes *)&var_mode;

???????bits_per_pixel =video_get_params (res_mode, penv);

??? }

?

?????? ?printf("add by zth now calculate hsynchand vsynch freq (info only )\n ");

??? /* calculate hsynch and vsynch freq (infoonly) */

??? t1 = (res_mode->left_margin +res_mode->xres + res_mode->right_margin + res_mode->hsync_len) / 8;

??? t1 *= 8;

??? t1 *= res_mode->pixclock;

?????? printf("addby zth;res_mode->pixclock= %d\n ",res_mode->pixclock);

??? t1 /= 1000;

??? hsynch = 1000000000L / t1;

??? t1 *= (res_mode->upper_margin +res_mode->yres + res_mode->lower_margin + res_mode->vsync_len);

??? t1 /= 1000;

??? vsynch = 1000000000L / t1;

??? /* fill in Graphic device struct */

??? sprintf (pGD->modeIdent, "%dx%dx%d%ldkHz %ldHz", res_mode->xres, res_mode->yres, bits_per_pixel,(hsynch /

1000), (vsynch / 1000));

??? printf ("%s\n",pGD->modeIdent);

??? pGD->winSizeX = res_mode->xres;

??? pGD->winSizeY = res_mode->yres;

??? pGD->plnSizeX = res_mode->xres;

??? pGD->plnSizeY = res_mode->yres;?????

?

?????? printf("bits_per_pixel%d\n ",bits_per_pixel);

??? switch (bits_per_pixel) {

??? case 8:

?????????? pGD->gdfBytesPP = 1;

?????????? pGD->gdfIndex = GDF__8BIT_INDEX;

?????????? break;

??? case 15:

?????????? pGD->gdfBytesPP = 2;

?????????? pGD->gdfIndex = GDF_15BIT_555RGB;

?????????? break;

??? case 16:

????????? ?pGD->gdfBytesPP = 2;

?????????? pGD->gdfIndex = GDF_16BIT_565RGB;

?????????? break;

??? case 24:

?????????? pGD->gdfBytesPP = 4;

?????????? pGD->gdfIndex = GDF_24BIT_888RGB;

?????????? break;

??case 32:

?????????? pGD->gdfBytesPP = 4;

?????????? pGD->gdfIndex =GDF_32BIT_X888RGB;

?????????? break;

??? }

?

?????? //pGD->frameAdrs= gd->fb_base;

?????? pGD->frameAdrs= LCD_VIDEO_ADDR;

?????? pGD->memSize= VIDEO_MEM_SIZE;

?????? /*Clear video memory */

??????

?????? memset((void*)pGD->frameAdrs, 0xFF00, pGD->memSize);

??// memset(LCD_VIDEO_ADDR, 0xFF00, VIDEO_MEM_SIZE);

?

??/*

???? *<Exyons 4412 datasheet pg1869>

???? *VIDCON0:

???? *????[13:6]: CLKVAL_F???? //設(shè)置LCD時鐘分頻系數(shù)

???? *

???? *?VCLK == 33.3Mhz????????<S700-AT070TN92 pg14> DCLK?Frequency ===> Type : 33.3Mhz

???? *?VCLK = FIMD * SCLK/(CLKVAL+1)

???? *?VCLK =? 800000000 / (CLKVAL +1)??

???? *?33300000 = 800000000 /(CLKVAL + 1)

???? *?CLKVAL + 1 = 24.02

???? *?CLKVAL = 23

???? * */

?

??? t1 = res_mode->pixclock;

??? t1 /= 1000;

??? t1 = 1000000000L / t1;

??? clkval = (CONFIG_SYS_VIDEO_VCLOCK_HZ / t1)- 1;

??? //clkval = (800000000 / 33300000) - 1;

????

??? // VIDCON0 = (23 << 6);

?????? VIDCON0=? EXYNOS_VIDCON0_CLKVAL_F(clkval);

??????

?????? printf("VIDCON0= %d? or %d? \r\n",(23 <<6),EXYNOS_VIDCON0_CLKVAL_F(clkval));

??? /*

???? *<Exyons 4412 datasheet pg1870 pg1848(時序)> <S700-AT070TN92 pg13(時序)>

???? *VIDTCON1:

???? *?????[5]:IVSYNC? ===> 1 : Inverted(反轉(zhuǎn))

???? *?????[6]:IHSYNC? ===> 1 : Inverted(反轉(zhuǎn))

???? *?????[7]:IVCLK?? ===> 1 : Fetchesvideo data at VCLK rising edge (下降沿觸發(fā))

???? *?? ???[10:9]:FIXVCLK? ====> 01 : VCLK running

???? * */

?

?????? //VIDCON1= (1 << 9) | (1 << 7) | (1 << 5) | (1 << 6);

?????? VIDCON1=? ( EXYNOS_VIDCON1_VCLK_RUNNING |

??????????????????????????? ?EXYNOS_VIDCON1_IVCLK_RISING_EDGE|

??????????????????????????? ?EXYNOS_VIDCON1_IVSYNC_INVERT |

??????????????????????????? ?EXYNOS_VIDCON1_IHSYNC_INVERT);???? ???

??????

?????? /*

?????? printf("VIDCON1= %d? or %d? \r\n",(1 << 9) | (1 << 7) |(1 << 5) | (1 << 6),

??????????????????????????????????????????????????????? EXYNOS_VIDCON1_VCLK_RUNNING|

??????????????????????????? ? ???????????????????????? EXYNOS_VIDCON1_IVCLK_RISING_EDGE|

??????????????????????????? ? ???????????????????????? EXYNOS_VIDCON1_IVSYNC_INVERT|

??????????????????????????? ?? ?????????????????????? EXYNOS_VIDCON1_IHSYNC_INVERT);

?????? */

??????

??/*

???? *<Exyons 4412 datasheet pg1874 pg1848(時序)> <S700-AT070TN92 pg13(時序)>

???? *VIDTCON0:

???? *??????[23:16]:? VBPD + 1 <------>tvpw (1 - 20)? 13

???? *??????[15:8]: VFPD + 1 <------> tvfp 22

???? *??????[7:0]: VSPW? + 1 <------>tvb - tvpw = 23 - 13 = 10

???? * */

???? //? VIDTCON0 = (12 << 16) | (21 << 8)| (9);??

???? // VIDTCON0 = (22 << 16)| (21 << 8) | (0);

?????? /*VIDTCON0= ( EXYNOS_VIDTCON0_VBPD(VBPD) |??????

??????????????????????????? ?EXYNOS_VIDTCON0_VFPD(VFPD) |

??????????????????????????? ?EXYNOS_VIDTCON0_VSPW(VSPW));??

?????? */

?????? VIDTCON0= ( EXYNOS_VIDTCON0_VBPD(res_mode->upper_margin) |???

??????????????????????????? ?EXYNOS_VIDTCON0_VFPD(res_mode->lower_margin)|

??????????????????????????? ?EXYNOS_VIDTCON0_VSPW(res_mode->vsync_len));??

??????

?

?????? printf("VIDTCON0= is 22,21,0 %d; %d; %d; \r\n",?res_mode->upper_margin,

?????????????????????????????????????????????????????????????? ??????????????????????????? ? res_mode->lower_margin,

?????????????????????????????????????????????????????????????????????????????????????????? ? res_mode->vsync_len);

?

?????? /*<Exyons4412 datasheet pg1874 pg1848(時序)><S700-AT070TN92 pg13(時序)>

???? *VIDTCON1:

???? *??????[23:16]:? HBPD + 1 <------>thpw (1 - 40)? 36

???? *??????[15:8]:?? HFPD + 1 <------>thfp 210

???? *??????[7:0]:??? HSPW? + 1 <------> thb - thpw = 46 - 36 = 10

???? */

???? ???? //VIDTCON1= (35 << 16) | (209 << 8) | (9);

??? ?????? //VIDTCON1= (45 << 16) | (209 << 8) | (0);

?????? /*??? VIDTCON1 = ( EXYNOS_VIDTCON1_HBPD(HBPD) |

??????????????????????????? ??? EXYNOS_VIDTCON1_HFPD(HFPD) |

??????????????????????????? ??? EXYNOS_VIDTCON1_HSPW(HSPW));?

?????? */

?????? VIDTCON1= ( EXYNOS_VIDTCON1_HBPD(res_mode->left_margin) |

??????????????????????????? ???EXYNOS_VIDTCON1_HFPD(res_mode->right_margin) |

??????????????????????????? ???EXYNOS_VIDTCON1_HSPW(res_mode->hsync_len));?

??????

?????? printf("VIDTCON1= is 45,209,0 %d; %d; %d; \r\n",?res_mode->left_margin,

?????????????????????????????????????????????????????????????????????????????????????????? ? res_mode->right_margin,

?????????????????????????????????????????????????????????????????????????????????????????? ? res_mode->hsync_len);

?

??? /*

???? *<Exyons 4412 datasheet pg1875>

???? *

???? *HOZVAL = (Horizontal display size) – 1and LINEVAL = (Vertical display size) – 1.

???? * Horizontal(水平) display size : 800

???? *Vertical(垂直) display size : 480

???? * */

?

?????? //VIDTCON2= (479 << 11) | 799;

?????? /*VIDTCON2= ( EXYNOS_VIDTCON2_LINEVAL(LINEVAL) |

??????????????????????????? ?EXYNOS_VIDTCON2_HOZVAL(HOZVAL));

?????? */

?

?????? VIDTCON2= ( EXYNOS_VIDTCON2_LINEVAL(pGD->winSizeY - 1) |

?????????????????????????????????? ?EXYNOS_VIDTCON2_HOZVAL(pGD->winSizeX - 1));

?

?????? printf("VIDTCON2=? 479 799 %d? or %d?\r\n", pGD->winSizeY - 1,pGD->winSizeX - 1);

?

//win0

??? /*

???? *<Exyons 4412 datasheet pg1877>

???? *WINCON0:

???? *?[5:2]: Selects Bits Per Pixel (BPP) mode for Window image : 1011 ===>24BPP

???? *?[1]:Enables/disables video output??1 = Enables

???? *

???? *modify by zth; have an error;add [15] :specifies word swap control bit :1=Enable ;2014 06-15 need enable

???? * */

??? //WINCON0 =( (1<<15) | (11 <<2) | 1);

?????? WINCON0=(EXYNOS_WINCON_WSWP_ENABLE | EXYNOS_WINCON_BPPMODE_24BPP_888 |

???????????????????? ? EXYNOS_WINCON_ENWIN_ENABLE);

?

?????? /*

?????? printf("WINCON0= %d? or %d? \r\n",(1<<15)|(11 << 2) | 1,

?????????????????????????????????????????????????????????????? EXYNOS_WINCON_WSWP_ENABLE|

?????????????????????????????????????????????????????????????? EXYNOS_WINCON_BPPMODE_24BPP_888|

?????????????????????????????????????????????????????????????? EXYNOS_WINCON_ENWIN_ENABLE);

?????? */

??????

??/*

???? *<Exyons 4412 datasheet pg1895>

???? *VIDOSD0C:Specifies the Window Size (窗口尺寸 單位為word)

???? *?????????

???? *

???? * */

???? //VIDOSD0C = 480 * 800;

?????? //VIDOSD0C= EXYNOS_VIDOSD_SIZE(ROW * COL);

?????? VIDOSD0C= EXYNOS_VIDOSD_SIZE(pGD->winSizeY * pGD->winSizeX);

??????

?????? //printf("VIDOSD0C= %d? or %d? \r\n",480 * 800,EXYNOS_VIDOSD_SIZE(ROW *COL));

?

??? /*

???? *<Exyons 4412 datasheet pg1891pg1801>

???? *[0]: Enables Channel 0. 1 = Enables

???? * */

???? // SHADOWCON |= 1;

??? SHADOWCON |= EXYNOS_WINSHMAP_CH_ENABLE(0);

?????? printf("SHADOWCON= %d?????? or %d? \r\n",1,EXYNOS_WINSHMAP_CH_ENABLE(0));

?

??? /*

???? *<Exyons 4412 datasheet? pg1894 pg1801>

???? *[18:16] Selects Channel 0's channel. ===>001 = Window 0

???? *[2:0] Selects Window 0's channel.? ===> 001 = Channel 0

???? *

???? *

???? * */

?

?????? /*WINCHMAP2&= ~(7 << 16);

?????? WINCHMAP2|= 1 << 16;

?????? WINCHMAP2&= ~7;

?????? WINCHMAP2|= 1;

?????? */

??????

?????? WINCHMAP2&=? EXYNOS_WINSHMAP_CH_DISABLE(16);

?????? WINCHMAP2|= EXYNOS_WINSHMAP_CH_ENABLE(16);

?????? WINCHMAP2&=? EXYNOS_WINSHMAP_CH_DISABLE(0);

?????? WINCHMAP2|= EXYNOS_WINSHMAP_CH_ENABLE(0);

?????????????

?????? printf("~(7<< 16) = %d?????? or %d? \r\n",~(7 <<16),EXYNOS_WINSHMAP_CH_DISABLE(16));

?????? printf("1<< 16= %d???? or %d? \r\n",1 << 16,EXYNOS_WINSHMAP_CH_ENABLE(16));

?????? printf("~7= %d???? or %d? \r\n",~7,EXYNOS_WINSHMAP_CH_DISABLE(0));

??? /*

???? *<Exyons 4412 datasheet? pg1895>

???? *VIDOSD0A: LCD左上角坐標

???? *VIDOSD0B: LCD右下角坐標

???? */

?????? //VIDOSD0A= 0;

?????? //VIDOSD0B= (799 << 11) | 479;

?????? VIDOSD0A=? ( EXYNOS_VIDOSD_LEFT_X(0) |EXYNOS_VIDOSD_TOP_Y(0));//0

?????? VIDOSD0B=? (EXYNOS_VIDOSD_RIGHT_X(pGD->winSizeX - 1) |EXYNOS_VIDOSD_BOTTOM_Y(pGD->winSizeY - 1));

?

?????? //printf("VIDOSD0A= %d?? or %d? \r\n",0,EXYNOS_VIDOSD_LEFT_X(0) |EXYNOS_VIDOSD_TOP_Y(0));

?????? printf("VIDOSD0B= %d???? or %d? \r\n",(799 << 11) | 479,

????????????????????????????????????????????????????????????????????? EXYNOS_VIDOSD_RIGHT_X(pGD->winSizeX- 1) | EXYNOS_VIDOSD_BOTTOM_Y(pGD->winSizeY - 1));

??? /*

???? *<Exyons 4412 datasheet? pg1902>

???? * VIDW00ADD0B0 : window0 frame buffer 起始地址

???? *?VIDW00ADD1B0 : window0 frame buffer 結(jié)束地址

???? * */

????

?????? //VIDW00ADD0B0= LCD_VIDEO_ADDR;

?????? //VIDW00ADD1B0= LCD_VIDEO_ADDR + VIDOSD0C * 4;

?????? VIDW00ADD0B0= pGD->frameAdrs;

?????? VIDW00ADD1B0= pGD->frameAdrs + VIDOSD0C * pGD->gdfBytesPP;

?????? printf("pGD->gdfBytesPP= 4 ;? %d?\r\n",pGD->gdfBytesPP);

?

??? /*

???? * <Exyons 4412 datasheet pg1869>

???? * Display On: ENVID and ENVID_F are set to"1".

???? *?[0]:ENVID ===> 1 = Enables

???? *?[1]:ENVID_F ===> 1 = Enables

???? * */

??? // VIDCON0 |= 3;

?????? VIDCON0|=? (EXYNOS_VIDCON0_ENVID_ENABLE |

??????????????????????????? ?EXYNOS_VIDCON0_ENVID_F_ENABLE);??

?

?????? /*printf("VIDCON0= %d???? or %d? \r\n",3,

??????????????????????????????????????????????????????? (EXYNOS_VIDCON0_ENVID_ENABLE|EXYNOS_VIDCON0_ENVID_F_ENABLE));

??????

?????? */???

?

?????? led_blink(10);//youcan see led blink and the lce is green now!

?????? printf("Video:video_hw_init complete \n");

?????? return((void*)&smi);???

}

?

// 描點

void lcd_draw_pixel(int row, intcol, int color)? //行,列 ,顏色

{

?????? unsignedlong * pixel = (unsigned long?*)LCD_VIDEO_ADDR;

?

?????? *(pixel+ row * COL + col) = color;

?

}

// 畫圖

//此函數(shù)僅支持img2lcd轉(zhuǎn)換格式包含信息頭的文件

void lcd_draw_bmp(const unsignedchar gImage_bmp[])

{

?????? inti, j;

?????? unsignedchar *p = (unsigned char *)gImage_bmp+8;//img2lcd轉(zhuǎn)換出來的包含信息頭8字節(jié)

?????? intblue, green, red;

?????? intcolor;

?????? intpic_width, pic_height;

?

?????? //獲取圖片大小 參考img2lcd軟件,可知其轉(zhuǎn)換的第3、4字節(jié)為寬,5、6字節(jié)為高

?????? pic_width= ((*(gImage_bmp+3)<<8) | *(gImage_bmp+2) );

?????? pic_height=((*(gImage_bmp+5)<<8) | *(gImage_bmp+4) );

?????? printf("pic_width= %d,? pic_height = %d",pic_width,pic_height);

?

?????? for(i = 0; i < pic_height; i++)

????????????? for(j = 0; j < pic_width; j++)

????????????? {

???????????????????? blue? = *p++;

???????????????????? green= *p++;

???????????????????? red?? = *p++;

?????????????

???????????????????? color= red << 16 | green << 8 | blue << 0;

???????????????????? lcd_draw_pixel(i,j, color);

????????????? }

?

}

// 清屏

void lcd_clear_screen(int color)

{

?????? inti, j;

?

?????? for(i = 0; i < ROW; i++)

????????????? for(j = 0; j < COL; j++)

???????????????????? lcd_draw_pixel(i,j, color);

?

}

// 劃橫線

void lcd_draw_hline(int row, intcol1, int col2, int color)

{

?????? intj;

?

?????? //描第row行,第j列

?????? for(j = col1; j <= col2; j++)

????????????? lcd_draw_pixel(row,j, color);

?

}

?

// 劃豎線

void lcd_draw_vline(int col, introw1, int row2, int color)

{

?????? inti;

?????? //描第i行,第col列

?????? for(i = row1; i <= row2; i++)

????????????? lcd_draw_pixel(i,col, color);

?

}

?

// 劃十字

void lcd_draw_cross(int row, intcol, int halflen, int color)

{

?????? lcd_draw_hline(row,col-halflen, col+halflen, color);

?????? lcd_draw_vline(col,row-halflen, row+halflen, color);

}

?

// 畫字符

void lcd_draw_char(unsigned charc)

{

?????? //必須是靜態(tài)變量

?????? staticint x = 0;?????? // 第幾列

?????? staticint y = 0;?????? // 第幾行

?????? inti,j;

?????? unsignedint line_dots=0x0;

?

?????? //獲得字模

#if FONT8_16

unsigned char *char_dots =(unsigned char *) (fontdata_8x16 + c * FONT_COL);

#endif

?

#if FONT10_18

unsigned char *char_dots =(unsigned char *) (fontdata_10x18 + c * FONT_COL*2);

#endif

?

#if FONT12_22?

unsigned char *char_dots =(unsigned char *) (fontdata_sun12x22 + c * FONT_COL*2);

#endif

?

?????? //是否需要回車換行

?????? if(c == '\n')

?????? {

????????????? y+= FONT_COL;

????????????? if(y > ROW)

???????????????????? y= 0;

????????????? return;

?????? }

?????? elseif (c == '\r')

?????? {

????????????? x= 0;

????????????? return;

?????? }

?

?????? unsignedlinek;

????????????? #ifFONT8_16??????

????????????? for(i = 0; i < FONT_COL; i++)

???????????????????? {

??????????????????????????? line_dots= char_dots[i];

??????????????????????????? for(j = 0; j < FONT_ROW; j++)

??????????????????????????? {

?????????????????????????????????? //為1,則描藍點

?????????????????????????????????? if(line_dots & (0x80 >> j))

?????????????????????????????????? {

????????????????????????????????????????? lcd_draw_pixel(y+i,x+j, 0xff);

?????????????????????????????????? }

??????????????????????????? }

???????????????????? }

?

?????????????

????????????? #endif???????????

?????????????

????????????? #ifFONT10_18

????????????? for(i = 0; i < FONT_COL; i++)

???????????????????? {

??????????????????????????? line_dots= ((char_dots[i*2]<<8) | char_dots[i*2+1]);

??????????????????????????? for(j = 0; j < FONT_ROW; j++)

??????????????????????????? {

?????????????????????????????????? //為1,則描藍點

?????????????????????????????????? if(line_dots & (0x8000 >> j))

?????????????????????????????????? {

????????????????????????????????????????? lcd_draw_pixel(y+i,x+j, 0xff);

?????????????????????????????????? }

??????????????????????????? }

???????????????????? }

????????????? #endif

?

????????????? #ifFONT12_22

????????????? for(i = 0; i < FONT_COL; i++)

???????????????????? {

???????????????????? line_dots= ((char_dots[i*2]<<8) | char_dots[i*2+1]);

??????????????????????????? for(j = 0; j < FONT_ROW; j++)

??????????????????????????? {

?????????????????????????????????? //為1,則描藍點

?????????????????????????????????? if(line_dots & (0x8000 >> j))

?????????????????????????????????? {

????????????????????????????????????????? lcd_draw_pixel(y+i,x+j, 0xff);

?????????????????????????????????? }

??????????????????????????? }

???????????????????? }

????????????? #endif

?????????????

// 光標移動到下一個字符的位置

x += FONT_ROW;

if (x > COL)

{

?????? x= 0;

?????? y+= FONT_COL;

?????? if(y > ROW)

?????? ?????? y = 0;

}

}

#endif

第三步:修改Makefile

打開/drivers/video/Makefile,定位到后面點位置增加:

COBJS-$(CONFIG_LCD_EXYNOS4412)+= zth_tiny4412_lcd.o videomodes.o

如下圖所示:

圖19-2 修改Makefile示意圖


第四步:修改videomodes.c

//參考的第3步?jīng)]有去修改。

打開/drivers/video/videomodes.c,首先定位到97行左右增加:

const struct ctfb_vesa_modes vesa_modes[VESA_MODES_COUNT] = {

???????? {0x301,RES_MODE_640x480, 8},

???????? {0x310,RES_MODE_640x480, 15},

???????? {0x311,RES_MODE_640x480, 16},

???????? {0x312,RES_MODE_640x480, 24},

???????? {0x303,RES_MODE_800x600, 8},

???????? {0x313,RES_MODE_800x600, 15},

???????? {0x314, RES_MODE_800x600,16},

???????? {0x315,RES_MODE_800x600, 24},

???????? {0x305,RES_MODE_1024x768, 8},

???????? {0x316,RES_MODE_1024x768, 15},

???????? {0x317,RES_MODE_1024x768, 16},

???????? {0x318,RES_MODE_1024x768, 24},

???????? {0x161,RES_MODE_1152x864, 8},

???????? {0x162,RES_MODE_1152x864, 15},

???????? {0x163,RES_MODE_1152x864, 16},

???????? {0x307,RES_MODE_1280x1024, 8},

???????? {0x319,RES_MODE_1280x1024, 15},

???????? {0x31A,RES_MODE_1280x1024, 16},

???????? {0x31B,RES_MODE_1280x1024, 24},

???????? {0x211,RES_MODE_800x480, 24},?? //modify by zth

};

?

接著、定位到106行附近,修改如下:

?

const struct ctfb_res_modes res_mode_init[RES_MODES_COUNT] = {

???????? /* x? y pixclk??le? ri? up?????? lo?? hs vs?s? vmode */

???????? {640, 480, 39721, 40,24, 32, 11, 96, 2, 0, FB_VMODE_NONINTERLACED},

???????? {800, 600, 27778, 64,24, 22, 1, 72, 2, 0, FB_VMODE_NONINTERLACED},

???????? {1024, 768, 15384,168, 8, 29, 3, 144, 4, 0, FB_VMODE_NONINTERLACED},

???????? {960, 720, 13100, 160,40, 32, 8, 80, 4, 0, FB_VMODE_NONINTERLACED},

???????? {1152, 864, 12004,200, 64, 32, 16, 80, 4, 0, FB_VMODE_NONINTERLACED},

???????? {1280, 1024, 9090,200, 48, 26, 1, 184, 3, 0, FB_VMODE_NONINTERLACED},

???????? {800, 480 ,30030 , 45,????? 209,22,21, 0, 0, 0, FB_VMODE_NONINTERLACED},

};

第五步:修改videomodes.h

打開/drivers/video/videomodes.h,定位到25行附近,修改如下:

#ifndefCONFIG_SYS_DEFAULT_VIDEO_MODE

//#defineCONFIG_SYS_DEFAULT_VIDEO_MODE? 0x301

//#ifndefCFG_SYS_DEFAULT_VIDEO_MODE

//#defineCFG_SYS_DEFAULT_VIDEO_MODE? 0x211

#define CONFIG_SYS_DEFAULT_VIDEO_MODE????? 0x211

#endif

?

接著定位到86行左右,修改如下:

#defineRES_MODE_640x480 ???????? 0

#defineRES_MODE_800x600 ???????? 1

#defineRES_MODE_1024x768??????? 2

#defineRES_MODE_960_720 ???????? 3

#defineRES_MODE_1152x864??????? 4

#defineRES_MODE_1280x1024????? 5

//#define RES_MODES_COUNT?????? 6

#define RES_MODE_800x480?6

#define RES_MODES_COUNT?7

?

//#define VESA_MODES_COUNT ?19?

#define VESA_MODES_COUNT ?20?//19->20

第六步:增加圖片數(shù)組

在\uboot_tiny4412-lcd\include\目錄下添加一個圖片數(shù)組文件:jpg_104160.h

此文件是用img2lcd來轉(zhuǎn)換實現(xiàn)得到,其設(shè)置示意如下圖18-3所示。

圖19-3img2lcd 軟件設(shè)置示意圖


第七步:修改cfb_console.c

首先,打開/drivers/video/cfb_console.c文件。

定們到98行左右,增加:

#if defined(CONFIG_LCD_EXYNOS4412)//modify? by zth

#include <zth_tiny4412_lcd.h>

#include <jpg_104160.h>

#endif

?

接著,定位到285行左右,修改:

//modify by zth

//#define VIDEO_INFO_X????????????????? (VIDEO_LOGO_WIDTH)

//#define VIDEO_INFO_Y????????????????? (VIDEO_FONT_HEIGHT/2)

#define VIDEO_INFO_X?? (0)

#define VIDEO_INFO_Y?? (VIDEO_LOGO_HEIGHT)

接著定位到1615行,增加修改:

#ifdef CONFIG_VIDEO_LOGO

???????? /* Plot the logo andget start point of console */

???????? PRINTD ("Video:Drawing the logo ...\n");

???????? video_console_address= video_logo ();

????????

???????? lcd_draw_bmp(gImage_bmp);

#else

???????? video_console_address= video_fb_address;

#endif

第八步:修改/common/console.c

打開/common/console.c,定位368行左右,為了輸出字符到LCD上,修改printf()函數(shù)。修改內(nèi)容如下:

int printf(constchar *fmt, ...)

{

???? va_list args;

???? uint i;

???? char printbuffer[CONFIG_SYS_PBSIZE];

?

???? va_start(args, fmt);

???? /* For this to work, printbuffer must belarger than

???? ?*anything we ever want to print.

???? ?*/

???? i = vsprintf(printbuffer, fmt, args);

???? va_end(args);

???? /* Print the string */

???? puts(printbuffer);

?

???? //modify by zth

???? uint j;

???? for (j = 0; j <strlen(printbuffer); j++)

???? {

????????????? lcd_draw_char((unsignedchar)printbuffer[j]);

???? }

????

???? return i;

}

?

第九步:修改zth_tiny4412.h

這一步修改配置文件,打開/include/configs/zth_tiny4412.h,首先定位到155行左右,使能調(diào)試輸出信息,這樣你會看到很多其他額外的信息,但這樣會去檢測Memorry,我們再將CONFIG_RAM_TEST注釋了,修改如下:

//#undefCONFIG_LL_DEBUG???????????????????????? /*disable debug */

#defineCONFIG_LL_DEBUG?????????????????? 1

#defineDEBUG 1

//#ifdefCONFIG_LL_DEBUG

//#defineCONFIG_RAM_TEST???????????????? 1???? /* Memory R/W test */

//#endif

?

定位到文件的最后部分,文件的第443行左右。增加下面內(nèi)容:

/*LCD*/

?

#define CONFIG_VIDEO???????????????? ? //Video support

#defineCONFIG_LCD_EXYNOS4412? 1

#defineCONFIG_VIDEO_LOGO????? 1?? //display Linux Logo in upper left corner

?

//#defineCONFIG_VIDEO_BMP_LOGO??? ????//use bmp_logo instead of linux_logo

//#defineCONFIG_CMD_BMP???????? //BMP support

//#defineCONFIG_VIDEO_BMP_GZIP????? //Gzipcompressed BMP image support

//#defineCONFIG_CMD_UNZIP

//#defineCONFIG_SPLASH_SCREEN??? //enable splashscreen support,implicitly enable U-Boot Bitmap Support.

#defineCONFIG_VGA_AS_SINGLE_DEVICE 1

#defineCONFIG_CFB_CONSOLE

#defineVIDEO_KBD_INIT_FCT? 0?????? //init function for keyboard

#defineVIDEO_TSTC_FCT? serial_tstc?? //keyboard_tstc function

#defineVIDEO_GETC_FCT? serial_getc?? //keyboard_getc function

?

?

#define LCD_VIDEO_ADDR???? (0x58000000)????

#define ?????? VIDEO_MEM_SIZE? 0x200000??????? /* 800x480x24bit = 0X119400 bytes */

#define? CONFIG_SYS_VIDEO_VCLOCK_HZ? (800000000)

?

?

#defineCONFIG_EXTRA_ENV_SETTINGS?? \

?"stdin=serial\0"????? \

?"stdout=vga\0"?????? \

?"stderr=serial\0"???? \

""

?

第十步:修改/sd_fuse/tiny4412/ sd_fusing.sh

其實經(jīng)過上面的步驟,大家可以按第十二步進行編譯,煤寫到SD卡運行u-boot了,但會出現(xiàn)一個問題,你會發(fā)現(xiàn)程序串口輸出運行輸出到如下圖18-4所示的位置,就不會繼續(xù)往下執(zhí)行了,正常運行的串口輸出如圖18-6所示。這是為什么呢?大家查看生成的u-boot.bin大小,就會發(fā)現(xiàn)其大小為372.8K左右,如下圖18-5所示。

圖19-4、未正常運行串口輸出信息截圖


?

圖19-5、u-boot.bin 大小說明圖


我們來看下/sd_fuse/tiny4412/ sd_fusing.sh的文件,有如下幾行語句,下面的語句是說明BL1、BL2、u-boot.bin、還有E4412_tzsw.bin燒寫到SD卡的位置。

# fusing images

signed_bl1_position=1

bl2_position=17

uboot_position=49

tzsw_position=705

?

來算一下,一個扇區(qū)為512byte ,那么(705-49)*512/1024=328K,即給u-boot.bin的空間只有328k大小,后面的u-boot.bin程序被燒寫到tzsw_position 位置片的E4412_tzsw.bin給覆蓋了。

所以這們這里需要修改一下,修改內(nèi)容如下

tzsw_position=1073

?

這里為什么是1073呢,是因為我還改了一個地方,增加拷貝u-boot.bin大小為512K,那么512*2+49=1073了

還要修改一下程序里的文件/arch/arm/include/asm/arch-exynos/ movi_partition.h定位到28行

#ifdefCONFIG_TRUSTZONE

#definePART_SIZE_UBOOT????????????? (512 *1024)? //modify by zth 328->512

#else

#definePART_SIZE_UBOOT????????????? (512 * 1024)

#endif

?

這樣就可以真正進行第十二步了。

第十一步:燒寫SD卡

???????? 以下命令提供參考:

cp -R /media/sf_share/u-boot_zth .

chmod 777 -R u-boot_zth /

cd u-boot_zth

make distclean

make zthtiny4412_config

make

cd sd_fuse/

make

cd zthtiny4412/

./sd_fusing.sh /dev/sdb

運行后的串口信息如下圖所示:

圖19-6 、正常運行串口輸出信息截圖


?

圖19-7 、正常運行效果圖


總結(jié)

以上是生活随笔為你收集整理的第十九章、TIny4412 U-BOOT移植十九 LCD移植的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

香蕉视频免费在线播放 | 91成人精品 | avhd高清在线谜片 | 天天插天天爱 | 中文字幕在线观看视频一区二区三区 | 免费看的毛片 | 美女天天操 | 国产精品网红福利 | 91免费高清 | 亚洲精品永久免费视频 | 高清中文字幕av | 日韩av一区二区在线播放 | 又黄又爽又刺激 | 天天艹天天 | 91精品国产91 | 久久夜色网| 久久久久免费视频 | 国产精品美女久久久久久免费 | 福利久久久 | 麻豆久久 | 最近中文字幕国语免费高清6 | 91成人久久| 国产高清绿奴videos | 久久免费在线观看 | 深夜国产在线 | 国内精品中文字幕 | 久草网在线| 欧美日韩一区二区视频在线观看 | 亚洲精品美女在线观看 | 人人狠狠综合久久亚洲 | 久久99视频精品 | 久久在线精品视频 | 久久99视频免费 | 国产精品高清av | 欧美日在线 | 国产精品欧美久久久久无广告 | 国产小视频在线看 | 国产成在线观看免费视频 | 亚洲精品在 | 天堂av免费观看 | www.久久com | 日韩欧美精品在线观看视频 | 国产精品久久久久国产a级 激情综合中文娱乐网 | av+在线播放在线播放 | 最近中文字幕完整高清 | 日韩av电影一区 | 国产一区在线免费观看视频 | 在线观看成人国产 | 五月婷婷.com | 国产精品久久久久一区 | 午夜黄色一级片 | 日韩在线视频二区 | 国产在线观看地址 | 亚洲精品在线电影 | 久久婷婷色综合 | 999视频精品 | 国产拍揄自揄精品视频麻豆 | 99国内精品 | 久久在线免费观看视频 | 欧美精品久久久久 | 久久成人18免费网站 | 久久九九精品久久 | 99热 精品在线| 亚洲小视频在线观看 | 国产精品一区二区62 | 色综合久久精品 | 久久在草 | 色99久久 | 中文字幕第一页在线 | 丁香久久综合 | 国产一级片观看 | 日韩精品一区二区三区免费视频观看 | 久久视频6 | 人人澡av| 天天射狠狠干 | 美女av免费| 久久国产精品色av免费看 | 国产主播大尺度精品福利免费 | 91激情视频在线观看 | 久久九九精品久久 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 久热av | 丁香激情综合久久伊人久久 | 久久涩视频 | 九色精品 | 综合中文字幕 | 一本一本久久a久久精品综合小说 | 国产精品入口麻豆www | 97日日| 热久久这里只有精品 | 日韩免费电影一区二区 | 黄色免费观看 | 欧美精品亚洲精品 | 丁香婷婷射 | 久久久黄色av| 欧美福利视频 | 999视频网| 欧美另类视频 | 中文字幕一区二区三区在线视频 | a级一a一级在线观看 | 久久99亚洲网美利坚合众国 | 综合久久久久久 | 黄色大片网 | 人人澡人人干 | 二区视频在线 | 日韩中文字幕国产精品 | 婷婷久久丁香 | 六月色丁香 | 精品亚洲一区二区 | 人人玩人人添人人澡97 | 久久免视频 | 97国产精品亚洲精品 | www.xxx.性狂虐| 欧美日在线 | av在线直接看| 久草免费在线观看视频 | 亚洲精品成人av在线 | 超碰在线观看97 | 麻豆影视在线免费观看 | 99精品免费久久久久久久久日本 | 色婷婷久久 | 久久女同性恋中文字幕 | 91精品黄色 | 99热手机在线观看 | 91色蜜桃 | 久爱综合 | 免费看的黄色片 | 国产精品综合久久久 | 精品人人爽 | 欧美综合在线视频 | 在线观看a视频 | 91精品久久久久久久久久入口 | 二区在线播放 | 免费在线观看中文字幕 | 久久久久一区二区三区 | 国内小视频 | 成人永久在线 | www.夜夜干.com | 天天躁日日躁狠狠躁av麻豆 | 四虎免费在线观看视频 | 天天操天天射天天 | 高清有码中文字幕 | 久久久久五月 | 97人人超| 亚洲成人av在线电影 | 在线免费观看视频 | 午夜精品久久久久久久99热影院 | 男女日麻批 | 黄色福利网 | 日韩精品91偷拍在线观看 | 亚洲黄色免费网站 | a成人v在线 | 操操操日日| 国产成人精品一区二三区 | 97在线看 | 97色资源 | 免费视频你懂得 | 成人a级大片 | 国产精品资源在线 | 操高跟美女 | 国产三级国产精品国产专区50 | 久久99精品久久久久久久久久久久 | 久久久久一区二区三区 | 免费一级黄色 | 国产黄色高清 | 免费在线观看毛片网站 | 久久精品视频日本 | 97在线观看免费观看 | 999久久精品 | 欧美一级免费 | 国产精品不卡一区 | 国产偷国产偷亚洲清高 | 久久人人精品 | 天天干天天干天天 | 精品国内自产拍在线观看视频 | 国产vs久久| 日韩一二区在线 | 日韩av综合网站 | 91精品欧美 | 日韩av免费观看网站 | 91精品国产三级a在线观看 | 国产精品嫩草在线 | 久久人人精品 | 狠狠激情中文字幕 | 成人午夜影视 | 精品女同一区二区三区在线观看 | 国产盗摄精品一区二区 | 丝袜网站在线观看 | 欧美一级艳片视频免费观看 | 91在线免费观看网站 | 狠狠狠色丁香综合久久天下网 | 美女视频黄的免费的 | 天天操比 | 成人啊 v | 成人精品国产免费网站 | 亚洲视屏在线播放 | 99精品久久只有精品 | 免费看搞黄视频网站 | 国产精品婷婷午夜在线观看 | 久久精品永久免费 | 国产高清亚洲 | 欧美日韩精| 婷婷丁香激情网 | 久久午夜精品影院一区 | 99视频导航 | 国产一区二区精品 | 一区二区三区手机在线观看 | 国产91免费在线 | 日本黄色大片免费看 | 中文字幕在线有码 | 97国产精品亚洲精品 | 91久久久久久国产精品 | 日韩精选在线 | 99精品区| 波多野结衣日韩 | 日韩高清一区 | 射综合网| 日韩在线 一区二区 | 久热电影 | 亚洲视频 在线观看 | 最近中文字幕免费视频 | 久久久久久久网 | 精品久久久久久亚洲综合网站 | 国产精品一二三 | 国产精品黄色av | 久久中文视频 | 国产丝袜高跟 | www.日日操.com| www久久久 | 日韩视频在线不卡 | 亚洲色图av | 韩国精品视频在线观看 | 久久久久欠精品国产毛片国产毛生 | 99精品一区二区 | 亚洲成人网在线 | 96精品在线 | 午夜精品一区二区三区视频免费看 | 草久视频在线观看 | 国产专区精品视频 | 日韩黄色免费 | 天天搞天天| 人人澡人人干 | 久久久精品欧美一区二区免费 | 中文字幕国语官网在线视频 | 9ⅰ精品久久久久久久久中文字幕 | 99视频国产精品 | 国内精品久久久久国产 | 三级av黄色 | 综合久久精品 | 日日夜夜网站 | 在线av资源 | 午夜精品电影 | av免费看电影 | 亚洲精品在线视频网站 | 91社区国产高清 | 天天做天天爱天天综合网 | 国产午夜三级 | 精品日韩av| 国产人成看黄久久久久久久久 | 久久国产一二区 | 美女福利视频 | 五月婷婷六月丁香在线观看 | 午夜的福利 | 日韩最新在线 | 免费在线观看av网站 | 波多野结衣久久资源 | 成人午夜精品福利免费 | 国产在线一卡 | 国产一级一级国产 | 久久久久免费精品国产 | 最新av免费 | 久久九九视频 | 天天做天天爱天天爽综合网 | 欧美精品久久人人躁人人爽 | 激情五月婷婷综合 | 成人国产亚洲 | 美女国产在线 | 成av在线 | 久草免费电影 | 日韩免费不卡视频 | 久久久久女人精品毛片九一 | 国产高清不卡一区二区三区 | 久久婷婷一区二区三区 | 99精品视频中文字幕 | 国产成人一区二区三区电影 | 日日夜夜草 | 成年人网站免费观看 | 国产成人综合精品 | 精品一区精品二区高清 | 亚洲专区在线播放 | 天堂在线免费视频 | 不卡视频在线看 | 伊人婷婷激情 | 美女一区网站 | 99久久爱 | 欧美a视频在线观看 | 亚洲免费公开视频 | 黄色毛片视频 | 懂色av懂色av粉嫩av分享吧 | 高清不卡一区二区在线 | 黄网站色欧美视频 | 国产精品久久久免费 | 黄色一级大片免费看 | 久久久久久久久久久国产精品 | 狠狠色伊人亚洲综合网站色 | 国产精品去看片 | 日韩一级成人av | 国产精品毛片久久久久久久久久99999999 | 国产日韩在线一区 | 国产69精品久久久久久久久久 | 日本精品久久久久中文字幕 | 中日韩欧美精彩视频 | 成人免费在线观看av | 日本精油按摩3 | 久久久精品成人 | 久色婷婷| av综合网址 | 一区二区视频欧美 | 一 级 黄 色 片免费看的 | 欧美激情精品久久久 | 91成人短视频在线观看 | 免费福利在线 | 欧美精品一区二区在线观看 | 久久99九九99精品 | 九九热在线精品 | 久久人人看| 欧美久久久久久久久久久久 | 欧美国产日韩一区二区三区 | 激情婷婷丁香 | 2020天天干夜夜爽 | 特级西西444www大精品视频免费看 | 超碰在线中文字幕 | 日韩电影在线观看中文字幕 | 亚洲精品理论片 | 欧美日韩国产综合一区二区 | 久久综合五月天婷婷伊人 | 色综合综合 | 国产在线 一区二区三区 | 在线电影日韩 | 国产中文字幕视频在线观看 | 99精品国产成人一区二区 | 日本久久久久 | 狠狠躁夜夜av | 欧美日韩后 | 亚洲人毛片 | 在线免费观看国产黄色 | 亚洲人成精品久久久久 | 国产视频资源在线观看 | 国产伦理一区二区三区 | www.福利 | 五月综合激情网 | 性色av一区二区 | 亚洲视频在线免费观看 | 免费看黄色小说的网站 | 免费观看91视频 | 超碰在97| 91视频午夜 | 日韩有码第一页 | 久久影院一区 | 最近最新中文字幕 | 亚洲国产日韩欧美 | 国产一级高清 | av中文字幕免费在线观看 | 欧美日韩综合在线 | 三级视频日韩 | 91精品一区二区三区蜜臀 | 玖玖精品在线 | 日日干日日色 | www在线免费观看 | 豆豆色资源网xfplay | 国产69精品久久99不卡的观看体验 | 在线观看免费黄色 | 特级aaa毛片 | 欧美日韩3p | 久久a久久 | 亚洲精品视频在线播放 | 久久久久国产成人精品亚洲午夜 | 黄色三级网站在线观看 | 在线观看91 | 丝袜美腿亚洲综合 | 日韩最新在线视频 | 亚洲 欧洲 国产 精品 | 五月婷婷在线视频观看 | 国内一区二区视频 | 久久一区二 | 中文字幕 国产 一区 | 久久午夜电影 | 碰超人人 | 欧美色图视频一区 | 亚洲涩涩网 | caobi视频| 99久久精品一区二区成人 | 色欧美视频| 麻豆久久| 国产成人av片 | 97人人模人人爽人人喊中文字 | 午夜视频一区二区 | 欧美狠狠色 | 五月婷婷综合在线观看 | 国产精品美女久久久久久网站 | 精品久久久久久国产 | 国产一级特黄电影 | 国产在线一区观看 | 日韩精品一区二区三区在线视频 | 精品国内自产拍在线观看视频 | 一区二区三区影院 | 国产免费人人看 | 麻豆视频免费播放 | 成人福利av| 亚洲精品一区中文字幕乱码 | 毛片一区二区 | 久久久 精品 | 91精品久久久久久 | 欧美日韩国产精品一区二区 | 97福利在线观看 | 欧美日韩99 | 一二三区av | 国产性天天综合网 | av电影免费观看 | 亚色视频在线观看 | 婷婷综合电影 | 91成人网页版 | 丁香婷婷在线 | 精品三级av| 色99网| 日韩免费视频观看 | 69国产盗摄一区二区三区五区 | .精品久久久麻豆国产精品 亚洲va欧美 | 免费成人在线观看视频 | 国产aa精品 | 亚洲天堂社区 | 免费精品在线视频 | 操综合| 国产福利电影网址 | 在线观看一区视频 | 日韩高清免费在线 | av综合在线观看 | 天天射天天操天天 | 97视频在线播放 | 久久视频在线观看 | 91av视频在线播放 | 日韩av高清 | 狠狠狠综合 | 懂色av懂色av粉嫩av分享吧 | 香蕉视频导航 | 亚洲精品乱码久久久久久蜜桃欧美 | 91久草视频 | 欧美日本国产在线观看 | 国产视频在线免费观看 | 成人午夜影院在线观看 | 在线观看黄色大片 | 五月婷婷六月丁香在线观看 | 综合色久 | 五月婷婷狠狠 | 91免费看黄色 | 99精品国产免费久久 | 99在线精品免费视频九九视 | 日本黄色一级电影 | 婷婷综合伊人 | 美女福利视频一区二区 | 在线黄色av| 成人免费观看网址 | 青青久草在线 | 波多野结衣资源 | 九草在线视频 | 免费网站在线观看人 | 五月婷婷一级片 | 亚洲黄色片在线 | 丝袜+亚洲+另类+欧美+变态 | 日韩精品一区不卡 | 美女又爽又黄 | 欧美一区二区免费在线观看 | 99精品国产一区二区 | 天天操狠狠操夜夜操 | 91精品国产自产老师啪 | 亚洲在线日韩 | 在线观看精品黄av片免费 | 欧美性大战 | 国产亚洲精品v | 欧产日产国产69 | 碰超在线 | 欧美日韩免费一区二区 | 久久五月精品 | 超碰在线97国产 | 友田真希x88av | 操操操操网| 黄色av一级 | 国产一区二区视频在线播放 | 亚洲天堂网视频 | 精品久久久久久一区二区里番 | 久久99热这里只有精品 | 成人免费视频在线观看 | 三级视频国产 | 97色资源| 99在线观看视频 | 91原创在线观看 | 最近最新mv字幕免费观看 | 1000部18岁以下禁看视频 | 天天色视频 | 综合色在线观看 | 成人h视频在线播放 | 国产精品初高中精品久久 | 国产精品18久久久久久首页狼 | 在线视频日韩 | 在线观看aa | 黄色软件视频网站 | av官网 | 欧美精品一区二区三区四区在线 | 伊人亚洲综合 | 国产福利精品一区二区 | 国产午夜在线 | 成人免费观看大片 | 欧美在线视频精品 | 国产成人亚洲精品自产在线 | 日韩精品免费一区二区 | 超碰个人在线 | 午夜精品一二三区 | 国产视频在线观看一区 | 天天天天天天天天操 | 手机av网站 | 国产精品欧美在线 | av在线专区 | 国产免费又粗又猛又爽 | 激情综合网在线观看 | 久久综合精品国产一区二区三区 | 婷婷丁香社区 | 天天综合色天天综合 | 日本久久免费视频 | 日本高清中文字幕有码在线 | 国产只有精品 | 午夜精品久久一牛影视 | 激情电影在线观看 | 国产高清在线观看 | 黄色小说免费在线观看 | 亚洲高清免费在线 | 狠狠狠色丁香婷婷综合久久五月 | 日韩av一区二区在线播放 | 国产精品欧美久久久久天天影视 | 日本黄色大片免费 | 麻花豆传媒一二三产区 | 日韩av一区在线观看 | 日日日操操| 视频 天天草 | 菠萝菠萝在线精品视频 | 国产日产欧美在线观看 | 五月天中文在线 | 久久综合狠狠狠色97 | 国产免费大片 | 日韩精品一区二区在线视频 | 免费福利在线视频 | 国产裸体视频网站 | 在线观看免费一级片 | 99国产成+人+综合+亚洲 欧美 | 伊人天天狠天天添日日拍 | 婷婷av网 | 国产精品第二十页 | 97精品国产 | 超碰在线日韩 | 国产福利91精品一区二区三区 | 国产一区二区在线播放视频 | 亚洲激情六月 | 亚洲午夜精品久久久久久久久 | 玖玖视频| 四虎永久免费网站 | 久久96| 国产亚洲aⅴaaaaaa毛片 | 天天操夜夜操天天射 | 色大片免费看 | 国产二区电影 | 婷婷精品 | 99色免费 | 国产成人精品999在线观看 | 一区二区三区动漫 | 亚洲天堂网在线播放 | 天天干天天玩天天操 | 国产亚洲人| 国产九九九视频 | 国产香蕉久久精品综合网 | 91豆花在线观看 | 日韩欧美国产免费播放 | 怡红院av久久久久久久 | 国内精品久久久久久久影视麻豆 | 欧美一二三视频 | 天天爽天天爽夜夜爽 | 99爱视频在线观看 | 国产精品一区在线观看你懂的 | 亚洲欧美日韩在线看 | 久久亚洲精品国产亚洲老地址 | 亚洲精品视频在线播放 | 婷婷久久综合九色综合 | 亚洲高清视频在线播放 | 色视频 在线 | 久草a视频| 国内精品视频在线 | 久久国产一区二区 | 九九国产精品视频 | 国产码电影 | 国产伦理精品一区二区 | 日韩一区二区三区免费视频 | 最新国产福利 | 婷婷 中文字幕 | 99精品亚洲 | 久久天天躁夜夜躁狠狠85麻豆 | 毛片美女网站 | 天天摸天天弄 | 91福利视频久久久久 | 婷婷电影在线观看 | 久久综合久久综合久久 | 国产99色| 日韩三区在线观看 | 中文字幕一区二区三区在线观看 | 亚洲一区精品二人人爽久久 | 亚洲不卡123 | 日韩二三区 | www.888.av | 99久久国产免费免费 | 在线免费高清一区二区三区 | 黄色三级免费 | 国产视频99 | 欧美色图狠狠干 | 国产精品久久一区二区无卡 | 亚洲国产经典视频 | 精品在线一区二区 | 在线观看视频黄色 | 成人免费中文字幕 | 涩涩网站在线观看 | 香蕉视频在线网站 | 在线色亚洲 | 18网站在线观看 | 欧美日韩一区二区三区不卡 | 国产成人黄色 | 久草视频播放 | 天天射天天 | 色小说在线 | 午夜久久影视 | 亚洲精品高清视频在线观看 | 男女激情片在线观看 | 99成人免费视频 | 欧美精品中文在线免费观看 | 欧美极品xxxxx | 四虎在线永久免费观看 | 中文字幕2021 | 亚洲精品91天天久久人人 | 久久99精品国产麻豆宅宅 | av天天草 | 国产亚洲精品成人av久久ww | 久草视频在线资源站 | 国产精品色婷婷 | 亚洲视频免费在线 | 国产精品av电影 | 亚洲黄色影院 | 国产精品一区免费看8c0m | 国产a网站 | 美女国产在线 | 在线你懂的视频 | 国产精品mm | 国产伦精品一区二区三区在线 | 婷婷久久丁香 | 天堂在线一区二区三区 | 国产精品美女久久久 | 黄色亚洲 | 欧美日韩在线看 | 亚洲一级理论片 | 久久精品79国产精品 | 日日夜夜干 | 欧美精品少妇xxxxx喷水 | 国产精品999久久久 久产久精国产品 | 免费av网站观看 | 91资源在线视频 | 国产只有精品 | 91av观看| 亚洲精品视频在线免费 | 亚洲女同ⅹxx女同tv | 国产精品久久久久久久7电影 | 天天射天天爱天天干 | 日本久久成人 | 成人一级片视频 | 日韩精品一区二 | 免费看片网站91 | 97超碰人人澡人人 | 午夜精品一区二区三区可下载 | 久久五月网 | 日韩免费视频播放 | 91精品国产福利在线观看 | 欧美一级电影在线观看 | 日韩区视频| 成年人在线观看视频免费 | 国产精品久久久精品 | 一区二区三区在线免费 | 亚洲成aⅴ人片久久青草影院 | 欧美另类性 | 中日韩三级视频 | 欧美一级视频免费看 | 97av精品| 在线黄色毛片 | 麻豆视频91 | 国产亚洲一区二区在线观看 | 色综合色综合久久综合频道88 | 蜜臀久久99静品久久久久久 | 中文字幕av免费在线观看 | 色爱区综合激月婷婷 | 精产嫩模国品一二三区 | 97视频免费观看2区 亚洲视屏 | 欧美亚洲精品一区 | 亚州日韩中文字幕 | 欧美日韩性生活 | 激情网五月天 | 一区二区三区久久精品 | 国产高清 不卡 | 久久精品香蕉视频 | av软件在线观看 | 国产1级视频 | 久久视频免费观看 | 91av色| 国产久草在线 | 夜夜夜夜操 | 亚洲www天堂com | 久久久久成人精品 | 99久久精品国产亚洲 | 亚洲精品国精品久久99热一 | 国产中文字幕在线播放 | 国产91精品久久久久久 | 在线综合 亚洲 欧美在线视频 | 日韩电影在线观看中文字幕 | 日韩专区视频 | 亚洲综合色网站 | 97国产精品亚洲精品 | 日韩久久激情 | 色悠悠久久综合 | 少妇bbb | 激情五月综合 | 五月婷婷综合在线视频 | av成人动漫在线观看 | 精品国产一区二 | 丁香婷婷激情网 | 丁香激情五月 | 久久精品国产免费看久久精品 | 少妇性bbb搡bbb爽爽爽欧美 | 欧美一级黄色片 | 亚洲综合在线播放 | 国产免费视频一区二区裸体 | 久久天天躁狠狠躁夜夜不卡公司 | 天天操欧美 | 日韩av高清在线观看 | 国产精品成人一区二区 | 婷婷.com| 国产日产精品一区二区三区四区 | 91在线视频播放 | 中文国产成人精品久久一 | 久久久精品午夜 | 中文超碰字幕 | 国产在线精品一区 | 在线观看网站你懂的 | 久久天天躁狠狠躁夜夜不卡公司 | 天天精品视频 | 黄色的网站在线 | 狠狠色免费 | 丁香六月婷婷激情 | www.午夜色.com | av在线播放快速免费阴 | 五月婷婷中文网 | 亚洲国产成人在线观看 | 欧美夫妻性生活电影 | 可以免费观看的av片 | 天天爱天天| 三级免费黄色 | 在线观看中文字幕一区二区 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 97精品国产97久久久久久免费 | 中文字幕在线久一本久 | 三三级黄色片之日韩 | 中文资源在线播放 | 国产精品久久久亚洲 | 国产免费二区 | 国产亚洲一级高清 | 久久久精品一区二区三区 | 永久免费观看视频 | 日韩精品电影在线播放 | 成人免费视频网址 | 九九电影在线 | 久草在线看片 | 在线观看免费黄视频 | 91精品国产乱码在线观看 | 91| 丝袜制服天堂 | 日韩三级成人 | 超碰人人国产 | 狠狠色狠狠色综合日日92 | 国产xxxx | 四虎免费在线观看 | 深夜激情影院 | 日韩免费成人 | 免费看黄色大全 | 久久免费av电影 | 久99久中文字幕在线 | 日韩一区二区在线免费观看 | 天天做天天爱天天爽综合网 | 午夜视频欧美 | 久久久麻豆精品一区二区 | 337p日本欧洲亚洲大胆裸体艺术 | 超碰在线人人 | 精品国偷自产在线 | 黄色片网站av | 五月天综合网 | 日韩精品免费一线在线观看 | 97日日碰人人模人人澡分享吧 | 日韩av电影免费在线观看 | 婷婷综合伊人 | 久久视频这里有久久精品视频11 | 玖玖在线资源 | 国产直播av | 亚洲网站在线看 | 久久精品高清视频 | 九色91视频 | 久久久九色精品国产一区二区三区 | 伊人婷婷激情 | 精品黄色在线 | 日韩手机在线观看 | 亚洲久草网| 九九九九九九精品 | 久久99国产精品免费网站 | 丁香花中文在线免费观看 | www国产亚洲精品久久网站 | 亚洲精品在线资源 | 91福利免费 | 有码中文在线 | 午夜体验区 | 欧美激情亚洲综合 | 精品国产免费一区二区三区五区 | 99热99| 日韩综合第一页 | 久久精品视频5 | 成人免费视频网站 | 国产精品99免视看9 国产精品毛片一区视频 | 亚洲小视频在线 | 国产精品美女久久久久久久 | 激情中文字幕 | 青春草免费视频 | 亚洲成人精品国产 | 欧美成人h版电影 | 国产一区二区三区黄 | 五月婷婷视频在线观看 | 五月天综合在线 | 日韩精品国产一区 | 成人免费视频免费观看 | 韩日精品在线 | 国产精品欧美一区二区 | 欧美视频在线观看免费网址 | 久久国产电影院 | av片免费播放 | 看片网站黄色 | 成人午夜性影院 | 九九热只有精品 | 久久蜜臀av | 久久黄色美女 | 九九在线免费视频 | 国产短视频在线播放 | 国产香蕉视频在线播放 | 成人av影院在线观看 | 婷婷激情在线 | 免费看色网站 | 福利视频精品 | 国产精品久久久久久久久久久久久久 | 亚洲视频99 | 免费观看v片在线观看 | 大荫蒂欧美视频另类xxxx | 免费视频黄色 | 麻豆首页 | 91手机视频在线 | 久久99久久99精品免费看小说 | 超碰av在线 | 亚洲综合色视频在线观看 | 国产99精品在线观看 | 色综合久久综合中文综合网 | 久久久精品欧美一区二区免费 | 亚洲欧美偷拍另类 | 中文字幕 国产专区 | 精品国产一区二区三区不卡 | 波多野结衣在线观看视频 | 免费看wwwwwwwwwww的视频 久久久久久99精品 91中文字幕视频 | 久久精品99国产精品 | 亚洲综合婷婷 | 伊人国产在线观看 | 伊人色播 | 久热久草在线 | 日韩av看片| 91系列在线| 亚洲国产精品久久久久婷婷884 | 日韩欧美观看 | 在线综合 亚洲 欧美在线视频 | 2019中文在线观看 | 九九九视频精品 | 午夜av在线播放 | 黄色小网站在线 | 在线亚洲成人 | 91免费视频网站在线观看 | 欧美午夜视频在线 | 久久视频免费看 | 高潮久久久 | 色综合欧洲 | 久久婷婷网 | 亚洲欧美日韩一二三区 | 特级毛片在线观看 | 久久综合狠狠综合久久激情 | 久久免费视频3 | 成人毛片网 | 在线视频一二三 | 中文字幕成人一区 | 国产视频在线看 | 午夜三级理论 | 免费观看的av | 在线免费高清一区二区三区 | 中文字幕资源网 国产 | 天天天天色射综合 | 欧美成人tv | 色婷婷综合五月 | 黄色app网站在线观看 | 精品一区三区 | 日韩在线观看中文字幕 | 日本精品久久久久影院 | 五月丁婷婷 | 欧美激情视频一区二区三区 | 色吊丝在线永久观看最新版本 | 国产精品一区免费在线观看 | 亚洲国产一区在线观看 | 免费看片日韩 | 亚洲午夜电影网 | 久久99精品一区二区三区三区 | 成人综合婷婷国产精品久久免费 | 国产真实在线 | 操操操天天操 | 日韩视频一区二区三区在线播放免费观看 | 91麻豆产精品久久久久久 | 久久综合九色综合久久久精品综合 | www成人av| 天天操天天射天天插 | 激情欧美一区二区三区免费看 | 国产婷婷vvvv激情久 | 欧美精品一区二区性色 | 国产黄在线 | 亚洲黄色小说网 | 亚洲va在线va天堂va偷拍 | 天天操夜夜做 | 国产亚洲视频在线 | 综合网久久| 久久亚洲福利视频 | 五月天综合婷婷 | 国产又粗又猛又黄又爽 | 色婷婷精品 | 制服丝袜天堂 | 在线看成人 | 99热在线网站 | 国产美女主播精品一区二区三区 | 九9热这里真品2 | 国产久视频 | 97精产国品一二三产区在线 | 激情综合亚洲 | 99热这里精品 | 一区二区三区日韩精品 | 视频一区二区精品 | 久久久亚洲精品 | 亚洲成人午夜在线 | 特级西西人体444是什么意思 | 久久久www免费电影网 | 丁香婷婷综合激情五月色 | 亚洲一区二区三区精品在线观看 | 日韩黄色av网站 | 久久久福利影院 | 中文字幕精品www乱入免费视频 | av线上免费观看 | 国产玖玖精品视频 | 色国产精品 | 国产精品久久久久久久久大全 | 狠狠干综合网 | 免费高清在线观看成人 | 91高清完整版在线观看 | 九九热在线播放 | 色网站在线观看 | 日韩精品在线视频免费观看 | 日韩欧美aaa | 17videosex性欧美 | 激情综合网五月婷婷 | 2018亚洲男人天堂 | 波多野结衣视频在线 | 黄色在线观看免费网站 | 麻豆视频免费看 | 国产精品资源在线观看 | 日本在线观看中文字幕无线观看 | av免费电影网站 | 成人毛片a | 亚洲一区日韩精品 | 久久永久免费视频 | 四虎影视成人永久免费观看亚洲欧美 | 97手机电影网 | 天天干天天操天天搞 | 最新久久免费视频 | 波多野结依在线观看 | 亚洲精品乱码白浆高清久久久久久 |