MTK GPIO

MTK平台驱动调试指南 收藏

GPIO设置篇

一、GPIO有关的函数

1.GPIO_ModeSetup:

函数原型:void GPIO_ModeSetup(kal_uint16 pin, kal_uint16 conf_dada)

功能:设置GPIO的工作模式是作为GPIO,还是作为专有功能接口。

参数:

pin:GPIO 的pin脚号,对应于原理图上MTK62XX 主CPU芯片的上的GPIO标号

conf_dada:值有0~3。其中0是表示作为GPIO模式,其他根据专有功能的不同进行设置。

2.GPO_InitIO

函数原型:void GPIO_InitIO(char direction, char port)

功能:初始化GPIO的工作方向是作为输入,还是作为输出

参数:
    direction:工作方向,0表示输入,1表示输出
    port:GPIO的pin脚

3.GPIO_ReadIO
函数原型:char GPIO_ReadIO(char port)
功能:从GPIO读取数据
参数:
    port:GPIO的pin脚

4.GPIO_WriteIO
函数原型:void GPIO_WriteIO(kal_char data, kal_char port)
功能:往GPIO写数据
参数:
data: 1表示给高电平,0表示给低电平
port:GPIO的pin脚
备注:这些函数在Gpio.C中可以找到。

二、GPIO模式设置
    GPIO口在系统上电的时候,有的是默认高电平,有的是默认低电平,这是MCU内部决定的,软件无法更改,但是在系统开机过程中,会对GPIO进行初始化,MCU中有几个GPIO模式初始化寄存器,通过这个寄存器给GPIO设置初始模式。
    例如:以下这个寄存器就是用来设置0-7号GPIO的模工作模式的。
    这个初始化过程在Gpio_Drv.C中的函数GPIO_init()中,项目开始的时候,先要检查这个部分的模式设置是否正确。

三、各个功能模块的GPIO设置
1.    LCD背光,马达
    有的LCD背光是靠GPIO进行控制的,有的则靠PMIC进行控制。但不管那个方式进行控制,都只需修改Custom_equipment.c中的相关部分就可以了,具体如下:
首先,检查数组
GPIO_MAP_ENTRY gpio_map_tbl[] = {
/*GPIO_LABEL_LCD_BACKLIGHT */   {GPIO_VAILD, GPIO_PORT_24, netname[GPIO_LABEL_LCD_BACKLIGHT], NULL },



};
将没有使用的GPIO,用GPIO_INVALID给屏蔽掉。
然后,修改函数custom_cfg_gpio_set_level,在对应的GPIO类型上将控制函数添加进去即可。比如:
   switch(gpio_dev_type)    
   {
      case GPIO_DEV_LED_MAINLCD:
      if( gpio_dev_level == LED_LIGHT_LEVEL0)// LEVEL0- LEVEL5是背光由若到强的控制,LEVEL0表示关闭背光

GPIO_WriteIO(GPIO_OFF, custom_cfg_outward_gpio_port(GPIO_LABEL_LCD_BACKLIGHT) );
        else
           GPIO_WriteIO(GPIO_ON, custom_cfg_outward_gpio_port(GPIO_LABEL_LCD_BACKLIGHT) );
        PWM2_level(gpio_dev_level);
        break;

2.    蓝牙
在文件bt_hw_define.h中参照原理图进行对应GPIO的修改。
   #define BT_GPIO_RESET     52//39 //GPIO_39 : PMIC reset
   #define BT_GPIO_DSC       36//;4 //GPIO_4 : to disconnect RFComm link
   #define BT_GPIO_POWER 4//12 //GPIO_12: Power
   #define BT_GPIO_DATASELECT 0//;3 //GPIO_3: DataSelect

3.    Camera
在文件Camera_hw.c和sccb.h中参照原理图进行对应GPIO的修改。
【Camera_hw.c】
       #define MODULE_POWER_PIN        6  // GPIO NO.
#define MODULE_RESET_PIN        12  // GPIO NO.
#define MODULE_CMPDN_PIN        13  // GPIO NO.

【sccb.h】
#define SCCB_SERIAL_CLK_PIN     8
#define SCCB_SERIAL_DATA_PIN       9

4.    TouchPanel
在文件Touch_panel_spi.h中参照原理图进行对应GPIO的修改
   #define SPI_DIN_PIN     1 //17  /*1GPO*/
   #define SPI_CLK_PIN     8 //20   /*8GPO*/
   #define SPI_DOUT_PIN    38 //22  /*18GPI*/
   #define SPI_CS_PIN      9 //23  /*9GPO*/
   #define SPI_BUSY_PIN    5 //21  /*5GPI*/

四、总结
    GPIO的设置相对来讲比较简单,只要仔细参对原理图,基本上就可以将GPIO配置好。当然有些时候GPIO配置好了也达不到效果,就需要和硬件工程师一起来进行检测分析,测量对应电路的工作电压或电流,来判断工作是否正常。总之在前期的调试方面,多跟硬件工程师沟通、讨论、分析,会很快解决问题。

Ø      中断调试篇
中断调试一般来说包括以下几个方面,一一做简单介绍:

1.     中断号匹配

这个部分在文件eint_def.c中进行设置,参照原理图设置即可。

2.     中断触发方式的设置

在文件eint_def.c中,首先要对中断的触发响应时间进行设置,是在数组变量custom_eint_sw_debounce_time_delay中。一般情况下这个部分是不用动的,但有时候中断触发有问题的时候,这就是一个调试点。比如对于Touchpanel的中断,对应的响应时间一般是0,如果不是0,就需要修改。

另外,因为中断触发分电平触发和边沿触发,电平触发又分高电平触发和低电平触发,边沿触发又分为上升沿触发和下降沿触发,因此先需要跟硬件工程师了解对应的中断触发方式,然后在对应的中断初始化的地方修改触发方式。

3.      中断处理流程调试
有时候中断设置好了,对应功能也不能正常使用,那么就需要调试中断处理流程了,需要增加trace,一般我们会用系统带的trace函数kal_prompt_trace,有时候调试这个函数不能正常工作,那么我们就用这个文件中的函数sys_print打印trace信息,要使用这个函数,需要在系统最开始启动的时候,调用sys_uart_init进行初始化。这个函数库是在6228平台上做的,可能在其他平台上寄存器因为不同,需要进行修改。

往往在调试的过程中,经常发现是给芯片供电方面出了问题。因为有时候MTK给过来的代码,在他们的参考设计上是一种供电方式,但是在我们的设计上可能就是不一样了。所以在找到芯片供电部分代码的时候,查找对应资料,看是否调用正常。

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/lym54533442/archive/2009/11/28/4894399.aspx

你可能感兴趣的:(设计模式,C++,c,C#,MTK)