聲明:本資料來自公司同事整理提供
1 音頻的通路有兩種:
i. T卡-->內存-->DSP解碼-->PCM信號--> 模擬基帶(ABB)--> [外部功放]-->輸出
ii. FM/TV chip-->模擬基帶(ABB)--> [外部功放]-->輸出
注:由於耳機功率相對較小所以在驅動耳機時只需要ABB內部的一級放大即可,二在驅動speaker的時候需要較高的功率所以需要經過一級外部功放。另外耳機的立體聲是BB的兩路信號(MP3_OUTR&MP3_OUTL)直接差分輸出的而speaker只使用了其中的一路,另一路信號被捨棄。
由於音頻信號經過數字和模擬兩個階段,所以對信號的放大可以分爲數字增益和模擬增益。其中模擬增益依靠硬件電路完成,範圍內線性度好不容易失真;而數字增益則是通過軟件完成,該方式線性度差容易出現失真等問題。在Afe2.c文件中有函數
void AFE_SetLevelVolume(kal_uint8 aud_func, kal_uint8 MaxAnalogGain, kal_uint8 step, kal_uint8 level)是通過改變模擬增益改變輸出音量大小的函數。其原理是更改ABB中可編程放大器的放大倍數來改變聲音的大小。而函數
void AFE_SetOutputVolume( kal_uint8 aud_func, kal_uint8 volume1, kal_int8 digital_gain_index )則是通過調整數字增益來改變音量的。
Pcm編解碼電路的任務是數字信號與模擬信號的轉換
Pcm緩衝區的數據處理:在event_callback裏收到MEDIA_DATA_REQUEST後按如下流程處理。
a.PCM_Strm_Open;
b. 調用setBuffer;
c. 填數據; GetWriteBuffer
d. 調用WriteDataDone;
e. 調用FinishWriteData;
f. 播放play(mdi_audio_play_string_with_vol_path)
2.音頻對應的驅動主要有以下文件:
Afe2.c------AFE_GetOutputVolume(),AFE_SetLevelVolume(),
Afe_turnonextamplifier(),afe_turnonextamplfier();
Afe.c------afe_switchextamplifier(char sw_on)等
audcoeff.c:此文件要注意outputchanal的配置,配置錯誤將沒有聲音出現
const unsigned char L1SP_MICROPHONE1 = L1SP_LNA_0;
const unsigned char L1SP_MICROPHONE2 = L1SP_LNA_1;
const unsigned char L1SP_SPEAKER1 = L1SP_BUFFER_0;
const unsigned char L1SP_SPEAKER2 = L1SP_BUFFER_ST;
const unsigned char L1SP_LOUD_SPEAKER = L1SP_BUFFER_ST_M|L1SP_BUFFER_EXT;;
audcoeff_default.h: 定義語音增強參數;
gpio_drv.c: 設置模式以及方向
nvram_default_audio.c: 配置各音階的音量,每個參數裏有“音量0~音量6”7個音量等級和16 Level Setting模擬增益調節
GAIN_NOR_CTN_VOL //call wait tone
GAIN_NOR_KEY_VOL //keypad volume;
GAIN_NOR_MIC_VOL //microphone input
GAIN_NOR_GMI_VOL // fm radio sound
GAIN_NOR_SPH_VOL // speech sound
GAIN_NOR_SID_VOL //side tone
GAIN_NOR_MED_VOL //music
在l1audio.h中有如下定義。
#define L1SP_KEYTONE 0 // 按鍵音。
#define L1SP_TONE 1 // 單音和絃。
#define L1SP_SPEECH 2 // 語音。
#define L1SP_SND_EFFECT 3 // 聲效。
#define L1SP_AUDIO 4 // MP3等
#define L1SP_VOICE 5 // 錄音
#define L1SP_DAI 6 // 數字聲音
#define L1SP_FM_RADIO 7 // FM聲音。
手機裏的音頻參數有如下內容
FIR = Finite filter, IIR= Infinite filter, 調整響應曲線
ES = Echo suppression, 抑制迴音
AEC = Acoustic echo canceller, 消除迴音
AGC = Automatic gain control, 自動增益補償
NS = Noise suppression, 背景噪音抑制
3.音頻格式:
MP3
MP3的全稱是Moving Picture Experts Group Audio Layer III。簡單的說,MP3就是一種音頻壓縮技術,由於這種壓縮方式的全稱叫MPEG Audio Layer3,所以人們把它簡稱爲MP3。MP3是利用 MPEG Audio Layer 3 的技術,將音樂以1:10 甚至 1:12 的壓縮率,壓縮成容量較小的file,換句話說,能夠在音質丟失很小的情況下把文件壓縮到更小的程度。而且還非常好的保持了原來的音質。正是因爲MP3體積小,音質高的特點使得MP3格式幾乎成爲網上音樂的代名詞。每分鐘音樂的MP3格式只有1MB左右大小,這樣每首歌的大小隻有3-4兆字節。使用MP3播放器對MP3文件進行實時的解壓縮(解碼),這樣,高品質的MP3音樂就播放出來了。
WMA
WMA (Windows MediaAudio)格式是來自於微軟的重量級選手,後臺強硬,音質要強於MP3格式,更遠勝於RA格式,
RealAudio
RealAudio主要適用於在網絡上的在線音樂欣賞,這些格式的特點是可以隨網絡帶寬的不同而改變聲音的質量,在保證大多數人聽到流暢聲音的前提下,令帶寬較富裕的聽衆獲得較好的音質。
MIDI
MIDI(Musical InstrumentDigitalInterface)
MID文件並不是一段錄製好的聲音,而是記錄聲音的信息,然後在告訴聲卡如何再現音樂的一組指令。
CD
*.cda格式,就是CD音軌。標準CD格式也就是44.1K的採樣頻率,速率88K/秒,16位量化位數,因爲CD音軌可以說是近似無損的,因此它的聲音基本上是忠於原聲的,因此如果你如果是一個音響發燒友的話,CD是你的首選。
4.“POP”噪聲是指音頻器件在上電、斷電瞬間以及上電穩定後,各種操作帶來的瞬態衝擊所產生的爆破聲。產生“POP”噪聲的瞬態衝擊通常是一種很窄的尖脈衝......
如何消除pop音:
開始播放時的pop音:先輸出音頻,延遲一段時間後,再打開音頻功放
這種方式只是利用軟件掩飾的指標方法,真正的消除應從硬件着手:比如減小輸出端的偶合電容,改用橋式電路等;
5.音頻放大器
音頻放大器分爲A類、B類和AB類和D類以及k類放大器,一般情況下用D類放大器,因爲效率高,體積小。
設計的時候一般音頻輸入輸出採用差分方式,雙聲道給耳機,偏置一路給功放。
BMT充電介紹:
1.電池充電相關文件:bmt.c chr_parameter.c
2.充電有三個過程:預充電、恆流充電、恆壓充電
1) 當Vbat<3.3V 屬於預充階段,在這個階段充電跟電池還有多少電壓沒有關係,即使電池電壓爲0V也應該可以衝進電(一般正規廠商電池內部有保護電路,當放電到兩點幾伏時已經截止,不能放出電了),只要電池本身沒問題!關鍵是確保BATDET腳是否處於低電平!手機充電是沒有任何反應的。
2) 當電池電壓低於3.3V時,PMIC(電源管理芯片)不能提供Vcore、Vdd等電壓,CPU處於關機狀態,這時CPU是不工作的!手機是沒有任何反應的,在這個模式只要BATDET腳通過下拉電阻置低,即可進行預充!
充電電流Ipre=10mV/Rsense 現在MTK平臺Rsense=0.33R, 可知Ipre=30mA
2). 當3.3V<bat<4.2V PMIC的LDO開始輸出電壓,從而cpu開始工作,這是進入恆流充電階段充電電流Icc=160mV/Rsense ,現在MTK平臺Rsense=0.33R,可知Icc=480mA
3). Vbat>4.2V 進入恆壓充電階段,這個階段電流逐漸變小,電壓維持不變!當電流減小到接近爲0時,CPU發出控制信號這時停止充電!
以下爲充電狀態圖:
3.當充電器插入時,亦即爲PMIC充電模塊提供了Vcharge電壓,只要把PMIC的BATDET腳接地即可啓動充電模塊,這時會產生一個充電中斷信號到CPU,通知CPU現在已經進入充電狀態。這時PMIC會產生一箇中斷給CPU,CPU開始啓動如下模塊:
一、ADC採樣,主要是採集Vchrg,Vbat及從MOSFET漏極輸出的電壓。
二、發消息給MMI層,讓它顯示充電狀態及一些採樣數據
三、檢測電池電壓有沒有超過保護電壓及電池連接是否連接正確,如果有問題即可通過CHRCTRL(GPI031)切斷充電電路!
四、平時顯示“充電器沒有連接”警告,是因爲PMIC的BATDET腳float(懸空),MOSFET沒有打開,從而沒有充電電流引起的
PMIC 會通過電池BAT ID腳來判斷要不要給電池充電,並不是用來區分是鋰電還是鎳氫電池!區別鋰電還是鎳氫電池是通過PMIC的BATUSE腳,低電平是選擇鋰電!我們目前使用的電池ID電阻是10k左右,只要電池三個腳都接到電池connector上,就可以通過電池ID電阻把BATDET腳接地,充電也就開始了(包括預充電)!插充電器後,只要把PMIC的BATDET腳接地,就可以保證有電流流入了,電池的電壓隻影響充電狀態(比如是預充還是恆流充電),如果電池電壓較低,只是預充的時間稍長一些,最多一兩個小時應該可以完成預充電,進入恆流充電狀態!
一般電池都有自保護,一塊合格的電池不應該會出現是0V的情況!
附:
1.當電池電壓過低時,即進入鎖定狀態,用萬用表測得電池兩端的電壓爲0V!手機在低電壓鎖定後不能充電跟手機的充電電路沒有關係!
2.電池保護IC主要有過沖保護、過放保護、大電流保護等功能。
3.鋰電池不能把電全部放完,必須加保護IC,如果電池電壓放電低於2V,就不能充進電了!
4.電池被鎖定後,需要激活電壓把電池喚醒。
5.電池在低壓時充不進去電,與電池廠家選用的保護IC有關!
在Chr_parmeter.c文件中有如下數據結構,其中定義了有關電池和充電部分的全部典型值。
bmt_customized_struct bmt_custom_chr_def =
{
#ifndef __CUST_NEW__
31,/*GPIO_CHRCTRL*/
14,/*GPIO_BATDET*/
7,/*GPIO_VIBRATOR*/
#endif /*__CUST_NEW__*/
/*charing parameters*/
/*Check Phy parameters,Maybe changed*/
1100000,/*Typical_LI_BATTYPE*/ 鋰電池典型值(容量)
1100000,/*Typical_NI_BATTYPE*/ 鎳氫電池典型值(容量)
1000000,/*ICHARGE_ON_HIGH*/ 最大充電電流
0,/*ICHARGE_ON_LOW*/ 最小充電電流
1000000,/*ICHARGE_OFF_HIGH*/ //??50000
4050000,/*V_FAST2TOPOFF_THRES*/
2500000,/*BATTMP_MINUS_40C*/
1469409,/*BATTMP_0C*/
520042,/*BATTMP_45C*/
6000000,/*MAX_VBAT_LI*/
鋰電池最大VBAT值
5500000,/*MAX_VBAT_NI*/
鎳氫電池最大VBAT值
3400000,/*V_PRE2FAST_THRES*/
250000,/*I_TOPOFF2FAST_THRES*/ /*250ma,TOPOFF->FAST*/
快速充電關閉電流
120000,/*I_TOPOFF2FULL_THRES*/ /*120ma,TOPOFF->BATFULL*/
正常充電關閉電流
4110000,/*V_FULL2FAST_THRES*/ /*BATFULL->FAST*/
414557,/*V_TEMP_FAST2FULL_THRES_NI*/ /*50oC,FAST->BATFULL*/
4050000,/*V_FULL2FAST_THRES_NI*/
600000,/*FAST_ICHARGE_HIGHLEVEL*/ /*600ma,for table search*/
快速充電最高限制電流
400000,/*FAST_ICHARGE_LOWLEVEL*/ /*400ma,for table search*/
快速充電最低限制電流
4050000,/*V_PROTECT_HIGH_LI*/
3800000,/*V_PROTECT_LOW_LI*/
#if defined(__RGT_DRV_M100__) //M100 support Nokia charger
7000000, 諾基亞充電器電壓 7v
#else
6500000,/*VCHARGER_HIGH*/ 普通充電器電壓爲6.5v
#endif
0,/*VCHARGER_LOW*/
/*Time delay*/
/* PRE CHARGE ,search table*/
/*TON = 3s,TOFF=2s*/
3,/*PRE_TON*/
2,/*PRE_TOFF*/
/* FAST CHARGE ,search table*/
/*TON = 3s,TOFF=0s*/
3,/*TOPOFF_TON*/
0,/*TOPOFF_TOFF*/
6,/*BATFULL_TON_LI*/ /*unit : second*/
0,/*BATFULL_TOFF_LI*/
1,/*BATFULL_TON_NI*/ /*unit : second*/
9,/*BATFULL_TOFF_NI*/
6,/*BATFULL_TOFF*/
10,/*BATHOLD_OFF*/
5,/*ADC_ISENSE_RESISTANCE_FACTOR*/ /*1/0.2*/
24, /*bmt_measure_discard_time*/ /*24 ticks*/
//ADC_CALIDATA adc_cali_param
以下爲手機電壓檢測部分的ADC校準值
{
{
5524,
5524,
5524,
5524,
5524,
5524
},
{
(23286),
(23286),
(23286),
(23286),
(23286),
(23286)
}
},
/*ratio = adc_volt_factor/100*/
//const kal_uint16 adc_volt_factor[ADC_MAX_CHANNEL]
{
50,
50,
50,
100,
50,
50
},
//const kal_uint8 TONOFFTABLE[6][2] =
{
{7,1},
{8,1},
{9,1},
{7,1},/*talk */
{8,1},/*talk */
{9,1}/*talk */
},
//const kal_int32 CurrOffset[3] =
{
100000, //100ma
100000,
100000
},
KAL_FALSE, /* enable checking temperature while charging */
#if defined(__MT6253_PLATFORM_SUPPORT__)
KAL_TRUE /* enable checking charging voltage while charging */
#else
KAL_FALSE /* enable checking charging voltage while charging */
#endif
};
Pmic_custom.c文件中宏
#define AC_CHR_CURRENT CHR_CURRENT_650
#define USB_CHR_CURRENT CHR_CURRENT_450
分別是對交流充電器和USB充電時的電流限制分別爲650ma和450ma
Bmt_main.c是關於電池和充電器的驅動文件。
在文件Auxmain.c文件AUX_task_main函數中
case MSG_ID_READ_ALL_ADC_CHANNEL_REQ:
adc_measure_count=0;
vbat_value = 0;
aux_read_adc_channel(vbat_adc_logic_id);
visense_value = 0;
aux_read_adc_channel(visense_adc_logic_id);
vcharger_value = 0;
aux_read_adc_channel(vcharger_adc_logic_id);
vbattemp_value = 0;
aux_read_adc_channel(vbattemp_adc_logic_id);
vaux_value = 0;
aux_read_adc_channel(vaux_adc_logic_id);
break;
部分是開機後進入工程模式下讀取電源相關ADC值部分代碼