2023年12月6日发(作者:)

mtk平台调试总结

1.代码的编译

部分私有的代码在modem中,参考平台对应的release_note(在vendor下),进行modem的编译和ap部分私有代码的拷贝。

编译preloader make pl

编译lk make lk

编译kernel make bootimage

编译dtbo make dtboimage

2.工程暗码

*#*#3646633#*#*,无相应的测试应用

3.调屏

用dct工具(vendor/mediatek/proprietary/tools/dct)确认RST脚是否配置成LCM_RST,代码里直接控制相应的寄存器,如果配置不

对,会导致rst脚无法拉高,默认应该是LCM_RST的,但笔者使用的工程偏偏是gpio模式,导致无法点亮屏幕。

默认只配置一款屏幕时lcm_compare_id函数不跑的,配置了两款屏幕以上才跑,如果读id都失败,会默认采取第一款屏的配置。

PLL_CLOCK的计算,参考FAQ11002

1、DSI vdo mode下的数据速率data_rate的大致计算公式为:

Data rate= (Height+VSA+VBP+VFP)*(Width+HSA+HBP+HFP)* total_bit_per_pixel*frame_per_second/total_lane_num

2、DSI cmd mode下的数据速率data_rate的大致计算公式为:

Data rate= width*height*1.2* total_bit_per_pixel*frame_per_second/total_lane_num

参数注释:

data_rate : 表示的是数据速率

width,height :屏幕分辨率

VSA VBP VFP :DSI vdo mode的vertical porch配置参数

HSA HBP HFP :DSI vdo mode的horizontal porch配置参数

total_bit_per_pixel :表示的是一个pixel需要用几个bit来表示,比如RGB565的话就是16个bit

frame_per_second :就是我们通常看到的fps,叫做帧率,表示每秒发送多少个帧,一般是60帧每秒

total_lane_num :表示的是data lane的对数。

params->_NUM = LCM_FOUR_LANE;

params->_ = LCM_DSI_FORMAT_RGB888;

params->al_sync_active = 4;

params->al_backporch = 16;

params->al_frontporch = 40;

params->al_active_line = 1440;

params->ntal_sync_active = 20;

params->ntal_backporch = 80;

params->ntal_frontporch = 80;

params->ntal_active_pixel = 720;

params->_disable = 1;

params->_CLOCK = 255; /* this value must be in MTK suggested table */

(4+16+60+1440)(20+80+80+720)*60*24%4%2=246240000=246M

mtk自行设计了一套tp架构,看不出有什么作用,感觉简单的东西复杂化了。

5.矩阵按键

用dct工具配置引脚,并配置相应的按键功能,遇到按键无功能时,cat mt_gpio查看引脚状态,如果状态不对,可能是引脚被占用了。

工具

dct(vendor/mediatek/proprietary/tools/dct)工具的用来辅助配置dts和配置引脚功能,最终生成。习惯了文本界面的编辑,

一下子还真习惯不了这种方式,但最终会在out目录的dts文件夹下生成文本形式的dts,可直接查看。

该工具有window和linux版本。点击Gen,Gen all,可以生成对应的dts文件。

如果提示找不到python解析器件,在window下需要配置环境变量(保证cmd下能调用到python)

对于高版本的ubuntu,系统默认是python3,重新改下

cd /usb/bin

ln -s python2.7 python

如果还报编码错误,在该文件夹子下的import xxx后面加上

reload(sys)

aultencoding("utf-8")

没功能

默认mic为dcc模式,如果电路设计为acc模式,需修改audio_custom_exp.h

dcc:mic电路串电感/或不串(micbias接到pmic外部就是模式2,接到pmic内部就是5/6(外部电路没看到micbias))

acc:mic电路串电容

typedef enum

{

AUDIO_MIC_MODE_ACC = 1,

AUDIO_MIC_MODE_DCC = 2,

AUDIO_MIC_MODE_DMIC = 3,

AUDIO_MIC_MODE_DMIC_LP = 4,

AUDIO_MIC_MODE_DCCECMDIFF = 5,

AUDIO_MIC_MODE_DCCECMSINGLE = 6,

} AUDIO_MIC_MODE;

#define PHONE_MIC_MODE (5)

#define PHONE_MIC_MODE (2) //dcc

#define PHONE_MIC_MODE (1) //acc

双mic

MTK_DUAL_MIC_SUPPORT = yes

主辅mic翻转(应该弃用了)

MTK_AUDIO_MIC_INVERSE = no

配置

手机平台默认都采用的sensorhub架构,该方式能计步,功耗更低等。拿到相应的代码后,参考平台默认的代码都能移植编译过去,可参考

实时查看scp log

while true; do cat /dev/scp;done

9.摄像头

摄像头移植部分和几年前变化不大,效果部分在hal文件夹,摄像头上电和驱动部分放置在kernel层。

10.串口

默认的串口波特率为921600,默认Android启动完成后(user/userdebug),会关掉串口log,可输入如下命令重新打开

echo 1 > /proc/mtprintk

或者修改程序(屏蔽mt_disable_uart函数)

bool mt_get_uartlog_status(void)

{

if (printk_ctrl == 1)

return false;

else if ((printk_ctrl == 0) || (printk_ctrl == 2))

return true;

return true;

}

static ssize_t mt_printk_ctrl_write(struct file *filp,const char *ubuf, size_t cnt, loff_t *data)

{

char buf[64];

long val;

int ret;

if (cnt >= sizeof(buf))

return -EINVAL;

if (copy_from_user(&buf, ubuf, cnt))

return -EFAULT;

buf[cnt] = 0;

ret = kstrtoul(buf, 10, (unsigned long *)&val);

if (ret < 0)

return ret;

switch (val) {

#ifdef CONFIG_PRINTK_MTK_UART_CONSOLE

case 0:

mt_disable_uart();

break;

case 1:

mt_enable_uart();

break;

#endif

#ifdef CONFIG_LOG_TOO_MUCH_WARNING

case 2:

set_logtoomuch_enable(0);

break;

case 3:

set_logtoomuch_enable(1);

break;

case 4:

mt_print_much_log();

break;

default:

if (val > 100)

set_detect_count(val);

break;

#else

default:

break;

#endif

}

return cnt;

}

修改

nv位置mcu/pcore/custom/modem,每次修改nv后,需要重新编译代码,这个比较不人性化,因为需要驱动工程师去编译,但nv是射

频工程师去配置的。像展讯平台,nv能直接修改,并烧写进系统,不需要编译。

热插拔

这部分比较简单,如果不支持热插拔,直接关掉该引脚功能,支持热插拔,配置plugout电平高低就行。一般热插拔都是开启的,只是插卡

极性有差异,配置下开拔出的电平就行。

如果默认没有开启热插拔,需要配置对应的引脚(上拉),可以参考其他项目的dws配置上去,同时在加上(MD side默认

开启热插拔)

MTK_SIM_HOT_SWAP = yes

可参考文档:SIM热插拔功能异常debug_

13.镜像打包

打包脚本可参考

#!/bin/sh

if [ -d "image" ]; then

rm -rf image

mkdir image

else

mkdir image

fi

mkdir image/DataBase

product=tb8765ap1_64_bsp

echo "start copy image"

cp out/target/product/$product/obj/KERNEL_OBJ/vmlinux image/

cp out/target/product/$product/preloader_$ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/vbmeta_ image/

cp out/target/product/$product/vbmeta_ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/loader_ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/ image/

cp out/target/product/$product/MT6739_Android_ image/

echo "start copy DB file"

cp vendor/mediatek/proprietary/modem/XXXX/_MT6739_S00* image/DataBase/

cp out/target/product/$product/vendor/etc/apdb/APDB_MT6739_S01__W2202 image/DataBase/

echo "stop copy image"

time=$(date "+%Y%m%d_%H%M")

zip -r YYYY_$ image

14.下载

在linux和windows下,都有对应的下载工具。点击下载,插上usb就行,电池也可以不接,这点比较方便。

下载到userdata镜像时,如果工具报镜像太大(ERROR:STATUS_TOO_LARGE(-1073479676)),可适当减少

BOARD_MTK_USERDATA_SIZE_KB的值

15.兼容DDR

修改custom_MemoryDevice.h,MemoryDeviceList_,如果MemoryDeviceList_没有该型号的emmc,到官

网下载最新的,更新到MemoryDeviceList_。

16.加大CONFIG_LOG_BUF_SHIFT

增大CONFIG_LOG_BUF_SHIFT的值,可以保存更多的内核log。

17.外置audio PA

在Ext_Speaker_Amp_Change函数中加入控制PA的函数,二合一喇叭可参考FAQ20649,更多常见音频问题参考Audio常用配

置.docx。

18.双卡改单卡

MTK_MULTI_SIM_SUPPORT = dsds 改为 MTK_MULTI_SIM_SUPPORT = ss

19.网络制式

六模C/Lf/Lt/W/T/G

C-->CDMA/CMDA2000

Lf-->FDD

Lt-->TDD

W-->WCDMA

T-->TD_SCDMA(移动)

G->GSM

L代表LTE(4G),有FDD和TDD两种

2G:CDMA,GSM

3G:WCDMA,CDMA2000,TD_SCDMA

4G:TDD,FDD

使用DMA模式

见如下代码spi-mt65xx.c,要使用dma模式,数据长度必须为4的倍数,否则以fifo的方式进行数据传输。

static bool mtk_spi_can_dma(struct spi_master *master,

struct spi_device *spi,

struct spi_transfer *xfer)

{

/* Buffers for DMA transactions must be 4-byte aligned */

return (xfer->len > MTK_SPI_MAX_FIFO_SIZE &&

(unsigned long)xfer->tx_buf % 4 == 0 &&

(unsigned long)xfer->rx_buf % 4 == 0);

}

升级

请参考这份文档,目前Android11对应的是V3.5

CS6000-BD12A-AND-V3.5EN_Android_OTA_SDCARD_

_TUNE_VALUE校准

23.音频调试工具

官网下载Audio_Tuning_Tool,工程模式打开音频调试模式Log and Debugging-->ATCI-->ALWAYS ENABLE ATCI,如果电脑没有

mtk usb驱动,设备管理器是提示cdc serial,安装驱动成功后,端口里多出来了一个VCOM,然后运行Audio_Tuning_Tool(连接不上以

管理员身份运行)

24.合入音频参数

Audio_Tuning_Tool导出来的是一个压缩文件,解压后有许多xml文件。mtk默认音频参数放这个路径

device/mediatek/vendor/common/audio_param/,工程下有又有几个同名的文件device/mediatek/mt6xxx/audio_param/,那组

合起来的参数就是工程audio_param+device/mediatek/vendor/common/audio_param/。

我们合入的参数直接放工程路径就行,如device/mediatek/mt6761/audio_param/,因为工程里的参数优先。

可通过编译后的音频参数(/vendor/etc/audio_param)和要合入的音频参数做对比,确保合入无误。

25.调整i2c速率&&上下拉电阻

用dct工具打开dws文件(最终生成dts)进行编辑就行,但有些在dts里也配置了节点,导致配置失败。如TP的dts里默认有

&i2c0 {

clock-frequency = <400000>;

};

要改就要同时该,或者屏蔽dts里面的clock-frequency = <400000>;,到out目录的dts文件夹进行搜索,看有没有配置成功。如要配置

成100k,那编译出来的节点就应该是

&i2c0 {

clock-frequency = <100000>;

...

};

上拉电阻可以配置的,修改文件

vendor/mediatek/proprietary/bootable/bootloader/preloader/platform/mt6xxx/src/drivers/i2c.c

26. [FAQ22441] Porting Camera Sensor 的时候新增metadata与tuning files的方法

要先创建对应的文件夹,然后运行脚本

mkdir -p imx135_mipi_raw/AWB_Tuning_Para

mkdir -p imx135_mipi_raw/AE_Tuning_Para

from pathlib import Path

import re

cur_path = Path(r'/home/w/sp5508_mipi_raw')cur_path = Path(r'/home/w/sp5508_mipi_raw')in_text = 'sp5508'out_text = 'imx135'AllFiles = set()AllPaths = set()def find_one_level_subpaths(current_path): temp_paths = set() for tmp_p in current_r(): if tmp__dir(): temp_(tmp_p) return temp_pathsdef find_all_level_subpaths(current_path): all_sub_paths = set() new_sub_paths = set()

all_sub_paths = find_one_level_subpaths(current_path) all_sub_(current_path) new_sub_paths = all_sub_paths while(new_sub_paths != set()): tmp_new_sub_collection = set() for tmp_path in new_sub_paths: tmp_new_sub = find_one_level_subpaths(tmp_path) tmp_new_sub_collection = tmp_new_sub_collection | tmp_new_sub all_sub_paths = all_sub_paths | tmp_new_sub_collection new_sub_paths = tmp_new_sub_collection - new_sub_paths return all_sub_pathsdef find_one_level_file(current_path): temp_files = set() for tmp_f in current_r(): if tmp__file(): temp_(tmp_f) return temp_files

AllPaths = find_all_level_subpaths(cur_path)for tmp_p in AllPaths: tmp_f = find_one_level_file(tmp_p) AllFiles = AllFiles | tmp_frep_pattern = e(in_text, re.I)def repl(matchobj): if (0) == in_text: return out_text else: return out_()def repl_in_a_file(cur_file): tmp_file = [] r_file = open(cur_file,'r', encoding='UTF-8') for tmp_string in r_nes(): tmp_repl = rep_(repl, tmp_string) tmp_(tmp_repl) r_() w_file = open(cur_file,'w') for tmp_string in tmp_file: w_(tmp_string) w_()

for tmp_f in AllFiles:

if tmp_ != '.xlsx':

try:

repl_in_a_file(tmp_f)

except:

print(tmp_f)

for tmp_f in AllFiles:

new_file = rep_(repl, str(tmp_f))

tmp_(new_file)

按鍵

lk/target/k6xxx_yy_bsp/include/target/cust_key.h

默认是9*9按键

如果用0作为KEY_VOLUMEUP键,打开preloader/custom/k6xxx_yy_bsp/dct/dct/,有类似的表格

2 OK NC LEFT VOLUMEUP VOLUMEDOWN NC NC NC

7 POUND NC 4 CALL 1 NC NC NC

BACK 0 NC STAR 9 8 NC NC NC

5 RIGHT NC 6 3 NC NC NC NC

NC NC NC NC NC NC NC NC NC

NC NC NC NC NC NC NC NC NC

NC NC NC NC NC NC NC NC NC

NC NC NC NC NC NC NC NC NC

0改好对应19(从0开始 从左往右,从上往下)

28.闪光灯配置

双闪:由一颗低色温和一颗高色温组合而成

dts配置单闪还是双闪

参考Flashlight_Driver_Porting_

flashlights_mt6370: flashlights_mt6370 {

compatible = "mediatek,flashlights_mt6370";

decouple = <0>;

channel@1 {

type = <0>;

ct = <0>;

part = <0>;

};

channel@2 {

type = <0>;

ct = <1>;

part = <0>;

};

};

decouple:分离

0代表双闪

1代表单闪

同时注意下hal配置的是不是也是单闪

vendor/mediatek/proprietary/custom/mt676x/hal/flashlight/flash_

if(sensorDev == DUAL_CAMERA_MAIN_SENSOR || sensorDev == DUAL_CAMERA_MAIN_2_SENSOR)

return 1; // 双色温LED

else

return 0;

闪光灯要作校准(没校准拍出来的图片可能会偏色),校准可参考释放出来的最新文档和视频,如Flashlight_等

成功校准时,闪光灯会闪多下,大概耗时2min,将生成的文件(/data/vendor/flash)合入代码里(FAQ21724),涉及到的文件

vendor/mediatek/proprietary/custom/mt676x/hal/flashlight/flash_tuning_

vendor/mediatek/proprietary/custom/mt676x/hal/flashlight/flash_tuning_custom_

vendor/mediatek/proprietary/custom/mt676x/hal/imgsensor/xxx_mipi_raw/camera_flash_awb_para_xxxmipiraw.h

校准方法:

adb root

adb shell setprop _ratio 1

然后在特定的环境下,点击拍照(使用的平台进入校准的方法是点击屏幕)

29.T卡热插拔配置

1、未插卡中断Pin是高电平,插入卡中断Pin是低电平

cd_level = /bits/ 8 ;

2、未插卡中断Pin是低电平,插入卡中断Pin是高电平

cd_level = /bits/ 8

dws里的中断极性也要配置下

30.内核版本确认

源码根目录下一般有几套内核,可以根据里的LINUX_KERNEL_VERSION判定具体用哪个内核。

31.查看修改引脚状态