2024年2月2日发(作者:)

1.

makefile

MXX_(mcumake)

(mcumake)

对于同一个平台,不同的项目有着不同的功能配置。对于驱动调试来说,需要修改和添加一些宏开关控制;

基本格式和步骤:

MXX_ :

XXX_XXX = XXX

XXX_XXX = NONE

XXX_XXX = TRUE

XXX_XXX = FALSE

:

ifdef XXX_XXX

ifneq ($(strip $( XXX_XXX)),FALSE)

COM_DEFS += XXX_XXX

endif

endif

代码中就使用XXX_XXX来控制相关代码;

#if defined(XXX_XXX)

//add code here

#endif

以MT6226(05c)平台为例:列举一些修改比较频繁的开关:

PLATFORM

CHIP_VER

LCD_MODULE

CUSTOM_CFLAGS

EXT_CAM_MODULE

ISP_SUPPORT

CMOS_SENSOR

NOR_FLASH_TYPE

MSDC_CARD_SUPPORT_TYPE

BLUETOOTH_SUPPORT

TOUCH_PANEL_SUPPORT

MOTION_SENSOR_SUPPORT

MT6226A

MT6226

S00

MT6226B

MT6226

S01

MT6226M

MT6226M

S01

MT6227A

MT6227A

S00

MT6227B

MT6227B

S01

用于LCM Module控制;详细见No.2

如用JTAG进行DEBUG需打开此开关;注意关闭Watch Dog

如用外部DSP来控制Sensor;需用到此开关;详见No.3

如Camera没有外挂DSP需打开此开关;

用以区分Sensor的类型;如OV7660;OV9650等

所用NOR Flash的类型;现一般是AMD Series;

用以是否支持T卡的开关;不支持为NONE;支持为MSDC_SD_MMC

用以是否支持蓝牙的开关;不支持为NONE;支持为所用芯片的类型;

用以是否支持触摸屏的开关;不支持为FALSE;支持为TRUE;

用以是否支持Motion sensor的开关;不支持为NONE;支持为所用芯片类型

MAIN_LCD_SIZE

FM_RADIO_CHIP

NAND_SUPPORT

PHONE_TYPE

PLATFORM_NAME

CAMERA_PIXEL

所用LCD的大小;如240X320;176X220;120X160等

用以是否支持FM功能;不支持为NONE;支持为所用芯片类型;

用以是否支持NAND FLASH;不支持为FASLE;支持为TRUE

滑盖机: SLIDE;翻盖机:CLAMSHELL;平板机:BAR;旋转:SPIN

项目名称;

所用Sensor象素;默认30万;130万:ONE_MEGA_PIXEL; 200万:TWO_MEGA_PIXEL等等

WEBCAM_SUPPORT

ect…….

用以是否支持Web Camera功能开关;支持为TRUE;不支持为FALSE

其他一些开关视项目而定;可以会修改;可能会添加一些开关。

(mcutools)

这个文件是当在mcucustomdrv下添加与LCD,image_sensor等类似的模块时,需要修改此文件以便ADS编译系统能编译到此模块下的文件;

可以参考image_sensor。

if (($project ne "basic") && ($project ne "l1s") && defined($cmos_sensor)) {

if ($cmos_sensor ne "NONE") {

push(@thatdirs, "drvimage_sensor$cmos_sensor");

}

}

2. LCM;Backlight;Vibrator

以SUNRISE_0255_LCM为例

步骤1:

MXX_中配置LCD_MODULE和MAIN_LCD_SIZE;

LCD_MODULE = SUNRISE_0255_LCM

MAIN_LCD_SIZE = 240X320

中加入:

COM_DEFS_FOR_SUNRISE_0255_LCM = SUNRISE_0255_LCM HX8312 COLOR_LCD TFT_MAINLCD

QVGA_MAINLCD

其中HX8312为LCD的型号;

COLOR_LCD,TFT_MAINLCD,QVGA_MAINLCD为LCD的类型

QVGA_MAINLCD:240X320

QCIF_MAINLCD: 176X220

QQVGA_MAINLCD: 120X160

如在SUNRISE_0255_LCM的基础上添加兼容屏;则在HX8312后面顺序加入LCD的型号

如果有Sub LCD;则需要顺序加入DUAL_LCD;COLOR_SUBLCD以及型号名称;

步骤2:

McucustomdrvLCD目录下添加SUNRISE_0255_LCM模块;目录以SUNRISE_0255_LCM为名。

可以参考其他LCM;加入和修改5个文件分别为:

lcd.c

lcd_hw.h

lcd_sw.h

lcd_sw_inc.h

lcd_sw_rnd.h

lcd.c:实现LCD的驱动接口

一般有init; sleep in;sleep out; block write等

lcd_hw.h: 一般不需要修改;

lcd_sw.h: 配置data address;command address和output format;

lcd_sw_inc.h:配置LCD WIDTH和HEIGHT;

lcd_sw_rnd.h: 一般不需修改;

步骤3:

加入背光控制代码;

Mcucustomdrvmisc_drvcustom_equipment.c

kal_bool custom_cfg_gpio_set_level(kal_uint8 gpio_dev_type, kal_uint8

gpio_dev_level )

{

//用SUNRISE_0255_LCM来控制代码

}

GPIO模式和PWM模式;(函数默认是PWM模式)

如果是GPIO模式;则在上述函数中加入模拟代码;

如果是PWM模式;则需要根据实际情况在Mcucustomdrvmisc_drvcustom_hw_default.c文件中修改PWM1_Level_Info;即频率和占空比;

另外在mcuplutommimmigpiogpioSrcGeneralDeviceInterface.c中有详细的MMI对背光的控制代码;

另外还需熟悉lcd_if.c(mcudrvsrc)对上述接口的调用;

3.Camera module;Sensor

外挂DSP暂不讨论;以OV9650为例:

步骤1:

MXX_中配置ISP_SUPPORT和CMOS_SENSOR;

ISP_SUPPORT = TRUE

CMOS_SENSOR = OV9650

CAMERA_PIXEL = ONE_MEGA_PIXEL

注:(一般30万象素可以插值到100万;130万可以插值到200万象素)

步骤2:

Mcucustomdrvimage_sensor下添加OV9650目录;

添加或修改文件:

camera_hw.c:Module Power on/off 控制;(GPIO分配要看硬件的资源分配表)

camera_para.c: ISP、Sensor相关寄存器配置;在实际调试中对比效果来修改;

image_sensor.c:timing;sensor init;power on/off;preview;capture等接口实现;

image_sensor.h:有关sensor一些属性设置(一些宏定义);

camera_info.c: 一般不需修改;

在完成所有的功能之后;效果调试是主要工作;

主要工具:META;CCT等;

关于ISP Address可参考MTK平台的DataSheet;

步骤3:

需对以下目录的文件有一定的了解!

mediacamera;

mediavideo;

plutommimtkappCamera

plutommimtkappVideo

plutommimtkappMDI

4.Keypad

按键分布图(可对照特定项目的硬件资源分配表)

KCOL0

KCOL1

KCOL2

KCOL3

KCOL4

KCOL5

KCOL6

KROW0

KROW1

KROW2

KROW3

KROW4

KROW5

KEY_XX

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

KEY

对于特定项目的键盘的定义和映射以及其他一些特殊的处理;代码用PHONE_TYPE和PLATFORM_NAME的组合来控制;

如 PHONE_TYPE = SLIDE

PLATFORM_NAME = M678

则代码控制如下:

customdrvmisc_drvM678_BBkeypad_def.c

const keypad_struct keypad_custom_def = {

#if defined(__PHONE_SLIDE__) //滑盖机型

#if defined(__SLIDE_M678)

//add m678 keypad define here

//ROW 0(第一列)

DEVICE_KEY_XX,

……

//ROW 1(第二列)

…….

//

…….

#else

#endif

#elif defined(__PHONE_BAR__) //直板机型

//

#elif defined(__PHONE_SPIN) //旋转机型

//

#elif defined(__PHONE_CLAMSHELL) //翻盖机型

//

#endif

};

如果除了平台提供的基本的按键外还需添加特定的按键定义;则除了上述外还需修改以下几处:

interfacehwdrvkbd_table.h

定义DEVICE_KEY_XX;注意顺序

#define DEVICE_KEY_XX 顺序值

plutommimmiFrameworkOslOslSrcKeyBrd.c

假设DEVICE_KEY_XX为特定的按键

//定义特定的按键

const U16 PresentAllKeys[]=

{

KEY_0,

KEY_1,

KEY_2,

KEY_3,

KEY_4,

KEY_5,

……

//定义特定的按键

#if defined(__SLIDE_M678)

,KEY_XX

#endif

};

//键盘映射(注意加入顺序要与PresentAllKeys[]一致)

static const KeyPadMap nKeyPadMap[] = {

{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_INFINITE},

……

……

//映射特定的按键

#if defined(__SLIDE_M678)

{DEVICE_KEY_XX, KEY_XX, KEY_TIMER_IDXX, TONE_DTMF_1, DEVICE_AUDIO_PLAY_INFINITE},

#endif

};

//定义TIMER ID;即KEY_TIMER_IDXX

plutommimmiIncTimerEvents.h

顺序加入KEY_TIMER_IDXX;

另外在drvsrckbdmain.c

中可以修改debounce time; Long press Time; Repeat Time等参数来满足特殊的需要;

5.耳机检测;线控

customdrvmisc_drvM678_BBauxmain.c

对于耳机检测;一般只需关心AUX_EINT_NO(一般平台默认)和SENDKEY_ADC(见auxmain.c);

可根据硬件的实际情况作一些相关的调整;

对于线控来说;需要配置REMOTE_EINT_NO、 REMOTE_ADC以及按键Press/Release对应的ADC值;

具体的处理过程可参考26平台__LINE_CONTROL_EARPHONE_SUPPORT__控制的代码;

6.ADC

MT6226平台可用资源ADC0-ADC6;

以线控为例,介绍一下修改或者添加流程:

interfacehwdrvBmt.h

typedef enum {

vbat_adc_channel=0,

visense_adc_channel,

vbattmp_adc_channel,

……

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

remote_adc_channel,

#endif

……

} adc_channel_type;

customdrvmisc_drvM678_BBadc_channel.c

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

const kal_uint8 ADC_REMOTE=6; //假设硬件接ADC6

#endif

kal_uint8 custom_adc_get_channel(adc_channel_type type)

{

Switch(type)

{

………

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

case remote_adc_channel:

return ((kal_uint8)ADC_REMOTE);

#endif

………

}

#endif

};

customdrvmisc_drvM678_BBauxmain.c

void aux_task_main( task_entry_struct * task_entry_ptr )

{

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

kal_uint8 remote_adc_logic_id;

kal_uint8 remote_adc_no

#endif

……

……

//创建

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

remote_adc_no = custom_adc_get_channel(remote_adc_channel)

remote_adc_logic_id = adc_sche_create_object(MOD_AUX, remote_adc_no,40,1, KAL_TRUE);

#endif

……

while(1)

{

receive_msg_ext_q(task_info_g[task_entry_ptr->task_indx].task_ext_qid,

¤t_ilm);

switch(current__id)

{

……

//读ADC

case MSG_ID_READ_ALL_ADC_CHANNEL_REQ:

……

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

aux_read_adc_channel(remote_adc_logic_id);

#endif

……

break;

……

//销毁

case MSG_ID_BMT_ADC_MEASURE_DONE_CONF:

……

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

else if (mea_done_ptr->adc_sche_id == remote_adc_logic_id)

{

adc_measure_count++;

remote_value = (kal_int32)mea_done_ptr->volt;

aux_remove_adc_channel(remote_adc_logic_id);

}

#endif

……

}

}

}

CLAMSHELL中断的REGISTOR可以在上述函数中添加

7.EINT

关于EINT的描述请参考平台的datasheet;

以线控为例,介绍一下修改或者添加流程:

interfacehwdrvEint.h:

typedef enum

{

……

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

remote_eint_chann,

#endif

……

} eint_channel_type;

customdrvmisc_drvM678_BBEint_def.c

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

const kal_uint8 REMOTE_EINT_NO=3; //假设硬件配置为EINT3

#endif

kal_uint8 custom_eint_get_channel(eint_channel_type type)

{

switch(type)

{

……

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

case remote_eint_chann:

return ((kal_uint8)REMOTE_EINT_NO);

#endif

……

}

}

customdrvmisc_drvM678_BBauxmain.c

//中断处理函数

void REMOTE_EINT_HISR(void)

{

if (remote_state) //高电平

{

//相关处理代码

}

else//低电平

{

//相关处理代码

}

}

//中断注册

void aux_task_main( task_entry_struct * task_entry_ptr )

{

kal_uint8 remote_eint_no;

……

#if defined(__LINE_CONTROL_EARPHONE_SUPPORT__)

remote_eint_no = custom_eint_get_channel(remote_eint_chann);

EINT_Registration(remote_eint_no,KAL_TRUE,remote_state,REMOTE_EINT_HISR, KAL_TRUE);

#endif

……

}

在注册中断时要注意:

中断触发方式:电平触发/边沿触发?

debounce: Enable/Disable?

电平触发高电平有效还是低电平有效等问题。

对于Eint0 - Eint3;可以通过下面的文件来修改debounce time;而Eint4 - Eint7没有debounce机制

customdrvmisc_drvM678_BBEint_def.c

kal_uint8 custom_eint_sw_debounce_time_delay[EINT_MAX_CHANNEL] =

{

50, /*EINT0*/

25, /*EINT 1*/

50, /*EINT2*/

50 /*EINT3*/

};

单位:50ms

也可通过下述方法来修改

EINTaddr()

EINT_Set_HW_Debounce()

EINT_SW_Debounce_Modify()

等函数来修改

8. Charger/USB

可参考Customer_BMT_

相关文件:

customdrvmisc_drvM678_BBchr_parameter.c 关注点:

bmt_customized_struct bmt_custom_chr_def[] = {};

此为充电相关电压和电流的设置;

static const kal_int32 chr_usb_detect_volt;

此为CHARGER/USB检测的电压值;

Mcubmt*.*

Mcudrvsrcpwic.c

9.Touch panel

customdrvmisc_drvM678_BBtouch_panel_custom.c

customdrvmisc_drvM678_BBtouch_panel_custom.h

customdrvmisc_drvM678_BBtouch_panel_spi.c

customdrvmisc_drvM678_BBtouch_panel_spi.h

drvsrctouch_panel.c

drvsrctouch_panel_main.c

修改点包括:

GPIO分配;ADC值;坐标值;中断配置;压力检测等

具体修改可参考代码;

10. AFE

customaudioM678_BBafe.c(模拟开关、PA切换等)

customaudioM678_BBaudcoeff.c(FIR Input/Output参数)

customaudioM678_BBnvram_default_audio.c(GAIN值)

l1audioafe2.c (AFE管理代码)

以上根据硬件给出的数据来进行调整!

11.Task

如何在MTK平台使用Task?

以DMB项目为例;请参照下述文件;DMB_SUPPPORT控制

customsystemM678_BBcustom_config.c

customsystemM678_BBcustom_config.h

customdrvDMBTCC78Xdmb_hw.c

12

Nor/Nand Flash; T-Flash

添加新的NAND:

DrvsrcNAND_MTD.c

static const flash_list NAND_ID_Table[] =

{

//{ ID, planesize in MB, blocksize in KB, pagesize in B, address cycle, IO bus width, mtd sub driver}

//添加新的NAND的相关信息(参考芯片Spec)

}

DA(Download Agent)部分代码(一般不需修改)

DA_SRCsrcnand_dev_tbl.c

Const NAND_Device_S g_NandFlashDevTbl[] =

{

//加入新的NAND信息(参考芯片Spec)

};

添加新的Nor Flash

DA_SRCsrcflash_dev_tbl.c

Const Nor_Device_S g_FlashDevTbl[] =

{

//加入新的Nor信息(参考芯片Spec)

};

对于DA的修改;需重新生成DA文件用于Flash Download Tool

13. 其他功能调试

其他的调试可根据实际情况参考本平台或者其他平台。