日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

EFM32G232F64时钟树

發布時間:2023/12/8 编程问答 62 豆豆
生活随笔 收集整理的這篇文章主要介紹了 EFM32G232F64时钟树 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.為了熟悉MCU的時鐘樹,先看看EFM32G232F64的CMU(ClockManagementUnit)

時鐘管理單元(CMU)用于管控晶振(時鐘源)和各個時鐘節點。出于降低功耗和啟動時間的目的,EFM32G的時鐘源支持數個不同規格的晶振。另外還有一個獨立的RC振蕩器用于燒寫Flash和調試。當然,時鐘管理單元也從硬件級別上支持RC振蕩器的校準。

晶振和系統時鐘樹,對于降低MCU的系統功耗有巨大意義。有了低功耗的晶振再結合彈性的時鐘控制策略,就可以在各種應用場合下降低功耗。不使用的外設就關掉它的時鐘源以節能。

時鐘管理單元,能夠配置選擇不同的時鐘源,使能和失能單個時鐘分支和所有外設的時鐘源,還能為不同的時鐘分支設置預分頻系數。短的晶振啟動時間使得從非低功耗模式(active)到低功耗模式(EM2~EM4)的占空比變得非常高效。RC震蕩校準特性保證了其高精度的RC震蕩頻率。

  CMU_ClockSelectSet(cmuClock_LFB, cmuSelect_LFXO);  //使能時鐘分支
  CMU_ClockEnable(cmuClock_LEUART0, true);  //使能某個外設的時鐘

1.1邏輯圖

1.2 實際圖

2.

從公司的硬件工程師那里得知,項目的PCB原理圖上只外接了32.768KHz的低速晶振到15和16腳,那個13.56MHz的晶振不是給EFM32G232F64用的,而是給射頻芯片THM3070射頻芯片用的。所以,可以推測,EFM32G還是用了內部自帶的高速時鐘源。

2.1 從代碼里找時鐘樹的配置細節

找時鐘樹配置是從公司的某個項目代碼中找的。參考了以下博文,沒有明顯發現,但是博文還是值得一看。

2.2 CMU外設庫函數 -?CMU_ClockSelectSet

void CMU_ClockSelectSet(CMU_Clock_TypeDef clock, CMU_Select_TypeDef ref)中,clock是時鐘分支,ref是外界的時鐘輸入源。
《EMF32G-RM》page97上說,默認HFCLK分支的時鐘來源選擇HFRCO,但是在多數應用時,推薦使用高頻晶振,可以修改 HFCLKSEL in CMU_CMD(寄存器)去配置HFCLK的時鐘源。
也就是說,在為各個時鐘分支選好時鐘源之后,剩下的就是配置各個時鐘分支的分頻系數了。這里沒有發現PLL。選擇時鐘源使用函數CMU_ClockSelectSet。
補充:
周立功的資料上說,默認所有的外設時鐘都是關閉的。
2. 常見問題解答
2.1 EFM32 系列MCU
1. 當我向某個控制寄存器寫入數據然后讀此寄存器,發現全部是 0,不知是什么原
因?
A:默認情況下, EFM32 系列 MCU 內部外設的時鐘都是關閉的。如果要設置某個外設
的 寄 存 器 , 必 須 先 通 過 CMU_HFPERCLKEN0 HFCORECLKEN0 、 LFACLKEN
LFBCLKEN 來使能相關外設的時鐘。若使用低頻外設,還需在 CMU_HFCORECLKEN0
存器中使能 LE 時鐘。

附錄

[轉發]在main()之前,IAR都做了啥?

【原文鏈接】http://www.cnblogs.com/mssql/archive/2011/01/29/tt146.html

最近要在Cortex-M3上寫一個簡單的操作系統,打算使用IAR,為了寫好啟動代碼,花了一些時間了解了IAR在main()以前做了些什么事。

首先系統復位時,Cortex-M3從代碼區偏移0x0000'0000處獲取棧頂地址,用來初始化MSP寄存器的值。

接下來從代碼區偏移0x0000'0004獲取第一個指令的跳轉地址。這些地址,是CM3要求放置中斷向量表的地方。

這里是一個程序的啟動區的反匯編:

__vector_table:
? 08004000??2600??????

? 08004002??2000??????

? 08004004??7E1D??????

? 08004006??0800?????

這個程序是由IAP程序來啟動的,IAP程序獲取0x0800'4000處的MSP值(0x20002600),并設置為MSP的值,即主堆棧最大范圍是0x2000'0000~0x2000'25FF。接下來IAP程序獲取0x0800'4004處的Reset_Handler的地址(0x0800'7E1D),并跳轉到Reset_Handler()執行。

IAP在這里完全是模仿了Cortex-M3的復位序列,也就是說,在沒有IAP的系統上,CM3只能從0x0800'0000獲取MSP,從0x0800'0004獲取第一條指令所處地址。而IAP就存在在0x0800'0000這個地址上,IAP的啟動,已經消耗掉了這個復位序列,所以IAP要啟動UserApp程序的時候,也是完全模仿Cortex-M3的復位序列的。

接下來我們看看復位后第一句指令——Reset_Handler()函數里有什么。

若我們使用的是ST公司標準外設庫,那么已經有了現成的Reset_Handler,不過他是弱定義——PUBWEAK,可以被我們重寫的同名函數覆蓋。一般來說,我們使用的都是ST提供的Reset_Handler,在V3.4版本的庫中,可以在startup_stm32f10x_xx.s中找到這個函數:

??????? PUBWEAK Reset_Handler
??????? SECTION .text:CODE:REORDER(2)
Reset_Handler
??????? LDR???? R0, =SystemInit
??????? BLX???? R0
??????? LDR???? R0, =__iar_program_start
??????? BX????? R0

看來ST沒有做太多的事,他只調用了自家庫提供的SystemInit函數進行系統時鐘、Flash讀取的初始化,并把大權交給了__iar_program_start這個IAR提供的“內部函數”了,我們就跟緊這個__iar_program_start跳轉,看看IAR做了什么,上面一段代碼的反匯編如下:

???????Reset_Handler:
__iar_section$$root:
? 08007E1C? 4801????? LDR????????? R0, [PC, #0x4]; LDR???? R0, =SystemInit
??08007E1E? 4780????? BLX????????? R0;BLX???? R0
??08007E20? 4801??????LDR????????? R0, [PC, #0x4];LDR???? R0, =__iar_program_start
??08007E22? 4700????? BX?????????? R0;BX????? R0
? 08007E24? 6C69??????

? 08007E26? 0800??????

? 08007E28? 7D8D??????

? 08007E2A? 0800?????

細心的觀眾會發現地址是0x0800'7E1C,比我們查到的0x0800'7E1D差了1,這是ARM家族的遺留問題,因為ARM處理器的指令至少是半字對齊的(16位THUMB指令集 or 32位ARM指令集),所以PC指針的LSB是常為0的,為了充分利用寄存器,ARM公司給PC的LSB了一個重要的使命,那就是在執行分支跳轉時,PC的LSB=1,表示使用THUMB模式,LSB=0,表示使用ARM模式,但在最新的Cortex-M3內核上,只使用了THUMB-2指令集挑大梁,所以這一位要常保持1,所以我們查到的地址是0x0800'7E1D(C=1100,D=1101),放心,我們的CM3內核會忽略掉LSB(除非為0,那么會引起一個fault),從而正確跳轉到0x0800'7E1C。

從0x0800'7E20處的加載指令,我們可以算出__iar_program_start所處的位置,就是當前PC指針(0x0800'7E24),再加上4,即0x0800'7E28處的所指向的地址——0x0800'7D8D(0x0800'7D8C),我們跟緊著跳轉,__iar_program_start果然在這里:

__iar_program_start:
? 08007D8C? F000F88C? BL???????????__low_level_init
? 08007D90? 2800????? CMP????????? R0, #0x0
? 08007D92? D001????? BEQ??????????__iar_init$$done
? 08007D94? F7FFFFDE? BL???????????__iar_data_init2

? 08007D98? 2000????? MOVS???????? R0, #0x0
? 08007D9A? F7FDFC49? BL???????????main

我們看到IAR提供了__low_level_init這個函數進行了“底層”的初始化,進一步跟蹤,我們可以查到__low_level_init這個函數做了些什么,不是不是我們想象中的不可告人。

__low_level_init:
? 08007EA8? 2001????? MOVS???????? R0, #0x1
? 08007EAA? 4770????? BX?????????? LR

__low_level_init出乎想象的簡單,只是往R0寄存器寫入了1,就立即執行"BX LR"回到調用處了,接下來,__iar_program_start檢查了R0是否為0,為0,則執行__iar_init$$done,若不是0,就執行__iar_data_init2。__iar_init$$done這個函數很簡單,只有2句話,第一句是把R0清零,第二句就直接"BL main",跳轉到main()函數了。不過既然__low_level_init已經往R0寫入了1,那么我們還是得走下遠路——看看__iar_data_init2做了些什么,雖然距離main只有一步之遙,不過這中間隱藏了編譯器的思想,我們得耐心看下去。

__iar_data_init2:
? 08007D54? B510????? PUSH???????? {R4,LR}
? 08007D56? 4804????? LDR????????? R0, [PC, #0x10]
? 08007D58? 4C04????? LDR????????? R4, [PC, #0x10]
? 08007D5A? E002????? B??????????? 0x8007D62
? 08007D5C? F8501B04? LDR????????? R1, [R0], #0x4
? 08007D60? 4788????? BLX????????? R1
? 08007D62? 42A0????? CMP????????? R0, R4
? 08007D64? D1FA????? BNE????????? 0x8007D5C
? 08007D66? BD10????? POP????????? {R4,PC}
? 08007D68? 7C78??????

? 08007D6A? 0800??????

? 08007D6C? 7C9C?????

? 08007D6E? 0800?????

看來IAR遲遲不執行main()函數,就是為了執行__iar_data_init2,我們來分析分析IAR都干了些什么壞事~

首先壓R4,LR入棧,然后加載0x0800'7C78至R0,0x0800'7C9C至R4,馬上跳轉到0x0800'7D62執行R0,R4的比較,結果若是相等,則彈出R4,PC,然后立即進入main()。不過IAR請君入甕是自不會那么快放我們出來的——結果不相等,跳轉到0x0800'7D5C執行,在這里,把R0指向的地址——0x0800'7C78中的值——0x0800'7D71加載到R1,并且R0中的值自加4,更新為0x0800'7C7C,并跳轉到R1指向的地址處執行,這里是另一個IAR函數:__iar_zero_init2:

__iar_zero_init2:
? 08007D70? 2300????? MOVS???????? R3, #0x0
? 08007D72? E005????? B??????????? 0x8007D80
? 08007D74? F8501B04? LDR????????? R1, [R0], #0x4
? 08007D78? F8413B04? STR????????? R3, [R1], #0x4
? 08007D7C? 1F12????? SUBS???????? R2, R2, #0x4
? 08007D7E? D1FB????? BNE????????? 0x8007D78
? 08007D80? F8502B04? LDR????????? R2, [R0], #0x4
? 08007D84? 2A00????? CMP????????? R2, #0x0
? 08007D86? D1F5????? BNE????????? 0x8007D74
? 08007D88? 4770????? BX?????????? LR
? 08007D8A? 0000????? MOVS???????? R0, R0

__iar_data_init2還沒執行完畢,就跳轉到了這個__iar_zero_inti2,且看我們慢慢分析這個幫兇——__iar_zero_inti2做了什么。

__iar_zero_inti2將R3寄存器清零,立即跳轉到0x0800'7D80執行'LDR????????? R2, [R0], #0x4',這句指令與剛才在__iar_data_init2見到的'LDR????????? R1, [R0], #0x4'很類似,都為“后索引”。這回,將R0指向的地址——0x0800'7C7C中的值——0x0000'02F4加載到R2寄存器,然后R0中的值自加4,更新為0x0800'7C80。接下來的指令檢查了R2是否為0,顯然這個函數沒那么簡單想放我我們,R2的值為2F4,我們又被帶到了0x0800'7D74處,隨后4條指令做了如下的事情:

1、將R0指向的地址——0x0800'7C80中的值——0x2000'27D4加載到R1寄存器,然后R0中的值自加4,更新為0x0800'7C84。

2、將R1指向的地址——0x2000'27D4中的值——改寫為R3寄存器的值——0,然后R1中的值自加4,更新為0x2000'27D8。

3、R2自減4

4、檢查R2是否為0,不為0,跳轉到第二條執行。不為,則執行下一條。

這簡直就是一個循環!——C語言的循環for(r2=0x2F4;r2-=4;r!=0){...},我們看看循環中做了什么。

第一條指令把一個地址加載到了R1——0x2000'27D4?是一個RAM地址,以這個為起點,在循環中,對長度為2F4的RAM空間進行了清零的操作。那為什么IAR要做這個事情呢?消除什么記錄么?用Jlink查看這片內存區域,可以發現這片區域是我們定義的全局變量的所在地。也就是說,IAR在每次系統復位后,都會自動將我們定義的全局變量清零0。

清零完畢后,接下來的指令"LDR????????? R2, [R0], #0x4"將R0指向的地址——0x0800'7C84中的值——0加載到R2寄存器,然后R0中的值自加4,更新為0x0800'7C88。隨后檢查R2是否為0,這里R2為0,執行'BX LR'返回到__iar_data_init2函數,若是不為0,我們可以發現又會跳轉至“4指令”處進行一個循環清零的操作。

讀到這里,我們應該可以猜到IAR的意圖了:__iar_data_init2一開始加載了0x0800'7C78至R0,0x0800'7C9C至R4,[R0,R4]就是一段啟動代碼區,在這個區域內保存了要“處理”的所有地址與信息——執行的函數地址或者參數,實際上,這片區域也有一個名字,叫做:Region$$Table$$Base。在這個區域內,程序以R0為索引,R4為上限,當R0=R4,__iar_data_init2執行完畢,跳轉至main()函數。

好了,保持我們這個猜想,繼續跟蹤我們的PC指針——我們回到了__iar_data_init2函數中,第一件事就是比較R0,R4的值,可惜的是,仍然不相等,我們又被帶到了0x0800'7D5C,至此,我們應該能看出這是一個__iar_data_init2的“主循環”,這也驗證了我們對IAR意圖的猜想~

??__iar_data_init2中的“主循環”:

? 08007D5C? F8501B04? LDR????????? R1, [R0], #0x4
? 08007D60? 4788????? BLX????????? R1
? 08007D62? 42A0????? CMP????????? R0, R4

我們可以等價寫為:for(r0=0x0800'7C78,r4=0x0800'7C9C;r0!=r4;r0+=4){...}

此時,我們的R0為0x0800'7C88,經過“指令1”,R0變為0x0800'7C8C,R1為0x0800'7C55。我們來看看,7C55處,IAR又要執行何種操作。

__iar_copy_init2:
? 08007C54? B418????? PUSH???????? {R3,R4}
? 08007C56? E009????? B??????????? 0x8007C6C
? 08007C58? F8501B04? LDR????????? R1, [R0], #0x4
? 08007C5C? F8502B04? LDR????????? R2, [R0], #0x4
? 08007C60? F8514B04? LDR????????? R4, [R1], #0x4
? 08007C64? F8424B04? STR????????? R4, [R2], #0x4
? 08007C68? 1F1B????? SUBS???????? R3, R3, #0x4
? 08007C6A? D1F9????? BNE????????? 0x8007C60
? 08007C6C? F8503B04? LDR????????? R3, [R0], #0x4
? 08007C70? 2B00????? CMP????????? R3, #0x0
? 08007C72? D1F1????? BNE????????? 0x8007C58
? 08007C74? BC12????? POP????????? {R1,R4}
? 08007C76? 4770????? BX?????????? LR

這是一個名為__iar_copy_init2的函數,他執行了什么"copy"操作呢?

首先壓R3,R4入棧,然后跳轉到0x0800'7C6C,從R0——Region$$Table$$Base中取出參數0x238放入R3,接下來的指令大家應該都熟悉了,0x238不為0,所以我們被帶至7C58處,再次從Region$$Table$$Base中取出參數0x0800'7F14放入R1,從Region$$Table$$Base取出參數0x2000'2AC8放入R2處。細心的觀眾應該能察覺這和__iar_zero_init2中取參數的幾乎一樣:先取出大小,隨后取出了地址——只不過這里多出了1個地址,沒錯這就是"copy",隨后的指令

? 08007C60? F8514B04? LDR????????? R4, [R1], #0x4
? 08007C64? F8424B04? STR????????? R4, [R2], #0x4
? 08007C68? 1F1B????? SUBS???????? R3, R3, #0x4
? 08007C6A? D1F9????? BNE????????? 0x8007C60
則是另一個“4指令”,指令1將R1指向地址的數據讀到R4,指令2將R2指向地址的數據改寫為R4的數據,指令3、4是完成一個循環。

說到這里大家都應該明白了——這就是一個"copy"的操作,從Flash地址0x0800'7F14起,將長度0x238的數據拷貝到RAM地址0x2000'2AC8中。

通過Jlink,我們可以看到這片區域是我們定義的并且已初始化的全局變量。也就是說,每次復位后,IAR在此處進行全局變量的初始化。

在這“4指令”執行完畢后,再次從Region$$Table$$Base中取出參數,為0,比較之后條件符合,函數返回__iar_data_init2。

此時的R0已經為0x0800'7C9C與R4相等,__iar_data_init2終于完成它的使命。

? 08007D98? 2000????? MOVS???????? R0, #0x0
? 08007D9A? F7FDFC49? BL???????????main

將R0清零以后,IAR放棄主動權,把PC指針交給了用戶程序的入口——main()。

但請注意,這里使用的是BL指令進行main跳轉,也就是說,main函數只是IAR手中的一個子程序,若是main函數執行到了結尾,接下來則會執行exit等IAR提供的“退出”函數。這些函數,等待下回分解~

總之,IAR在啟動main()函數以前,執行了Reset_Handler,調用SystemInit()(ST庫提供)進行時鐘,Flash讀取初始化,并轉入__iar_program_start中執行__low_level_init與__iar_data_init2,并在__iar_data_init2中,先后調用__iar_zero_init2與__iar_copy_init2對全局變量、全局已初始化變量進行相應的初始化操作。最后,調用main()函數執行。

這就是IAR在啟動main()函數之前做的事情,它并沒有那么神秘,只要花些時間,就可以跟跟蹤分析出這個過程。

? /***************************************************************************//*** @brief* Select reference clock/oscillator used for a clock branch.** @details* Notice that if a selected reference is not enabled prior to selecting its* use, it will be enabled, and this function will wait for the selected* oscillator to be stable. It will however NOT be disabled if another* reference clock is selected later.** This feature is particularly important if selecting a new reference* clock for the clock branch clocking the core, otherwise the system* may halt.** @param[in] clock* Clock branch to select reference clock for. One of:* @li #cmuClock_HF* @li #cmuClock_LFA* @li #cmuClock_LFB @if _CMU_LFCLKSEL_LFAE_ULFRCO* @li #cmuClock_LFC* @endif @if _SILICON_LABS_32B_PLATFORM_2* @li #cmuClock_LFE* @endif* @li #cmuClock_DBG @if DOXYDOC_USB_PRESENT* @li #cmuClock_USBC* @endif** @param[in] ref* Reference selected for clocking, please refer to reference manual for* for details on which reference is available for a specific clock branch.* @li #cmuSelect_HFRCO* @li #cmuSelect_LFRCO* @li #cmuSelect_HFXO* @li #cmuSelect_LFXO* @li #cmuSelect_HFCLKLE* @li #cmuSelect_AUXHFRCO* @li #cmuSelect_HFCLK @ifnot DOXYDOC_EFM32_GECKO_FAMILY* @li #cmuSelect_ULFRCO* @endif******************************************************************************/ void CMU_ClockSelectSet(CMU_Clock_TypeDef clock, CMU_Select_TypeDef ref) {uint32_t select = cmuOsc_HFRCO;CMU_Osc_TypeDef osc = cmuOsc_HFRCO;uint32_t freq;uint32_t tmp;uint32_t selRegId; #if defined( _SILICON_LABS_32B_PLATFORM_2 )volatile uint32_t *selReg = NULL; #endif #if defined( CMU_LFCLKSEL_LFAE_ULFRCO )uint32_t lfExtended = 0; #endifselRegId = (clock >> CMU_SEL_REG_POS) & CMU_SEL_REG_MASK;switch (selRegId){case CMU_HFCLKSEL_REG:switch (ref){case cmuSelect_LFXO: #if defined( _SILICON_LABS_32B_PLATFORM_2 )select = CMU_HFCLKSEL_HF_LFXO; #elif defined( _SILICON_LABS_32B_PLATFORM_1 )select = CMU_CMD_HFCLKSEL_LFXO; #endifosc = cmuOsc_LFXO;break;case cmuSelect_LFRCO: #if defined( _SILICON_LABS_32B_PLATFORM_2 )select = CMU_HFCLKSEL_HF_LFRCO; #elif defined( _SILICON_LABS_32B_PLATFORM_1 )select = CMU_CMD_HFCLKSEL_LFRCO; #endifosc = cmuOsc_LFRCO;break;case cmuSelect_HFXO: #if defined( CMU_HFCLKSEL_HF_HFXO )select = CMU_HFCLKSEL_HF_HFXO; #elif defined( CMU_CMD_HFCLKSEL_HFXO )select = CMU_CMD_HFCLKSEL_HFXO; #endifosc = cmuOsc_HFXO; #if defined( CMU_MAX_FREQ_HFLE )/* Set 1 HFLE wait-state until the new HFCLKLE frequency is known.This is known after 'select' is written below. */setHfLeConfig(CMU_MAX_FREQ_HFLE + 1, CMU_MAX_FREQ_HFLE); #endif #if defined( CMU_CTRL_HFXOBUFCUR_BOOSTABOVE32MHZ )/* Adjust HFXO buffer current for frequencies above 32MHz */if (SystemHFXOClockGet() > 32000000){CMU->CTRL = (CMU->CTRL & ~_CMU_CTRL_HFXOBUFCUR_MASK)| CMU_CTRL_HFXOBUFCUR_BOOSTABOVE32MHZ;}else{CMU->CTRL = (CMU->CTRL & ~_CMU_CTRL_HFXOBUFCUR_MASK)| CMU_CTRL_HFXOBUFCUR_BOOSTUPTO32MHZ;} #endifbreak;case cmuSelect_HFRCO: #if defined( _SILICON_LABS_32B_PLATFORM_2 )select = CMU_HFCLKSEL_HF_HFRCO; #elif defined( _SILICON_LABS_32B_PLATFORM_1 )select = CMU_CMD_HFCLKSEL_HFRCO; #endifosc = cmuOsc_HFRCO; #if defined( CMU_MAX_FREQ_HFLE )/* Set 1 HFLE wait-state until the new HFCLKLE frequency is known.This is known after 'select' is written below. */setHfLeConfig(CMU_MAX_FREQ_HFLE + 1, CMU_MAX_FREQ_HFLE); #endifbreak;#if defined( CMU_CMD_HFCLKSEL_USHFRCODIV2 )case cmuSelect_USHFRCODIV2:select = CMU_CMD_HFCLKSEL_USHFRCODIV2;osc = cmuOsc_USHFRCO;break; #endif#if defined( CMU_LFCLKSEL_LFAE_ULFRCO ) || defined( CMU_LFACLKSEL_LFA_ULFRCO )case cmuSelect_ULFRCO:/* ULFRCO cannot be used as HFCLK */EFM_ASSERT(0);return; #endifdefault:EFM_ASSERT(0);return;}/* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(osc, true, true);/* Configure worst case wait states for flash access before selecting */flashWaitStateMax();/* Switch to selected oscillator */ #if defined( _CMU_HFCLKSEL_MASK )CMU->HFCLKSEL = select; #elseCMU->CMD = select; #endif #if defined( CMU_MAX_FREQ_HFLE )/* Update HFLE configuration after 'select' is set.Note that the HFCLKLE clock is connected differently on planform 1 and 2 */setHfLeConfig(CMU_ClockFreqGet(cmuClock_HFLE), CMU_MAX_FREQ_HFLE); #endif/* Keep EMU module informed */EMU_UpdateOscConfig();/* Update CMSIS core clock variable *//* (The function will update the global variable) */freq = SystemCoreClockGet();/* Optimize flash access wait state setting for currently selected core clk */flashWaitStateControl(freq);break;#if defined( _SILICON_LABS_32B_PLATFORM_2 )case CMU_LFACLKSEL_REG:selReg = (selReg == NULL) ? &CMU->LFACLKSEL : selReg; #if !defined( _CMU_LFACLKSEL_LFA_HFCLKLE )/* HFCLKCLE can not be used as LFACLK */EFM_ASSERT(ref != cmuSelect_HFCLKLE); #endif/* Fall through and select clock source */case CMU_LFECLKSEL_REG:selReg = (selReg == NULL) ? &CMU->LFECLKSEL : selReg; #if !defined( _CMU_LFECLKSEL_LFE_HFCLKLE )/* HFCLKCLE can not be used as LFECLK */EFM_ASSERT(ref != cmuSelect_HFCLKLE); #endif/* Fall through and select clock source */case CMU_LFBCLKSEL_REG:selReg = (selReg == NULL) ? &CMU->LFBCLKSEL : selReg;switch (ref){case cmuSelect_Disabled:tmp = _CMU_LFACLKSEL_LFA_DISABLED;break;case cmuSelect_LFXO:/* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(cmuOsc_LFXO, true, true);tmp = _CMU_LFACLKSEL_LFA_LFXO;break;case cmuSelect_LFRCO:/* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(cmuOsc_LFRCO, true, true);tmp = _CMU_LFACLKSEL_LFA_LFRCO;break;case cmuSelect_HFCLKLE:/* Ensure correct HFLE wait-states and enable HFCLK to LE */setHfLeConfig(SystemCoreClockGet(), CMU_MAX_FREQ_HFLE);BUS_RegBitWrite(&CMU->HFBUSCLKEN0, _CMU_HFBUSCLKEN0_LE_SHIFT, 1);tmp = _CMU_LFBCLKSEL_LFB_HFCLKLE;break;case cmuSelect_ULFRCO:/* ULFRCO is always on, there is no need to enable it. */tmp = _CMU_LFACLKSEL_LFA_ULFRCO;break;default:EFM_ASSERT(0);return;}*selReg = tmp;break;#elif defined( _SILICON_LABS_32B_PLATFORM_1 )case CMU_LFACLKSEL_REG:case CMU_LFBCLKSEL_REG:switch (ref){case cmuSelect_Disabled:tmp = _CMU_LFCLKSEL_LFA_DISABLED;break;case cmuSelect_LFXO:/* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(cmuOsc_LFXO, true, true);tmp = _CMU_LFCLKSEL_LFA_LFXO;break;case cmuSelect_LFRCO:/* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(cmuOsc_LFRCO, true, true);tmp = _CMU_LFCLKSEL_LFA_LFRCO;break;case cmuSelect_HFCLKLE: #if defined( CMU_MAX_FREQ_HFLE )/* Set HFLE wait-state and divider */freq = SystemCoreClockGet();setHfLeConfig(freq, CMU_MAX_FREQ_HFLE); #endif/* Ensure HFCORE to LE clocking is enabled */BUS_RegBitWrite(&CMU->HFCORECLKEN0, _CMU_HFCORECLKEN0_LE_SHIFT, 1);tmp = _CMU_LFCLKSEL_LFA_HFCORECLKLEDIV2;break;#if defined( CMU_LFCLKSEL_LFAE_ULFRCO )case cmuSelect_ULFRCO:/* ULFRCO is always enabled */tmp = _CMU_LFCLKSEL_LFA_DISABLED;lfExtended = 1;break; #endifdefault:/* Illegal clock source for LFA/LFB selected */EFM_ASSERT(0);return;}/* Apply select */if (selRegId == CMU_LFACLKSEL_REG){ #if defined( _CMU_LFCLKSEL_LFAE_MASK )CMU->LFCLKSEL = (CMU->LFCLKSEL& ~(_CMU_LFCLKSEL_LFA_MASK | _CMU_LFCLKSEL_LFAE_MASK))| (tmp << _CMU_LFCLKSEL_LFA_SHIFT)| (lfExtended << _CMU_LFCLKSEL_LFAE_SHIFT); #elseCMU->LFCLKSEL = (CMU->LFCLKSEL & ~_CMU_LFCLKSEL_LFA_MASK)| (tmp << _CMU_LFCLKSEL_LFA_SHIFT); #endif}else{ #if defined( _CMU_LFCLKSEL_LFBE_MASK )CMU->LFCLKSEL = (CMU->LFCLKSEL& ~(_CMU_LFCLKSEL_LFB_MASK | _CMU_LFCLKSEL_LFBE_MASK))| (tmp << _CMU_LFCLKSEL_LFB_SHIFT)| (lfExtended << _CMU_LFCLKSEL_LFBE_SHIFT); #elseCMU->LFCLKSEL = (CMU->LFCLKSEL & ~_CMU_LFCLKSEL_LFB_MASK)| (tmp << _CMU_LFCLKSEL_LFB_SHIFT); #endif}break;#if defined( _CMU_LFCLKSEL_LFC_MASK )case CMU_LFCCLKSEL_REG:switch(ref){case cmuSelect_Disabled:tmp = _CMU_LFCLKSEL_LFA_DISABLED;break;case cmuSelect_LFXO:/* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(cmuOsc_LFXO, true, true);tmp = _CMU_LFCLKSEL_LFC_LFXO;break;case cmuSelect_LFRCO:/* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(cmuOsc_LFRCO, true, true);tmp = _CMU_LFCLKSEL_LFC_LFRCO;break;default:/* Illegal clock source for LFC selected */EFM_ASSERT(0);return;}/* Apply select */CMU->LFCLKSEL = (CMU->LFCLKSEL & ~_CMU_LFCLKSEL_LFC_MASK)| (tmp << _CMU_LFCLKSEL_LFC_SHIFT);break; #endif #endif#if defined( CMU_DBGCLKSEL_DBG ) || defined( CMU_CTRL_DBGCLK )case CMU_DBGCLKSEL_REG:switch(ref){ #if defined( CMU_DBGCLKSEL_DBG )case cmuSelect_AUXHFRCO:/* Select AUXHFRCO as debug clock */CMU->DBGCLKSEL = CMU_DBGCLKSEL_DBG_AUXHFRCO;break;case cmuSelect_HFCLK:/* Select divided HFCLK as debug clock */CMU->DBGCLKSEL = CMU_DBGCLKSEL_DBG_HFCLK;break; #endif#if defined( CMU_CTRL_DBGCLK )case cmuSelect_AUXHFRCO:/* Select AUXHFRCO as debug clock */CMU->CTRL = (CMU->CTRL & ~(_CMU_CTRL_DBGCLK_MASK))| CMU_CTRL_DBGCLK_AUXHFRCO;break;case cmuSelect_HFCLK:/* Select divided HFCLK as debug clock */CMU->CTRL = (CMU->CTRL & ~(_CMU_CTRL_DBGCLK_MASK))| CMU_CTRL_DBGCLK_HFCLK;break; #endifdefault:/* Illegal clock source for debug selected */EFM_ASSERT(0);return;}break; #endif#if defined( USB_PRESENT )case CMU_USBCCLKSEL_REG:switch(ref){case cmuSelect_LFXO:/* Select LFXO as clock source for USB, can only be used in sleep mode *//* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(cmuOsc_LFXO, true, true);/* Switch oscillator */CMU->CMD = CMU_CMD_USBCCLKSEL_LFXO;/* Wait until clock is activated */while((CMU->STATUS & CMU_STATUS_USBCLFXOSEL)==0){}break;case cmuSelect_LFRCO:/* Select LFRCO as clock source for USB, can only be used in sleep mode *//* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(cmuOsc_LFRCO, true, true);/* Switch oscillator */CMU->CMD = CMU_CMD_USBCCLKSEL_LFRCO;/* Wait until clock is activated */while((CMU->STATUS & CMU_STATUS_USBCLFRCOSEL)==0){}break;#if defined( CMU_STATUS_USBCHFCLKSEL )case cmuSelect_HFCLK:/* Select undivided HFCLK as clock source for USB *//* Oscillator must already be enabled to avoid a core lockup */CMU->CMD = CMU_CMD_USBCCLKSEL_HFCLKNODIV;/* Wait until clock is activated */while((CMU->STATUS & CMU_STATUS_USBCHFCLKSEL)==0){}break; #endif#if defined( CMU_CMD_USBCCLKSEL_USHFRCO )case cmuSelect_USHFRCO:/* Select USHFRCO as clock source for USB *//* Ensure selected oscillator is enabled, waiting for it to stabilize */CMU_OscillatorEnable(cmuOsc_USHFRCO, true, true);/* Switch oscillator */CMU->CMD = CMU_CMD_USBCCLKSEL_USHFRCO;/* Wait until clock is activated */while((CMU->STATUS & CMU_STATUS_USBCUSHFRCOSEL)==0){}break; #endifdefault:/* Illegal clock source for USB */EFM_ASSERT(0);return;}break; #endifdefault:EFM_ASSERT(0);break;} #if defined( CMU_MAX_FREQ_HFLE )/* Get to assert wait-state config. */getHfLeConfig(); #endif }

?

轉載于:https://www.cnblogs.com/Ph-one/p/7597602.html

總結

以上是生活随笔為你收集整理的EFM32G232F64时钟树的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

亚洲综合色婷婷 | 91视频三区| 国产盗摄精品一区二区 | 99久久精品国产欧美主题曲 | 国产69久久精品成人看 | 国产一区成人 | 三级黄色理论片 | 手机av电影在线 | 在线导航av | 999男人的天堂 | 97人人模人人爽人人喊中文字 | 国产成人高清av | 毛片www| 开心综合网 | 在线亚洲日本 | 在线a人v观看视频 | 黄网站色欧美视频 | 日本久久中文 | 在线电影 一区 | 欧美在线一二 | 国产又粗又硬又爽的视频 | 亚洲国产中文在线观看 | 国产精品九九九九九九 | 成人欧美日韩国产 | 五月开心六月伊人色婷婷 | 成人h在线播放 | 国产精品久久电影观看 | 精品在线不卡 | 久久tv| 国产午夜av | 日韩免费一级a毛片在线播放一级 | 亚洲无人区小视频 | 免费毛片一区二区三区久久久 | 国产精品久久久久久久久久直播 | 亚洲精品影院在线观看 | 黄色视屏在线免费观看 | 成人视屏免费看 | 日本黄色免费网站 | 最新中文字幕在线观看视频 | 国产生活一级片 | 久久国产精品网站 | 免费国产黄线在线观看视频 | 在线观看日本韩国电影 | 成人a视频片观看免费 | 人人看人人艹 | 日本aaaa级毛片在线看 | 人人狠狠 | 久久国产色| 一区二区中文字幕在线播放 | 久久欧美视频 | 国产成人免费高清 | 特级毛片网站 | 最新国产一区二区三区 | 日韩免费福利 | 国产精品国产精品 | 欧美天堂久久 | 久久久久久久久久久免费视频 | 特级a老妇做爰全过程 | 免费热情视频 | 91天天操 | 国产成免费视频 | 福利一区二区在线 | 香蕉视频在线看 | 91成人欧美 | 国产精品美女毛片真酒店 | 国产免费精彩视频 | 久久99久久99免费视频 | 久久久久久久久久久综合 | 久久视频精品在线观看 | 四虎免费在线观看视频 | 99久久超碰中文字幕伊人 | 97视频在线观看成人 | 在线不卡a | 亚洲91中文字幕无线码三区 | 国产精品a久久 | 99精品国产成人一区二区 | 日韩视频在线观看视频 | 久色 网 | 精品美女视频 | 中文字幕亚洲欧美日韩 | 国产91在线观| 伊人资源站| 欧美日韩网站 | 国产美女精品在线 | 999久久精品 | av黄色成人 | 高清不卡一区二区在线 | 成人免费在线观看入口 | 亚洲人视频在线 | 亚洲传媒在线 | 欧洲视频一区 | 一区二区三区在线免费观看视频 | 五月婷婷在线观看 | 久久久久女教师免费一区 | 国产一卡二卡四卡国 | av电影在线观看完整版一区二区 | 天天操天天操 | 久久久久久久久久久久av | 九九免费观看全部免费视频 | 久久成人国产精品免费软件 | 中文字幕123区 | 久久成人国产精品免费软件 | 99久久9 | 欧美黄网站 | 免费日韩视频 | 99成人精品 | www黄色av| 国产九九九视频 | 三级免费黄色 | 黄色小说视频在线 | 91av视频免费观看 | 日韩高清av在线 | 欧美一二三专区 | 中文字幕高清视频 | 国产高清在线一区 | 国产欧美日韩精品一区二区免费 | 国产打女人屁股调教97 | 91色吧 | 欧美色图另类 | 国产永久免费高清在线观看视频 | 国产精品久久久久9999吃药 | 日韩中文在线播放 | 亚洲免费国产视频 | 日韩免费网址 | 青春草免费视频 | 免费观看www视频 | 国产伦精品一区二区三区照片91 | 中文字幕在线成人 | 国产精品久久久av | 网站在线观看日韩 | 天天久久夜夜 | 九九综合久久 | 成人一级影视 | 亚洲欧美偷拍另类 | 人人干人人超 | 国产精品亚洲片在线播放 | 精品久久一区 | 天天曰天天射 | 亚洲不卡av一区二区三区 | 亚洲 中文 在线 精品 | 精品字幕在线 | 日本三级全黄少妇三2023 | 色综合天天色综合 | 69国产精品视频 | 在线视频 91 | 日韩电影黄色 | 国产乱对白刺激视频在线观看女王 | 91在线免费观看国产 | 国产打女人屁股调教97 | 亚洲永久免费av | 国产一区在线观看免费 | 中文字幕av在线免费 | 精品国精品自拍自在线 | 色综合久久五月天 | 亚洲欧洲中文日韩久久av乱码 | 久久国产精品影片 | 国产一区二区午夜 | 国产精品一区二区av | 国产高清无线码2021 | 日韩精品视频免费 | 国产免费影院 | 五月天中文字幕 | 色多多污污在线观看 | 精品亚洲欧美无人区乱码 | 中文字幕久久精品亚洲乱码 | 免费日p视频 | 久久精品国产精品亚洲 | 久久99精品久久久久久 | 欧美在线视频精品 | 四虎在线影视 | 欧美亚洲三级 | 九九九在线 | 国产精品网红福利 | 曰本三级在线 | 黄色大全免费观看 | 91精品国产综合久久福利不卡 | 婷婷在线网站 | 波多野结衣久久资源 | 婷婷激情站 | 国产精品 国产精品 | 波多野结衣日韩 | 精品国产色 | 激情深爱 | 欧美男女爱爱视频 | 91九色在线播放 | 免费在线看v | www色网站| 韩国精品一区二区三区六区色诱 | 在线观看www视频 | 欧美精品一级视频 | 狠狠综合久久av | 久久国产精品电影 | 日韩中文字幕免费视频 | 激情五月婷婷综合网 | 亚洲综合最新在线 | 六月色婷 | 五月婷婷av在线 | 国产精品免费久久久久 | av一级在线 | 99精品视频在线看 | 日韩理论片在线观看 | 97免费公开视频 | 久久视频网 | 欧美伊人网 | 国产精品一区二区久久精品爱涩 | 97国产大学生情侣白嫩酒店 | www.福利视频 | 99视频在线免费观看 | 激情视频网页 | 日韩av二区 | a视频免费在线观看 | 在线观看av中文字幕 | 日日干干 | www.97视频 | 中文字幕在线一二 | 日本久久精品视频 | 91成人网在线播放 | 黄色毛片在线观看 | 成人久久精品视频 | 亚洲国产免费av | .精品久久久麻豆国产精品 亚洲va欧美 | 亚洲精品国偷拍自产在线观看蜜桃 | 久草视频2 | 国产涩涩在线观看 | 精品视频| 中文字幕日韩高清 | 日韩1级片 | 黄色91在线| 免费黄色在线 | 国产视频999 | 精品国产伦一区二区三区 | 国产黄色精品在线 | 国产手机在线观看视频 | 久久开心激情 | 日日夜夜天天人人 | 最新中文字幕在线资源 | 国产不卡在线看 | 国产视频在线播放 | 免费观看成人网 | 国产97视频 | h视频在线看 | 欧美性生活免费看 | 欧洲精品在线视频 | 国产高清在线一区 | 国产成人91 | 国产在线免费av | 精品一区中文字幕 | 国产色综合天天综合网 | 四虎在线观看视频 | 91香蕉视频黄 | 一级性av | 日韩va亚洲va欧美va久久 | 亚洲国产美女精品久久久久∴ | 99久久综合狠狠综合久久 | 免费黄色av. | 中文字幕美女免费在线 | 欧美久久久久久久 | 日韩av免费一区 | 久久综合久久伊人 | 成人一级免费视频 | 国产精品久久久久久久久久尿 | 99国产成+人+综合+亚洲 欧美 | 91在线精品一区二区 | 国产精品美女久久久久久久久 | 精品久久久久久久久久久久久久久久 | 欧美日韩国产成人 | 日韩中文字幕a | 天堂在线一区二区 | 精品999国产 | 一区二区三区不卡在线 | 69av网| 黄色在线免费观看网址 | 91精品久久久久久粉嫩 | 日本久久电影网 | 美女网站在线播放 | 色中色资源站 | 亚洲黄色一级视频 | 欧美精品久久久久久久久久 | 在线看片a | 91欧美国产 | 狠狠色综合网站久久久久久久 | 免费精品在线视频 | av亚洲产国偷v产偷v自拍小说 | 成人久久久久久久久久 | 国际精品网| 免费网站看v片在线a | 人人看黄色 | 国产原创在线观看 | 国产免费视频在线 | 99在线观看视频网站 | 天堂网一区二区 | 天天操 夜夜操 | 亚洲天天在线日亚洲洲精 | a在线观看免费视频 | 国产高清专区 | 亚洲国产美女精品久久久久∴ | 日韩在观看线 | 成人国产精品免费 | 五月导航 | 日韩视频免费观看高清完整版在线 | 久久久久福利视频 | 亚洲激情| 色射爱| 99午夜| 国产麻豆精品在线观看 | 亚洲艳情 | 91九色性视频 | 亚洲三级影院 | 91福利视频久久久久 | 久久精品视频在线观看免费 | 99性视频 | 毛片888 | 婷婷深爱激情 | 色九九影院 | aⅴ视频在线 | 亚洲天堂免费视频 | 亚洲最新av网址 | www国产在线 | 爱色婷婷| 成人av日韩| 中文字幕在线成人 | 久久99精品国产99久久6尤 | 亚洲激精日韩激精欧美精品 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 国产视频1 | 免费看网站在线 | 成人在线视频网 | 国产综合福利在线 | 91传媒在线| 亚洲成色777777在线观看影院 | 婷婷社区五月天 | 在线播放国产精品 | 日韩在线观| 狠狠色丁香婷婷综合视频 | 免费观看一区二区 | 欧美一区二区三区在线 | 一区二区三区四区在线免费观看 | 天天干国产 | 亚州国产精品视频 | 麻豆国产网站 | 精品不卡av | 久久久午夜精品福利内容 | 国产中出在线观看 | 国产综合婷婷 | 日韩成人黄色 | 日韩一二三 | 国产欧美精品一区二区三区四区 | 亚洲国产中文字幕在线观看 | 久久精品国产精品亚洲 | 99热9| 亚洲午夜精品一区二区三区电影院 | 亚洲精品乱码白浆高清久久久久久 | 国产精品久久久一区二区 | 国产精品一区二区免费在线观看 | 日韩午夜电影院 | 国产日产精品一区二区三区四区 | 亚洲成av人片在线观看无 | 草久久久| 丁香视频全集免费观看 | av丁香花 | 欧美综合色在线图区 | 久久久久国产精品厨房 | 国产精品18videosex性欧美 | avv天堂| 超碰97在线资源站 | av中文字幕免费在线观看 | 能在线看的av | 欧美日韩亚洲一 | 四虎永久国产精品 | 黄色av高清 | 99免费在线观看视频 | 亚洲不卡123 | 成 人 黄 色视频免费播放 | av一级网站 | 国产中文字幕一区二区三区 | 日韩av资源在线观看 | 最新日本中文字幕 | 国产精品午夜在线观看 | 精品黄色在线观看 | 亚洲精品综合一区二区 | 亚洲资源在线网 | 五月天色婷婷丁香 | 亚洲天堂视频在线 | 国产色道 | 91麻豆高清视频 | 久草精品在线播放 | 亚洲成av片人久久久 | 国产色啪| 免费在线播放视频 | 日韩久久在线 | 中文字幕高清av | 久草在线视频精品 | 久久成人综合视频 | 亚洲精品福利在线观看 | 国产亚洲永久域名 | 亚洲视频每日更新 | 手机av资源 | 国产成人精品一区二区三区免费 | 亚洲国产精品99久久久久久久久 | 精品免费久久久久 | 国产成人精品一区二区三区在线 | 国产精品 日韩 欧美 | 亚洲在线精品 | 婷婷精品在线视频 | 97成人在线免费视频 | 国产精品色 | 免费看在线看www777 | 亚洲精品国产精品99久久 | 日韩videos| 又爽又黄又刺激的视频 | 91在线看黄 | 九九九在线 | 91免费国产在线观看 | a级国产乱理伦片在线观看 亚洲3级 | 91夫妻视频| 久草在线免费资源站 | 国产亚洲欧美精品久久久久久 | 欧美久久综合 | 丁香六月激情 | 亚洲夜夜网 | 高清av在线 | 欧美久久电影 | av综合av | 国产毛片久久 | 亚洲一级电影 | 四虎影视4hu4虎成人 | 亚洲一区二区三区四区精品 | 久久久久久久久久久久99 | 激情影院在线观看 | 国产精品18久久久久久久 | 91九色porny在线 | 国产精品久久久久久久午夜片 | 久久99影院 | 不卡的一区二区三区 | 欧美中文字幕久久 | 日韩av进入 | 国内视频一区二区 | 日韩在线国产精品 | 日日夜夜精品 | 九九免费在线观看视频 | 在线有码中文字幕 | 亚洲综合五月 | 久久成年人网站 | 精品欧美小视频在线观看 | 黄色片网站大全 | 中文字幕 国产精品 | 久久久电影| 久久国产成人午夜av影院潦草 | 久久精品视频国产 | 久草在线免费看视频 | 久久久国产精品电影 | av在线免费播放 | 中文字幕免费观看全部电影 | 五月婷婷导航 | 天堂在线一区二区 | 你操综合 | 日本一区二区免费在线观看 | 婷婷综合国产 | 日韩三级视频在线观看 | 在线免费观看av网站 | 国外av在线| 88av色| 九九在线视频免费观看 | 亚洲国产婷婷 | 免费福利在线观看 | 四虎影视成人永久免费观看亚洲欧美 | 成人aaa毛片 | 黄色一级大片在线免费看产 | 丁香九月婷婷 | 久草免费在线视频观看 | av大全在线播放 | 欧美色就是色 | 激情xxxx | 色欲综合视频天天天 | 国产精品综合久久久 | 中文字幕在线观看国产 | 日韩久久精品一区二区三区下载 | 一级黄色大片在线观看 | 最新国产在线视频 | 免费av在线播放 | 国产成年人av | 美女精品在线观看 | 久草久热 | 亚洲激情视频在线 | 成年人视频在线免费观看 | 国产精品久久久99 | 欧美日韩在线电影 | 免费成人在线观看视频 | 麻豆网站免费观看 | 亚洲精品免费在线观看 | 免费亚洲视频 | 人人澡人人添人人爽一区二区 | 欧美激情第一区 | 日韩视频一 | 欧美激情第八页 | 日韩国产欧美在线视频 | 国产xxxx性hd极品 | 国产成人精品一区二区三区网站观看 | 亚洲黄a| 久草免费新视频 | 在线91网| 7777xxxx| 精品久久久久久久久中文字幕 | 国产黄色免费电影 | 天天干天天操 | 97精品欧美91久久久久久 | 激情九九 | 亚洲精品黄 | 日韩精品三区四区 | 天海翼一区二区三区免费 | 99这里只有久久精品视频 | 亚洲最新av网站 | 久久www免费视频 | 日韩另类在线 | av成人在线电影 | av动态图片 | 国产视频1区2区3区 久久夜视频 | 国产精品美女久久久免费 | 国产不卡在线 | 国产99一区视频免费 | 久久国产免 | 国产精品网站一区二区三区 | 婷婷丁香激情网 | 国产精品久久99综合免费观看尤物 | 日韩v欧美v日本v亚洲v国产v | 欧美日韩精品综合 | 国产 欧美 日本 | 国产精品麻豆一区二区三区 | 久久久人人人 | 玖玖在线视频观看 | 亚洲日本va午夜在线电影 | 日韩精品视频第一页 | 久久精品专区 | 美女国产精品 | 亚洲精品视频在线观看免费视频 | 91精品入口 | 日本久久99| 国产精品一区二区在线看 | 蜜桃视频在线视频 | 国产福利中文字幕 | 国产香蕉视频在线观看 | 欧美了一区在线观看 | www视频在线播放 | 丁香电影小说免费视频观看 | 欧美另类sm图片 | 久久综合偷偷噜噜噜色 | 这里只有精品视频在线 | 97电影网手机版 | 美女网站视频免费都是黄 | 17婷婷久久www | 国产精品精品久久久久久 | 国产 色 | 91精彩在线视频 | 亚洲做受高潮欧美裸体 | 国产精品久久久久aaaa | 日本精a在线观看 | 亚洲精品国产免费 | 69xxxx欧美 | 婷婷综合在线 | 色综合天天在线 | 97色噜噜 | 免费电影一区二区三区 | 亚洲精品色 | 天天操天天射天天舔 | 一区二区久久 | www.亚洲黄色| 在线免费观看国产黄色 | 一级免费片| 中文字幕资源网 | 天天综合久久综合 | 日韩电影在线一区 | 欧美日韩精品免费观看 | 国产成人在线免费观看 | 日韩精品在线看 | 国产91成人在在线播放 | 2019精品手机国产品在线 | 免费精品在线观看 | 精品国产免费人成在线观看 | 伊人春色电影网 | 精品一二三区视频 | 久久精品精品 | 欧美精品久久久久 | 亚洲精品视频免费在线观看 | 六月丁香婷 | 欧美日韩精品在线观看视频 | 亚洲精品视频在线观看免费 | 一级做a爱片性色毛片www | 亚洲综合狠狠干 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 久热av | 中文资源在线播放 | 亚洲国产精品va在线 | 91精品在线免费观看视频 | 涩涩伊人| 亚洲精品乱码久久久久久蜜桃欧美 | 国产精品一区在线观看 | 亚洲精品 在线视频 | 中文字幕在线观看日本 | 欧美日韩国产亚洲乱码字幕 | av电影中文 | 亚洲一区 影院 | 国产老熟 | 国产精品一区免费在线观看 | 天天操天天干天天干 | 精品美女在线视频 | 91免费高清在线观看 | 色在线国产 | 在线观看成人毛片 | 在线你懂的视频 | www.色婷婷 | 超碰免费在线公开 | 波多野结衣精品在线 | 一区二区三区播放 | 中文字幕 婷婷 | 亚洲 欧美 国产 va在线影院 | 欧美成人日韩 | 三级av在线免费观看 | 在线观看黄网站 | 成人avav | 日本成人中文字幕在线观看 | 欧美一区二区在线刺激视频 | 色开心| 天天拍天天干 | 国产区精品视频 | av在线播放观看 | 永久黄网站色视频免费观看w | 国产精品免费成人 | 亚洲高清视频一区二区三区 | 国产美女久久久 | 丁香九月婷婷综合 | 久久久精品国产一区二区电影四季 | 免费看亚洲毛片 | 91久久国产精品 | 国产精品一区二区av麻豆 | 久久97久久97精品免视看 | 国产91对白在线播 | 97免费视频在线 | 国产视频在线一区二区 | 香蕉97视频观看在线观看 | 精品99在线视频 | av 一区二区三区 | 成人a视频 | 欧美性免费 | 午夜视频色| 在线视频 成人 | 人人讲下载 | 亚洲欧洲xxxx | 中文字幕在线观 | 亚洲第一区在线播放 | 精品国内自产拍在线观看视频 | 97电影在线观看 | 可以免费看av | 正在播放一区 | 国产精品高潮久久av | 欧美日bb| 麻豆播放 | 国产精品视频内 | 最新国产精品久久精品 | 成人免费在线看片 | 在线观看视频色 | 91看片淫黄大片91 | 天天干视频在线 | 成年人免费观看国产 | www.激情五月.com | 婷婷在线不卡 | 少妇视频一区 | 最新av免费在线 | 91丨九色丨蝌蚪丰满 | 91视频在线免费 | 国产一区二区久久久 | 99麻豆视频| 成人黄色小说网 | 久草网站在线 | 精品欧美一区二区在线观看 | 免费观看视频黄 | 99视频精品全部免费 在线 | 毛片网免费 | 国产在线欧美在线 | 国产精品一区二区三区电影 | av不卡免费在线观看 | 在线免费观看视频你懂的 | 国产精品久久久免费 | 国产福利在线免费观看 | 国产96av | 日韩大片在线 | 日韩成人中文字幕 | 在线精品视频在线观看高清 | 99re在线视频观看 | 国内精品久久久久影院优 | 亚洲精品福利在线观看 | 九九九电影免费看 | 美女又爽又黄 | 特黄特色特刺激视频免费播放 | 日韩超碰在线 | 麻豆视频在线播放 | 97在线影视 | 成人av影视 | 国产精品欧美一区二区 | 中文字幕日韩在线播放 | 久久久久久草 | 麻豆成人小视频 | 天天操天天操天天爽 | 中文理论片 | 亚洲精品国产精品乱码在线观看 | 色播亚洲婷婷 | 精品国产亚洲一区二区麻豆 | 超碰97网站| 国产日韩视频在线播放 | 精品国产乱码久久久久久天美 | 久久深夜福利免费观看 | 色偷偷88欧美精品久久久 | 色欧美视频 | 色视频在线观看 | 日日爱影视 | 最近最新中文字幕视频 | 五月激情久久久 | 日韩成人免费在线观看 | 黄色小视频在线观看免费 | 久久久影片 | 国产精品成人一区 | 视频 天天草 | 国产精品嫩草69影院 | 亚洲欧洲一区二区在线观看 | 制服丝袜在线 | 亚洲精品视频在线观看免费视频 | 天天曰视频| 9ⅰ精品久久久久久久久中文字幕 | 美女网站黄在线观看 | 在线免费三级 | 欧美天堂久久 | 日本精品免费看 | 久久激情精品 | 久久香蕉国产精品麻豆粉嫩av | 亚洲人成人天堂h久久 | 99日精品| 久久黄色a级片 | 69国产成人综合久久精品欧美 | 96国产精品视频 | 亚洲妇女av | 亚洲国产成人精品久久 | 色综合亚洲精品激情狠狠 | 91亚洲精品久久久久图片蜜桃 | 中文字幕视频观看 | 91免费试看 | 亚洲欧美日韩一级 | 欧美日韩在线精品 | 激情欧美丁香 | 一级α片免费看 | 超碰在线观看av.com | 日韩三级久久 | 很黄很黄的网站免费的 | 久久午夜剧场 | 91精品国产99久久久久久红楼 | 欧美激情另类 | 色综合久久久久综合体桃花网 | 色夜视频 | 在线看片中文字幕 | 亚洲精品视频在线播放 | 丁香午夜 | 亚洲国产精品资源 | 亚洲天堂激情 | 色婷婷综合久久久中文字幕 | 亚洲免费在线视频 | av在线日韩 | 麻豆影视网站 | 中文字幕视频免费观看 | 国产成人精品午夜在线播放 | 精品国产亚洲日本 | 麻豆系列在线观看 | 超碰av在线 | 久草| 天天爱天天射天天干天天 | 国产精品大片 | 99免费在线视频观看 | av五月婷婷| 国产成人在线免费观看 | 国产色视频网站2 | 国产69久久精品成人看 | 欧美一级特黄高清视频 | 亚洲天堂精品视频 | 伊人手机在线 | 久草在线免费新视频 | 人人狠狠| 亚洲午夜小视频 | 伊人天天狠天天添日日拍 | 日韩免费b | 久久国产精品99精国产 | 精品国产一区二区三区噜噜噜 | 一区二区激情 | av黄色国产 | 一级特黄aaa大片在线观看 | 成人啪啪18免费游戏链接 | 特级a老妇做爰全过程 | 国产精品久久久久久久久岛 | 色中色综合 | 欧美日韩中文国产一区发布 | 欧美精品一区二区在线播放 | 亚洲丝袜一区二区 | 国产精品久久网 | 欧美日韩久 | 国产经典 欧美精品 | 精品v亚洲v欧美v高清v | 久久久国产成人 | 国产对白av| 九九涩涩av台湾日本热热 | 干狠狠 | 这里有精品在线视频 | 免费久久99精品国产 | 中文字幕色在线 | 91漂亮少妇露脸在线播放 | 亚洲精品综合久久 | 日韩av不卡在线 | av电影免费在线看 | 激情在线网址 | a在线观看国产 | 日韩网站中文字幕 | 中文视频在线播放 | www免费网站在线观看 | 欧美综合久久 | 一级片视频免费观看 | 亚洲一片黄 | 福利一区视频 | www.久久成人 | 四虎www.| 亚洲精品88欧美一区二区 | 国产精品18久久久久久首页狼 | 免费日韩视频 | 视频二区在线视频 | 在线观看日韩国产 | 久久精品导航 | 色婷婷亚洲精品 | 欧美福利片在线观看 | 天天操天天操天天操天天操 | 免费高清在线观看成人 | 精品国产一区二区三区免费 | 亚洲精品国偷拍自产在线观看蜜桃 | 日韩中文字幕第一页 | 91精品免费在线 | 四虎永久免费 | 国产va精品免费观看 | 亚洲v精品 | 黄色软件在线观看免费 | 久久综合之合合综合久久 | 久久精品视频99 | 青青草国产免费 | 国产精品美女在线观看 | 中文字幕日韩精品有码视频 | 亚洲精品视频在线观看视频 | 久久久国产一区 | 亚洲欧美日本一区二区三区 | 色福利网 | 国产精品高潮在线观看 | 久久99久久99精品免观看粉嫩 | 五月婷婷天堂 | 婷婷激情影院 | 天天射天天| 欧美日韩免费观看一区二区三区 | 亚洲欧美色婷婷 | 国产一区二区三区高清播放 | 色99导航 | 国产免费久久av | 中文字幕免费高清 | 99久热在线精品视频观看 | 久草免费福利在线观看 | 国产精品国产自产拍高清av | 天天射天天做 | 超级碰碰碰碰 | 久久官网 | 国产精品黄 | 天天天色 | 久久婷婷一区二区三区 | 麻豆视频免费观看 | av高清一区 | 日韩手机在线观看 | 国产又粗又猛又黄视频 | 97精品国产97久久久久久粉红 | 在线观看亚洲国产 | 中文字幕色婷婷在线视频 | 国产精品福利在线观看 | 国产精品理论片 | 日韩在线观看av | 国产精品美女免费 | 亚欧洲精品视频在线观看 | 久久久亚洲国产精品麻豆综合天堂 | 日韩欧美大片免费观看 | 日韩激情视频在线 | 国产精品视频地址 | 日本黄色大片免费看 | 国产一级黄色电影 | 91麻豆精品一区二区三区 | 国产精品美女久久久久久免费 | 精品久久久久久久久久 | 在线精品视频免费播放 | 91在线观| 久久久精品综合 | 丰满少妇一级 | 丁香六月在线 | 在线视频 你懂得 | 免费av黄色| 91视频 - v11av | 久久久久欧美精品999 | 五月婷婷丁香 | bbb搡bbb爽爽爽| 国产人成在线观看 | 亚洲精品国产片 | 欧美中文字幕久久 | 中文字幕黄色 | 西西www444| 麻豆果冻剧传媒在线播放 | 婷婷丁香在线 | 色天堂在线视频 | 日韩在线色视频 | 五月婷在线播放 | 超碰999| 欧美电影黄色 | 青青草国产免费 | 亚洲五月六月 | 天堂va在线观看 | 久香蕉| 久草com | 99久久婷婷国产 | 国产日韩欧美综合在线 | 欧美日韩中文字幕综合视频 | 91丨porny丨九色 | 免费高清在线观看电视网站 | 久久国产精品视频 | 国产精品黄 | 国产精品久久99 | 日韩精品首页 | 国产尤物一区二区三区 | 日韩欧美在线免费 | 久久久国产精品一区二区三区 | 国产精品扒开做爽爽的视频 | 天天操导航 | 视频二区在线视频 | 亚洲va欧美va | 天天综合网国产 | 久久久高清免费视频 | 伊人宗合| 中文字幕人成人 | av看片在线 | 日本xxxx裸体xxxx17 | 欧美日韩免费一区二区三区 | 一区三区在线欧 | av理论电影 | 国产一区二区三区在线 | 91成人亚洲 | 国产 视频 高清 免费 | 国产精品欧美激情在线观看 | 狠狠色狠狠色 | 日韩av五月天 | 免费av福利| 国产精品日韩精品 | 色夜影院| 六月天综合网 | 国产精品com | 人人添人人澡人人澡人人人爽 | 九九久久免费 | 99精品免费网 | 激情www| 国产私拍在线 | 美女av电影| 国产a级精品 | 欧美 激情 国产 91 在线 | 国产午夜麻豆影院在线观看 | 色婷婷99 | 日韩精品久久一区二区三区 | 国产在线a免费观看 | 日韩久久网站 | 国产中文字幕三区 | 色婷婷久久久综合中文字幕 | 天天操网| 女人18片毛片90分钟 | 亚洲精品大全 | 欧美综合色在线图区 | 香蕉视频免费看 | 国产精品第54页 | 亚洲视频久久久 | 91高清不卡| 插婷婷 | 99久精品视频 | www.日本色 | 国产精品一区二区在线观看免费 | 欧美日韩在线免费观看视频 | 国产永久免费高清在线观看视频 | aaawww| 欧美亚洲免费在线一区 | 69人人| 国产91亚洲| 中文字幕资源网 国产 | a黄色影院 | av大全免费在线观看 | 成人黄色片在线播放 | 国产精品一区二 | 亚洲狠狠婷婷 | 日本久久影视 | 久久av网| 国产精品久久一区二区三区不卡 |