MTK平台驱动调试介绍ppt课件.ppt_第1页
MTK平台驱动调试介绍ppt课件.ppt_第2页
MTK平台驱动调试介绍ppt课件.ppt_第3页
MTK平台驱动调试介绍ppt课件.ppt_第4页
MTK平台驱动调试介绍ppt课件.ppt_第5页
已阅读5页,还剩32页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Agenda,一、驱动调试开发周期(一)给出EVT贴片软件(二)EVT至MP驱动调试(三)MP后项目维护二、驱动调试步骤(一)掌握资料(二)EVT贴片软件的整合(三)各模块调试优化三、各模块调试介绍,一.驱动调试开发周期,(一)给出EVT贴片软件接手新项目后需要根据硬件资源配置表和机器的配置整合一版软件,用于EVT试产主板贴片用,最低要求要能开机,背光能够点亮。如果LCD能点亮正常显示,则有利于产线测试,加快项目进度。(二)EVT至MP驱动调试拿到主板后调试各个模块:调试LCD、Camera效果等,保证各个模块能够正常工作。一直到量产前需要和硬件,测试工程师不断沟通解决出现的问题。(三)MP后

2、项目维护量产后需要跟进产线出现的问题及客户反映的问题。,二.驱动调试步骤,(一)掌握资料通常开始一个新项目的驱动调试的时候,需要掌握以下资料。1.硬件资源配置表(Hardwareresourcetable)它包括BB上所有硬件资源的用法:GPIO/GPOInterfaceInterruptsettingKeypadsettingADCsettingChipSelect/Audiosetting/T-FlashCardInterface2.硬件原理图详细的硬件接法,便于调试时参考用。3.产品规格书/产品定义了解项目定义:机器的结构形式、LCD像素大小、sensor类型等。以上资料由项目经理和硬件

3、工程师给出。,(二)EVT贴片软件的整合,1.配置makefilexxx_GPRS.mak(mcumake)Option.mak(mcumake)不同的项目需求不同,需要修改和添加一些宏开关控制。基本格式和步骤:MXX_GPRS.mak:XXX_XXX=XXXXXX_XXX=NONEXXX_XXX=TRUEXXX_XXX=FALSEOption.mak:ifdefXXX_XXXifneq($(strip$(XXX_XXX),FALSE)COM_DEFS+=XXX_XXXendifendif代码中就使用XXX_XXX来控制相关代码;#ifdefined(XXX_XXX)/addcodehere#

4、endif,驱动常用的一些宏开关:RF_MODULE=SIMC25_06B_MT6139E#MT6129DAFC_VCXO_TYPE=VCXO#VCTCXOPMIC=MT6305#ChargeFunction,NONE,MT6305orMT6318PLATFORM=MT6225LCD_MODULE=TRULY_1N2007_LCMMSDC_CARD_SUPPORT_TYPE=MSDC_SD_MMCFM_RADIO_CHIP=TEA5760UK#NONE,TEA5767HN,NAND_SUPPORT=FALSEUSB_IN_NORMAL_MODE_SUPPORT=TRUEISP_SUPPORT=

5、TRUE#TRUE,FALSECMOS_SENSOR=OV7670BLUETOOTH_SUPPORT=BTMTK_MT6601TOUCH_PANEL_SUPPORT=TRUE#TRUEorFALSEPHONE_TYPE=BAR#BAR,CLAMSHELL,SLIDEPLATFORM_NAME=XXMAIN_LCD_SIZE=240X320WEBCAM_SUPPORT=TRUE#TRUE,FALSEforWEBCAMERAsupportYUV_SENSOR_SUPPORT=TRUE#TRUE,FALSE,2.根据Hardwareresourcetable配置硬件资源,配置GPIO/GPO:GPI

6、O/GPO的初始化设置;配置中断号:蓝牙中断号、ChargerDRV_WriteReg(GPIO_MODE2,0 x5555);DRV_WriteReg(GPIO_MODE3,0 x1555);DRV_WriteReg(GPIO_MODE5,0 x5680);DRV_WriteReg(GPIO_MODE6,0 x5515);DRV_WriteReg(GPIO_MODE7,0 x1555);DRV_WriteReg(GPO_MODE,0 x0005);/GPO0forEA24#ifdefined(_BAR_K28_)GPIO_ModeSetup(2,0);GPIO_InitIO(1,2);GPI

7、O_WriteIO(0,2);#elifdefined(_BAR_S50_)/LK2007-06-27GPIO_ModeSetup(0,0);GPIO_InitIO(1,0);GPIO_WriteIO(0,0);#endif,模块调试:Backlight,mcucustomdrvmisc_drvSIMC25_06B_BBcustom_equipment.ckal_boolcustom_cfg_gpio_set_level(kal_uint8gpio_dev_type,kal_uint8gpio_dev_level)switch(gpio_dev_type)caseGPIO_DEV_LED_MA

8、INLCD:/用屏的宏开关来控制代码break;,注意事项:需根据硬件接法区分背光芯片使能端控制是脉冲计数还是PWM方式。脉冲计数:在GPIO端输出高低电平来模拟脉冲,连续发送一定数量的脉冲到背光芯片使能端,在其限定的范围之内,脉冲数越多,背光越亮,反之越暗。用此方式可以节省PWM资源用于其他用途。if(gpio_dev_level)switch(gpio_dev_level)case1:temp=4;/7break;case2:temp=11;/13break;case3:temp=16;/19break;case4:temp=20;/25break;case5:temp=25;/27bre

9、ak;default:temp=16;break;for(i=0;itemp;i+)GPIO_WriteIO(0,7);for(j=0;j100;j+)GPIO_WriteIO(1,7);for(j=0;j20;j+)elseGPIO_WriteIO(0,7);,PWM模式:需要根据实际情况在Mcucustomdrvmisc_drvcustom_hw_default.c文件中修改PWM_Level_Info;即频率和占空比。MMI对背光的控制:mcuplutommimmigpiogpioSrcGeneralDeviceInterface.c;关键的几个函数:voidTurnOffBacklig

10、ht(void):打开背光计时的timer。StaticvoidBacklightTimerHdlr(void):背光timer调用处理函数。VoidTurnOnBacklight(gpio_backlight_time_enumtime_enum):打开的背光函数。注意:当time_enum=0时,即调用TurnOnBacklight(0),作用是关闭背光的timer,使背光保持常亮不灭。如果需要恢复正常需要先调用一下TurnOffBacklight()函数使timer正常工作。背光、键盘灯的亮灭和lcdsleepin/sleepout在以上函数里有同步的处理。,模块调试:LCM,以SUNR

11、ISE_0255_LCM为例步骤1:XXX_GPRS.mak中配置LCD_MODULE和MAIN_LCD_SIZE;LCD_MODULE=SUNRISE_0255_LCMMAIN_LCD_SIZE=240X320Option.mak中加入:COM_DEFS_FOR_SUNRISE_0255_LCM=SUNRISE_0255_LCMHX8312COLOR_LCDTFT_MAINLCDQVGA_MAINLCD其中HX8312为LCDdriverIC的型号;COLOR_LCD,TFT_MAINLCD,QVGA_MAINLCD为LCD的类型QVGA_MAINLCD:240X320QCIF_MAINLC

12、D:176X220QQVGA_MAINLCD:128X160如果有SubLCD;则需要顺序加入DUAL_LCD;COLOR_SUBLCD以及型号名称。,步骤2:McucustomdrvLCD目录下添加SUNRISE_0255_LCM模块;目录以SUNRISE_0255_LCM为名。加入和修改5个文件分别为:lcd.clcd_hw.hlcd_sw.hlcd_sw_inc.hlcd_sw_rnd.hlcd.c:实现LCD的驱动接口;关键函数:init,sleepin,sleepout,blockwrite,init_lcd_interface等。lcd_sw.h:配置dataaddress;com

13、mandaddress和outputformat等;lcd_sw_inc.h:配置LCDWIDTH和HEIGHT;lcd_sw_rnd.h:一般不需修改;lcd_hw.h:一般不需要修改;,关键函数介绍:Voidinit_lcd_interface(void):LCD读写时序的设置,参考driveric的spec,一般差异不大,较稳定;VoidLCD_Init_xxxx(void):加入供应商给的初始化设置代码。需要注意开始部分的Reset信号设置,延时要满足IC的要求。LCD的显示效果基本上就在这段代码里调整。如果要兼容其它屏,需要在reset后读取IC的ID来区分不同的屏;VoidLCD_

14、EnterSleep_xxxx(void)和VoidLCD_ExitSleep_xxxx(void):加入厂商给的sleep代码;voidLCD_BlockWrite_HX8312A(kal_uint16startx,kal_uint16starty,kal_uint16endx,kal_uint16endy):刷屏函数,设置刷屏时的起始、结束地址。Kal_boolESD_check(void):ESD措施,防止静电干扰使寄存器数据乱掉,定时去检测LCM的IC寄存器数据,如果数据乱了,则重新写入,保证LCD能正常显示。几个关键指令(Lcd_sw.h):写寄存器:LCD_CtrlWrite_xx

15、xx()写数据:LCD_DataWrite_xxxx()读数据:LCD_DataRead_xxxx(),LCD常见问题及调试方法水波纹(flicker):正负电压不对称导致,需要调整Vcom值。白屏或花屏:可能是init寄存器设置有问题,在初始化代码中调试,刷一屏红黄蓝三色,如果正常则可以排除初始化设置的问题。送数据的方式有问题,分清8bit/9bit/16bit/18bit。Blockwrite地址寄存器设置错误。颜色失常:需要调整gamma值,需要厂家调试。整体色调偏暗或是偏淡:对比度有问题,调整涉及到电压的几个相关寄存器。,模块调试:Vibrator,mcucustomdrvmisc_d

16、rvSIMC25_06B_BBcustom_equipment.ckal_boolcustom_cfg_gpio_set_level(kal_uint8gpio_dev_type,kal_uint8gpio_dev_level)switch(gpio_dev_type)caseGPIO_DEV_VIBRATOR:/addcodeherebreak;马达控制方式:1.GPIO直接控制:只有高低电平的切换。2.PWM方式:可以调整占空比和频率来调节马达的振感。,模块调试:Touchpanel,customdrvmisc_drvM678_BBtouch_panel_custom.ccustomdrv

17、misc_drvM678_BBtouch_panel_custom.hcustomdrvmisc_drvM678_BBtouch_panel_spi.ccustomdrvmisc_drvM678_BBtouch_panel_spi.hdrvsrctouch_panel.cdrvsrctouch_panel_main.c修改点包括:GPIO分配、ADC值、坐标值、中断配置、压力检测等。经常调试用到的函数:IsPressureValid:压力检测,检测计算出Rtouch值,可用来去除飞笔。Tp_read_adc:读取当前pendown的adc值,可以改变算法,调整touchpanel的效果。其他的

18、诸如:touch_panel_HISR、touch_panel_init、touch_panel_down_hdr,可以在这些函数里加一些延时处理,可以改善断笔飞笔。,模块调试:Camera,以OV9655为例:步骤1:XXX_GPRS.mak中配置ISP_SUPPORT和CMOS_SENSOR:ISP_SUPPORTTRUECMOS_SENSOR=OV9655CAMERA_PIXEL=ONE_MEGA_PIXEL注:(一般30万象素可以插值到100万;130万可以插值到200万象素)如果是YUVsensor,需要设置:YUV_SENSOR_SUPPORT=TRUE步骤2:Mcucustomd

19、rvimage_sensor下添加OV9655目录;添加或修改文件:camera_hw.c:ModulePoweron/off控制;(GPIO分配要看硬件的资源分配表)camera_para.c:ISP、Sensor相关寄存器配置;在实际调试中对比效果来修改;image_sensor.c:timing;sensorinit;poweron/off;preview;capture等接口实现;image_sensor.h:有关sensor一些属性设置(一些宏定义);camera_info.c:一般不需修改;在完成所有的功能之后,效果调试是主要工作。主要工具:META;CCT等;,关于分屏的一点说明

20、:Camera录像时经常碰到preview或者capture分屏的现象。如果录像后保存的片源放到电脑上看还是有分屏,说明问题出在sensor录像这一块。通常我们是降低录像的帧率来解决问题,15fps-12fps。如果是preview时移动手机在屏上看到的分屏,特别是QVGA的屏经常碰到这种情形。则原因是sensor采集数据往屏的buffer里填数据的时序和LCD刷屏的时序不匹配的导致。二者间缺少一个握手信号,所以经常会出现两帧图像重叠的现象,即LCD上看到的分屏。后续MTK会引出一个SYNC同步信号用于LCD和sensor的匹配,解决这个问题。关于显示效果的调试:RAWsensor数据处理这一

21、块是BB的ISP处理,也需要CCT工具调试,通常需要等mtk工程师过来支持;YUVsensor数据处理是在sensor的IC里做的,所以一般是IC厂商过来支持。但是缺少专业工具调试,有同事已经做好了用ATcommand写寄存器数据调sensor的方法,比较方便。,模块调试:Keypad,键盘定义需要对照硬件资源配置表来设置。customdrvmisc_drvM678_BBkeypad_def.cconstkeypad_structkeypad_custom_def=#ifdefined(_PHONE_SLIDE_)/滑盖机型#ifdefined(_SLIDE_M678)/addm678keyp

22、addefinehere/ROW0(第一列)DEVICE_KEY_XX,/ROW1(第二列)./.#else#endif#elifdefined(_PHONE_BAR_)/直板机型/#elifdefined(_PHONE_SPIN)/旋转机型/#elifdefined(_PHONE_CLAMSHELL)/翻盖机型/#endif;,如果需要添加新键,除了上述外还需修改以下几处:interfacehwdrvkbd_table.h定义DEVICE_KEY_XX:注意顺序#defineDEVICE_KEY_XX顺序值plutommimmiFrameworkOslOslSrcKeyBrd.c假设DEVI

23、CE_KEY_XX为特定的按键定义特定的按键constU16PresentAllKeys=KEY_0,KEY_1,KEY_2,KEY_3,KEY_4,KEY_5,/定义特定的按键KEY_XX,;,键盘映射(注意加入顺序要与PresentAllKeys中一致)staticconstKeyPadMapnKeyPadMap=DEVICE_KEY_0,KEY_0,KEY_TIMER_ID0,TONE_DTMF_0,DEVICE_AUDIO_PLAY_INFINITE,DEVICE_KEY_1,KEY_1,KEY_TIMER_ID1,TONE_DTMF_1,DEVICE_AUDIO_PLAY_INFIN

24、ITE,/映射特定的按键DEVICE_KEY_XX,KEY_XX,KEY_TIMER_IDXX,TONE_DTMF_1,DEVICE_AUDIO_PLAY_INFINITE,;定义TIMERID:即KEY_TIMER_IDXX在plutommimmiIncTimerEvents.h中顺序加入KEY_TIMER_IDXX;在drvsrckbdmain.c中可以修改debouncetime,LongpressTime,RepeatTime等参数来满足特殊的需要。,模块调试:AFE,customaudioM678_BBafe.c(模拟开关、PA切换等)customaudioM678_BBaudcoe

25、ff.c(FIRInput/Output参数)customaudioM678_BBnvram_default_audio.c(GAIN值)l1audioafe2.c(AFE管理代码)硬件给出的音频参数在audcoeff.c和nvram_default_audio.c中修改。Afe.c中切换PA开关的动作,通常是一个GPIO或GPO来控制。Afe2.c中都是afe的管理代码,比如左右声道切换的函数等等,一般比较成熟,很少修改。可以关注一下里面函数的调用。,模块调试:ADC,以MT6226平台为例,可用资源有ADC0-ADC6。通常用到ADC通道的有charger,customdrvmisc_dr

26、vM678_BBadc_channel.c#ifdefined(_LINE_CONTROL_EARPHONE_SUPPORT_)constkal_uint8ADC_REMOTE=6;/假设硬件接ADC6#endifkal_uint8custom_adc_get_channel(adc_channel_typetype)Switch(type)#ifdefined(_LINE_CONTROL_EARPHONE_SUPPORT_)caseremote_adc_channel:return(kal_uint8)ADC_REMOTE);#endif#endif;,customdrvmisc_drvM6

27、78_BBauxmain.cvoidaux_task_main(task_entry_struct*task_entry_ptr)#ifdefined(_LINE_CONTROL_EARPHONE_SUPPORT_)kal_uint8remote_adc_logic_id;kal_uint8remote_adc_no#endif/创建#ifdefined(_LINE_CONTROL_EARPHONE_SUPPORT_)remote_adc_no=custom_adc_get_channel(remote_adc_channel)remote_adc_logic_id=adc_sche_crea

28、te_object(MOD_AUX,remote_adc_no,40,1,KAL_TRUE);#endifwhile(1)receive_msg_ext_q(task_info_gtask_entry_ptr-task_indx.task_ext_qid,#endif,break;/销毁caseMSG_ID_BMT_ADC_MEASURE_DONE_CONF:#ifdefined(_LINE_CONTROL_EARPHONE_SUPPORT_)elseif(mea_done_ptr-adc_sche_id=remote_adc_logic_id)adc_measure_count+;remot

29、e_value=(kal_int32)mea_done_ptr-volt;aux_remove_adc_channel(remote_adc_logic_id);#endif,模块调试:EINT,M6226平台有Eint0Eint7,Eint4Eint7是GPIO复用过来的。以线控为例,介绍一下修改或者添加流程:interfacehwdrvEint.htypedefenum#ifdefined(_LINE_CONTROL_EARPHONE_SUPPORT_)remote_eint_chann,#endifeint_channel_type;customdrvmisc_drvM678_BBEin

30、t_def.c#ifdefined(_LINE_CONTROL_EARPHONE_SUPPORT_)constkal_uint8REMOTE_EINT_NO=3;/假设硬件配置为EINT3#endifkal_uint8custom_eint_get_channel(eint_channel_typetype)switch(type)#ifdefined(_LINE_CONTROL_EARPHONE_SUPPORT_)caseremote_eint_chann:return(kal_uint8)REMOTE_EINT_NO);#endif,customdrvmisc_drvM678_BBauxm

31、ain.c/中断处理函数voidREMOTE_EINT_HISR(void)if(remote_state)/高电平/相关处理代码else/低电平/相关处理代码/中断注册voidaux_task_main(task_entry_struct*task_entry_ptr)kal_uint8remote_eint_no;#ifdefined(_LINE_CONTROL_EARPHONE_SUPPORT_)remote_eint_no=custom_eint_get_channel(remote_eint_chann);EINT_Registration(remote_eint_no,KAL_TR

32、UE,remote_state,REMOTE_EINT_HISR,KAL_TRUE);#endif在注册中断时要注意:中断触发方式:电平触发/边沿触发?debounce:Enable/Disable?电平触发高电平有效还是低电平有效等问题。,Debouncetime对于Eint0Eint3,可以通过下面的文件来修改debouncetime;而Eint4Eint7没有debounce机制。customdrvmisc_drvM678_BBEint_def.ckal_uint8custom_eint_sw_debounce_time_delayEINT_MAX_CHANNEL=50,/*EINT0*

33、/25,/*EINT1*/50,/*EINT2*/50/*EINT3*/;也可通过下述函数来修改EINTaddr()EINT_Set_HW_Debounce()EINT_SW_Debounce_Modify(),模块调试:Charger/USB,customdrvmisc_drvM678_BBchr_parameter.c充电相关电压和电流的设置:bmt_customized_structbmt_custom_chr_def=;里面包括一些重要的电压电流值的设置。电池格数的算法:custom_equipment.c中custom_cfg_vbat_level_regulator函数处理每格电压的设置:nvram_user_config.c(06B)/custom_hw_default.c(05C)/*BatteryvoltageLevel*/3500000,/*LowBatteryPoweroff*/3550000,/*LowBattery*/*batterylevel18*/3580000,3630000,3740000,3840000,3950000,9

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论