6410 LCD驱动移植

转载 2011年01月13日 16:30:00

移植工作主要有以下部分(仅仅对未作处理的部分做阐述):

1.在mach-smdk6410.c这个文件中添加初始化的设备

&s3c_device_fb,

会根据name 自动关联执行哪个设备的probe的探测函数

 

同时在plat-s3c64XX下面增加dev-fb.c 主要是用来填充platform_fb这个结构体

static struct resource s3cfb_resource[] = {
 [0] = {
  .start = S3C64XX_PA_LCD,
  .end   = S3C64XX_PA_LCD + S3C64XX_SZ_LCD - 1,
  .flags = IORESOURCE_MEM,
 },
 [1] = {
  .start = IRQ_LCD_VSYNC,
  .end   = IRQ_LCD_VSYNC,
  .flags = IORESOURCE_IRQ,
 },
 [2] = {
  .start = IRQ_LCD_FIFO,
  .end   = IRQ_LCD_FIFO,
  .flags = IORESOURCE_IRQ,
 },
};

static u64 fb_dma_mask = 0xffffffffUL;

struct platform_device s3c_device_fb = {
 .name    = "s3cfb",
 .id    = -1,
 .num_resources   = ARRAY_SIZE(s3cfb_resource),
 .resource   = s3cfb_resource,
 .dev              = {
  .dma_mask  = &fb_dma_mask,
  .coherent_dma_mask = 0xffffffffUL
 }
};

static struct s3c_platform_fb default_fb_data __initdata = {
 .hw_ver = 0x40,
 .clk_name = "lcd",
 .nr_wins = 5,
 .default_win = 1,//CONFIG_FB_S3C_V2_DEFAULT_WINDOW,
 .swap = FB_SWAP_HWORD,
};

void __init s3cfb_set_platdata(struct s3c_platform_fb *pd)
{
 struct s3c_platform_fb *npd;
 int i;

 if (!pd)
  pd = &default_fb_data;
 npd = kmemdup(pd, sizeof(struct s3c_platform_fb), GFP_KERNEL);
 if (!npd)
  printk(KERN_ERR "%s: no memory for platform data/n", __func__);

 for (i = 0; i < npd->nr_wins; i++)
  npd->nr_buffers[i] = 1;

 npd->nr_buffers[npd->default_win] = 1 + 1;

 npd->cfg_gpio = s3cfb_cfg_gpio;
 npd->backlight_on = s3cfb_backlight_on;
 npd->reset_lcd = s3cfb_reset_lcd;

 s3c_device_fb.dev.platform_data = npd;
}

在machine_init的时候执行s3cfb_set_platdata(NULL);就已经填充完毕

.clk_name = "lcd", 在填充时候就已经把对应LCD所需的clk指向其具体的clk(CPU.c中有相关的结构体的填充)

所有的时钟都是在cpu.c中配置的!具体的时钟实现是在对应平台下的clock.c配置

 

2)mach-s3c6400/include/mach/memory.h 中增加了
    #define CONSISTENT_DMA_SIZE (SZ_8M + SZ_4M + SZ_2M)
    #define __virt_to_bus(x) __virt_to_phys(x)
    #define __bus_to_virt(x) __phys_to_virt(x)
   
  如果不定义这个的话默认为2M,会导致DMA太小溢出

3)删除mach-smdk6410.c中设置LCD, Gpio_request会导致后面initial时候gpio-request失败,(重复调用)

#if 0   
 gpio_request(S3C64XX_GPN(5), "LCD power");
 gpio_request(S3C64XX_GPF(13), "LCD power");
 gpio_request(S3C64XX_GPF(15), "LCD power");
#endif

以下是删除设置LCD的类型,以为在probe时候已经配置好了,各版本内核的架构不一样,所以初始化的位置也就不相同,以后续高版本为准,

 
#if 0
 tmp = __raw_readl(S3C64XX_SPCON);
 tmp &= ~S3C64XX_SPCON_LCD_SEL_MASK;
 tmp |= S3C64XX_SPCON_LCD_SEL_RGB;
 __raw_writel(tmp, S3C64XX_SPCON);

 
 tmp = __raw_readl(S3C64XX_MODEM_MIFPCON);
 tmp &= ~MIFPCON_LCD_BYPASS;
 __raw_writel(tmp, S3C64XX_MODEM_MIFPCON);
#endif 

 

4)plat-s3c24xx/include/plat/clock.h 增加了clock.h这个文件,因为24xx和64xx在部分功能和接口是一样的,函数可以互相调用

 

5)plat-s3c64xx/include/plat/pll.h   regs-gpio.h 定义了时钟和pin脚相关的宏以及函数

6)修改asm/fb.h
//static inline int fb_is_primary_device(struct fb_info *info)
//{
// return 0;
//}

extern int fb_is_primary_device(struct fb_info *info);

fb_is_primary_device 是调用S3cfb.c中的函数而不是直接返回0

这一步至关重要,因为在后面framebuffer_register时候会有个判断,就是是使用那一个fb设备作为当前设备,

 

 

大概的移植需要这些步骤,但是有些函数和头文件是直接在原文件上更改的,标记做的不全,所以也就不详细的写了

相关文章推荐

ELK日志处理之使用logstash收集log4J日志

介绍logstash处理log4j日志,包括log4j的简介、工程的搭建、log4j配置、logstash配置,实现日志从产生到logstash再到Elasticsearch的整个流程。
  • napoay
  • napoay
  • 2017-03-11 00:29
  • 9450

logstash实现日志文件同步到elasticsearch深入详解

引言:之前博文介绍过了mysql/oracle与ES之间的同步机制。而logstash最初始的日志同步功能还没有介绍。本文就logstash同步日志到ES做下详细解读。1、目的:将本地磁盘存储的日志文...

Logstash处理json格式日志文件的三种方法

file { type => "voip_feedback" path => ["/usr1/data/voip_feedback.txt"] fo...

16.ELK实时日志分析平台之Beats平台简介

ELK实时日志分析系统的Beats平台的简单介绍。

24.ELK实时日志分析平台之Filebeat介绍及安装方法

介绍Filebeat及其安装方法。

23.ELK实时日志分析平台之Beats平台搭建

介绍实时日志分析平台ELK的搭建过程。

Filebeat 日志收集器 安装和配置

Filebeat的配置文件是/etc/filebeat/filebeat.yml,遵循YAML语法。具体可以配置如下几个项目: Filebeat Output Shipper ...

Filebeat的高级配置-Filebeat部分

http://blog.csdn.net/xiongzhichao/article/details/51783704 在Filebeat安装完成准备使用前,最好先对Filebeat进行一些详细的...

20.ELK实时日志分析平台之Elasticsearch 查询简介

简单介绍Elasticsearch的Json DSL查询方法。

17.ELK实时日志分析平台之Elasticsearch简介

简单介绍Elasticsearch的功能及一些基本概念。
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)