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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

【正点原子STM32连载】第七章 认识HAL库 摘自【正点原子】MiniPro STM32H750 开发指南_V1.1

發布時間:2023/12/10 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【正点原子STM32连载】第七章 认识HAL库 摘自【正点原子】MiniPro STM32H750 开发指南_V1.1 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1)實驗平臺:正點原子MiniPro H750開發板
2)平臺購買地址:https://detail.tmall.com/item.htm?id=677017430560
3)全套實驗源碼+手冊+視頻下載地址:http://www.openedv.com/thread-336836-1-1.html
4)對正點原子STM32感興趣的同學可以加群討論:879133275

第七章 認識HAL庫

HAL,英文全稱Hardware Abstraction Layer,即硬件抽象層。HAL庫是ST公司提供的外設驅動代碼的驅動庫,用戶只需要調用庫的API函數,便可間接配置寄存器。我們要寫程序控制STM32芯片,其實最終就是控制它的寄存器,HAL庫就為了更方便我們去控制寄存器,從而節約開發時間。
本章將分為如下幾個小節:
7.1 初識STM32 HAL庫
7.2 HAL庫驅動包
7.3 HAL庫框架結構
7.4 如何使用HAL庫
7.5 HAL庫使用注意事項

7.1 初識STM32 HAL庫

STM32開發中常說的HAL庫開發,指的是利用HAL庫固件包里封裝好的c語言編寫的驅動文件,來實現對STM32內部和外圍電器元件的控制的過程。但只有HAL庫還不能直接驅動一個STM32的芯片,其它的組件已經由ARM與眾多芯片硬件、軟件廠商制定的通用的軟件開發標準CMSIS實現了,本文只簡單介紹這個標準,等大家熟悉開發后再研究這個框架。
簡單地了解HAL庫的發展和作用,可以方便學習者確定HAL庫是否適合作為學習者自己長期開發STM32的工具,以降低開發、學習的成本。
7.1.1 CMSIS標準
根據一些調查研究表明,軟件開發已經被嵌入式行業公認為最主要的開發成本,為了降低這個成本,ARM與Atmel、IAR、KEIL、SEGGER和ST等諸多芯片和軟件工具廠商合作,制定了一個將所有Cortex芯片廠商的產品的軟件接口標準化的標準CMSIS(Cortex Microcon troller Software Interface Standard)。下面來看ARM官方提供的CMSIS規范架構圖,如圖7.1.1.1所示:

圖7.1.1.1 CorteX芯片的CMSIS分級實現
從圖中可以看出這個標準分級明顯,從用戶程序到內核底層實現做了分層。按照這個分級,HAL庫屬于CMSIS-Pack中的“Peripheral HAL”層。CMSIS規定的最主要的3個部分為:核內外設訪問層(由ARM負責實現)、片上外設訪問層和外設訪問函數(后面兩個由芯片廠商負責實現)。ARM整合并提供了大量的模版,各廠商根據自己的芯片差異修改模版,這其中包括匯編文件startup_device.s、system_.h和system_.c這些與初始化和系統相關的函數。
結合STM32H7的芯片來說,其CMSIS應用程序的簡單結構框圖,不包括實時操作系統和中間設備等組件,其結構如圖7.1.1.2所示。

圖7.1.1.2 CMSIS分級下的STM32H7的文件分布
上面的框架是根據我們現在已經學習到的知識回過頭來作的一個總結,這里只是作簡單介紹,告訴大家它們之間存在一定聯系,關于組成這些部分的文件、文件的作用及各文件如何組合、各分層的作用和意義,我們會在今后的學習過程中慢慢學習。
7.1.2 HAL庫簡介
庫函數的引入,大大降低STM主控芯片開發的難度。ST公司為了方便用戶開發STM32芯片開發提供了三種庫函數,從時間產生順序是:標準庫、HAL庫和LL庫。目前ST已經逐漸暫停對部分標準庫的支持,ST的庫函數維護重點對角已經轉移到HAL庫和LL庫上,下面我們分別為這三種庫作一下簡單的介紹。
1.標準外設庫(Standard Peripheral Libraries)
標準外設庫(Standard Peripherals Library)是對STM32芯片的一個完整的封裝,包括所有標準器件外設的器件驅動器,是ST最早推出的針對STM系列主控的庫函數。標準庫的設計的初衷是減少用戶的程序編寫時間,進而降低開發成本。幾乎全部使用C語言實現并嚴格按照“Strict ANSI-C”、MISRA-C 2004等多個C語言標準編寫。但標準外設庫仍然接近于寄存器操作,主要就是將一些基本的寄存器操作封裝成了C函數。開發者仍需要關注所使用的外設是在哪個總線之上,具體寄存器的配置等底層信息。

圖7.1.2.1 ST的標準庫函數家族
ST為各系列提供的標準外設庫稍微有些區別。例如,STM32F1x的庫和STM32F3x的庫在文件結構上就有些不同,此外,在內部的實現上也稍微有些區別,這個在具體使用(移植)時,需要注意一下!但是,不同系列之間的差別并不是很大,而且在設計上是相同的。
STM32的標準外設庫涵蓋以下3個抽象級別:
? 包含位,位域和寄存器在內的完整的寄存器地址映射。
? 涵蓋所有外圍功能(具有公共API的驅動器)的例程和數據結構的集合。
? 一組包含所有可用外設的示例,其中包含最常用的開發工具的模板項目。
關于更詳細的信息,可以參考ST的官方文檔《STM32 固件庫使用手冊中文翻譯版》,文檔中對于標準外設庫函數命名、文件結構等都有詳細的說明,這里我們就不多介紹了。
值得一提的是由于STM32的產品性能及標準庫代碼的規范和易讀性以及例程的全覆蓋性,使STM32的開發難度大大下降,更多。但ST從L1以后的芯片L0、L4和F7等系列就沒有再推出相應的標準庫支持包了。
2.HAL庫
HAL是Hardware Abstraction Layer的縮寫,即硬件抽象層。是ST為可以更好的確保跨STM32產品的最大可移植性而推出的MCU操作庫。這種程序設計由于抽離應用程序和硬件底層的操作,更加符合跨平臺和多人協作開發的需要。
HAL庫是基于一個非限制性的BSD許可協議(Berkeley Software Distribution)而發布的開源代碼。ST制作的中間件堆棧(USB主機和設備庫,STemWin)帶有允許輕松重用的許可模式, 只要是在ST公司的MCU 芯片上使用,庫中的中間件(USB主機/設備庫,STemWin)協議棧即被允許修改,并可以反復使用。至于基于其它著名的開源解決方案商的中間件(FreeRTOS,FatFs,LwIP和PolarSSL)也都具有友好的用戶許可條款。
HAL庫是從ST公司從自身芯片的整個生產生態出發,為了方便維護而作的一次整合,以改變標準外設庫帶來各系列芯片操作函數結構差異大、分化大、不利于跨系列移植的情況。相比標準外設庫,STM32Cube HAL庫表現出更高的抽象整合水平,HAL庫的API集中關注各外設的公共函數功能,這樣便于定義一套通用的用戶友好的API函數接口,從而可以輕松實現從一個STM32產品移植到另一個不同的STM32系列產品。但由于封閉函數為了適應最大的兼容性,HAL庫的一些代碼實際上的執行效率要遠低于寄存器操作。但即便如此,HAL庫仍是ST未來主推的庫。
3.LL庫
LL庫(Low Layer)目前與HAL庫捆綁發布,它的設計為比HAL庫更接近于硬件底層的操作,代碼更輕量級,代碼執行效率更高的庫函數組件,可以完全獨立于HAL庫來使用,但LL庫不匹配復雜的外設,如USB等。所以LL庫并不是每個外設都有對應的完整驅動配置程序。使用LL庫需要對芯片的功能有一定的認知和了解,它可以:
? 獨立使用,該庫完全獨立實現,可以完全拋開HAL庫,只用LL庫編程完成。
? 混合使用,和HAL庫結合使用。
對于HAL庫和LL庫的關系,如圖7.1.2.2 Cube的軟件框架所示,可以看出它們設計為彼此獨立的分支,但又同屬于HAL庫體系。

圖7.1.2.2 Cube的軟件框架
通過以上簡介我們對目前主流的STM32開發庫有了一個初步的印象。標準庫和HAL庫、LL庫完全相互獨立,HAL庫更傾向于外設通用化,擴展組件中解決芯片差異操作部分;LL傾向于最簡單的寄存器操作,ST在未來還將重點維護和建設HAL庫,標準庫已經部分停止更新。HAL庫和LL庫的應用將是未來的一個趨勢。
7.1.3 HAL庫能做什么
用過標準庫的朋友應該知道,使用標準庫可以忽略很多芯片寄存器的細節,根據提供的接口函數快速配置和使用一個STM32芯片,使用HAL庫也是如此。不論何種庫,本質都是配置指定寄存器使芯片工作在我們需要的工作模式下。HAL庫在設計的時候會更注重軟硬件分離。HAL庫的API集中關注各個外設的公共函數功能,便于定義通用性更好、更友好的API函數接口,從而具有更好的可移植性。HAL庫寫的代碼在不同的STM32產品上移植,非常方便。
我們需要學會調用HAL庫的API函數,配置對應外設按照我們的要求工作,這就是HAL庫能做的事。但是無論庫封裝得多高級,最終還是要通過配置寄存器來實現。所以我們學習HAL庫的同時,也建議同時學習外設的工作原理和寄存器的配置。只有掌握了原理,才能更好的使用HAL庫,一旦發生問題也能更快速了定位和解決問題。
HAL庫還可以和STM32CubeMX(圖形化軟件配置工具)配套一起使用,開發者可以使用該工具進行可視化配置,并且自動生成配置好的初始化代碼,大大的節省開發時間。

7.2 HAL庫驅動包

HAL庫是一系列封裝好的驅動函數,本節將從下載渠道、固件包的內容分析及在實際開發中用到的幾個文件的詳細介紹。
7.2.1 如何獲取HAL庫固件包
HAL庫是ST推出的STM32Cube軟件生態下的一個分支。STM32Cube是ST公司提供的一套免費開發工具和STM32Cube 固件包,旨在通過減少開發工作、時間和成本來簡化開發人員的工作,并且覆蓋整個STM32產品。它包含兩個關鍵部分:
1、允許用戶通過圖形化向導來生成C語言工程的圖形配置工具STM32CubeMX。可以通過CubeMX實現方便地下載各種軟件或開發固件包。
2、包括由STM32Cube硬件抽象層(HAL),還有一組一致的中間件組件(RTOS、USB、FAT文件系統、圖形、TCP/IP和以太網),以及一系列完整的例程組成的STM32Cube固件包。
ST提供了多種獲取固件包的方法。本節只介紹從ST官方網站上直接獲取固件庫的方法。網頁登陸:www.st.com,在打開的頁面中依次選擇:“Tools & Software”->“Ecosystem”-> “STM32Cube”->新頁面->選擇“Prodcut selector”,具體如下圖所示:

圖7.2.1.1 找到STM32CubeH7固件包的下載位置
在展開的頁面中選擇我們需要和固件,這里展開“STM32CubeH7”即可看到我們需要的H7的固件包,按下圖操作,在新的窗口中拉到底部,選擇適合自己的下載方式,注冊帳號即可獲取相應的驅動包。

圖7.2.1.2 下載STM32CubeH7固件包
STM32Cube固件包,我們已經給大家下載好并且放到A盤8,STM32參考資料1,STM32CubeH7固件包,當前固件包版本是:STM32Cube_FW_H7_V1.6.0。因為現在是STM32H750的學習,所以我們準備好的固件包是H7的。大家要根據自己學習的芯片,下載對應的固件包。如果需要最新的固件包,大家按照上述的方法到官網重新獲取即可。
7.2.2 STM32Cube固件包分析
STM32Cube 固件包完全兼容STM32CubeMX。對于圖形配置工具STM32CubeMX入門使用,由于需要STM32F1基礎才能入門使用,所以我們安排在后面第十章給大家講解。本小節,我們主要講解STM32Cube固件包的結構。
解壓STM32CubeH7固件包后,我們看看其目錄結構,如圖7.2.2.1所示。

圖7.2.2.1 STM32CubeH7固件包的目錄結構
下面對STM32CubeH7固件包進行簡要介紹。對于Documentation文件夾,里面是一個STM32CubeH7英文說明文檔,這里我們就不做過多解釋。接下來我們通過幾個表格依次來介紹一下STM32CubeH7中幾個關鍵的文件夾。
(1)Drivers文件夾
Drivers文件夾包含BSP,CMSIS和STM32H7xx_HAL_Driver三個子文件夾。三個子文件夾具體說明請參考下表7.2.2.1:

表7.2.2.1 Drivers文件夾介紹
(2)Middlewares文件夾
該文件夾下面有ST和Third_Party 2個子文件夾。ST文件夾下面存放的是STM32相關的一些文件,包括STemWin和USB庫等。Third_Party文件夾是第三方中間件,這些中間價都是非常成熟的開源解決方案。具體說明請見下表7.2.2.2:

表7.2.2.2 Middlewares文件夾介紹
(3)Projects文件夾
該文件夾存放的是ST官方的開發板的適配例程,每個文件夾對應一個ST官方的Demo板,根據型號的不同提供MDK和IAR等類型的例程。里面有很多實例,讀者可以根據自己的需要來作為參考。比如我們要查看STM32H750相關工程,所以我們直接打開子文件夾STM32H750B-DK即可。里面有很多實例,我們都可以用來參考。這里大家注意,每個工程下面都有一個MDK-ARM子文件夾,該子文件夾內部會有名稱為Project.uvprojx的工程文件,我們只需要雙擊它就可在MDK中打開工程。
(4)Utilities文件夾
該文件夾是一些公用組件,也是主要為ST官方的Demo板提供的,在我們的例程中使用得不多。有興趣的同學可以深入研究一下,這里我們不做過多介紹。
(5)其它幾個文件
文件夾中還有幾個單獨的文件,用于聲明軟件版本或者版權信息,我們使用ST的芯片已經默認得到這個軟件的版權使用授權,可以簡單了解一下各文件的內容,實際項目中我們一般不添加。
License.md:用于聲明軟件版權信息的文件。
package.xml:描述固件包版本信息的文件。
Release_Notes.html:超文本文件,用瀏覽器打開可知它是對固件包的補充描述和固件版本更新的記錄說明。
7.2.3 CMSIS文件夾關鍵文件
上一節中我們對STM32cube固件包的主要目錄結構做了分析。這一小節在上一小節的基礎上,我們來分析一下CMSIS文件夾:由命名可知該文件夾和7.1.1小節中提到的CMSIS標準是一致的,CMSIS為軟件包的內容制定了標準,包括文件目錄的命名和內容構成,CMSIS版本5.7.0的規定軟件包目錄如表7.2.3.1所示:

表7.2.3.1 CMSIS v5.7.0的文件夾規范
知道了CMSIS規定的組件及其文件目錄的大概內容后,我們再來看看ST提供的CMSIS文件夾,如上節提到的,它的位置是“STM32Cube_FW_H7_V1.6.0\Drivers\CMSIS”。打開文件夾內容如圖7.2.3.1所示,可以發現它的目錄結構完全按照CMSIS標準執行,僅僅是作了部分刪減。

圖7.2.3.1 STM32CubeH7固件包的CMSIS文件夾
CMSIS文件夾中的Device和Include這兩個文件夾中的文件是我們工程中最常用到的。下面對這兩個文件夾作簡單的介紹:
(1)Device文件夾
Device文件夾關鍵文件介紹如下表7.2.3.1所示:

表7.2.3.1 Device文件夾關鍵文件介紹
表7.1.2.1列出的文件都是正式工程中必須的文件。固件包的CMSIS文件包括了所有STM32H7芯片型號的文件,而我們只用到STM32H750系列,所以只是挑我們用到的系列文件來講。
(2)Include文件夾
Include文件夾存放了符合CMSIS標準的 Cortex-M 內核頭文件。 想要深入學習內核的朋友可以配合內核相關的手冊去學習。對于STM32H7的工程,我們只要把我們需要的添加到工程即可,需要的頭文件有:cmsis_armcc.h、cmsis_armclang.h、cmsis_compiler.h、cmsis_version.h、core_cm7.h和mpu_armv7.h。這幾個頭文件,對比起來,我們會比較多接觸的是core_cm7.h。
core_cm7.h是內核底層的文件,由ARM公司提供,包含一些AMR內核指令,如軟件復位,開關中斷等功能。今后在需要的例程再去講解其程序,現在之所以提到,是因為它包含了一個重要的頭文件stdint.h。
7.2.4 stdint.h簡介
stdint.h是從c99中引進的一個標準C庫的文件。在2000年3月,ANSI 采納了 C99 標準。ANSI C被幾乎所有廣泛使用的編譯器(如:MDK、IAR)支持。多數C代碼是在ANSI C基礎上寫的。任何僅僅使用標準C并且沒有和任何硬件有依賴的代碼實際上能保證在任何平臺上用遵循C標準的編譯器編譯成功。就是說這套標準不依賴硬件,獨立于任何硬件,可以跨平臺。
stdint.h可以在MDK安裝目錄下找到,如MDK5安裝在C盤時,可以在路徑:C:\Keil_v5\ARM\ARMCC\include找到。stdint.h的作用就是提供了類型定義,其部分類型定義代碼如下:

/* exact-width signed integer types */ typedef signed char int8_t; typedef signed short int int16_t; typedef signed int int32_t; typedef signed __INT64 int64_t;/* exact-width unsigned integer types */ typedef unsigned char uint8_t; typedef unsigned short int uint16_t; typedef unsigned int uint32_t; typedef unsigned __INT64 uint64_t;

在今后的程序,我們都將會使用這些類型,比如:uint32_t(無符號整型)、int16_t等。

7.3 HAL庫框架結構

這一節我們將簡要分析一下HAL驅動文件夾下的驅動文件,
7.3.1 HAL庫文件夾結構
HAL庫頭文件和源文件在STM32Cube固件包的STM32H7xx_HAL_Driver文件夾中,打開該文件夾,如圖7.3.1.1所示。

圖7.3.1.1 STM32H7xx_HAL_Driver文件夾目錄結構
STM32H7xx_HAL_Driver文件夾下的Src(Source的簡寫)文件夾存放是所有外設的驅動程序源碼,Inc(Include的簡寫)文件夾存放的是對應源碼的頭文件。Release_Notes.html是HAL庫的版本更新信息。最后三個是庫的用戶手冊,這個需要可以去熟悉一下,查閱起來很方便。
打開Src和Inc文件夾,大家會發現基本都是stm32h7xx_hal_和stm32h7xx_ll_開頭的.c和
.h文件。剛學HAL庫的朋友可能會說,stm32h7xx_hal_開頭的是HAL庫,我能理解。那么stm32h7xx_ll_開頭的文件又是什么?stm32h7xx_ll_開頭的文件是前面介紹過的LL庫的文件。
7.3.2 HAL庫文件介紹
HAL庫關鍵文件介紹如下表7.3.2.1所示,表中ppp代表任意外設。

表7.3.2.1 HAL庫關鍵文件介紹
以上是HAL庫最常見的文件的列表,在Src/Inc下面還有Legacy文件夾,用于特殊外設的補充說明。我們的教程中用到的比較少,這里不展開描述。
不止文件命名有一定規則,stm32h7xx_hal_ppp (c/h)中的函數和變量命名也嚴格按照命名規則,如表7.3.2.2所示的命名規則在大部分情況下都是正確的:

表7.3.2.2 HAL庫函數、變量命名規則
對于HAL的API函數,常見的有以下幾種:
?初始化/反初始化函數:HAL_PPP_Init(), HAL_PPP_DeInit()
?外設讀寫函數:HAL_PPP_Read(),HAL_PPP_Write(),HAL_PPP_Transmit(),HAL_PPP_Receive()
?控制函數:HAL_PPP_Set (),HAL_PPP_Get ()
?狀態和錯誤:HAL_PPP_GetState (), HAL_PPP_GetError ()
HAL庫封裝的很多函數都是通過定義好的結構體將參數一次性傳給所需函數,參數也有一定的規律,主要有以下三種:
? 配置和初始化用的結構體
一般為PPP_InitTypeDef或PPP_ ConfTypeDef的結構體類型,根據外設的寄存器設計成易于理解和記憶的結構體成員。
? 特殊處理的結構體
專為不同外設而設置的,帶有“Process”的字樣,實現一些特異化的中間處理操作等。
? 外設句柄結構體
HAL驅動的重要參數,可以同時定義多個句柄結構以支持多外設多模式。HAL驅動的操作結果也可以通過這個句柄獲得。有些HAL驅動的頭文件中還定義了一些跟這個句柄相關的一些外設操作。如用外設結構體句柄與HAL定義的一些宏操作配合,即可實現一些常用的寄存器位操作。

表7.3.2.3 HAL庫驅動部分與外設句柄相關的宏
但對于SYSTICK/NVIC/RCC/FLASH/ GPIO這些內核外設或共享資源,不使用PPP_HandleTypedef這類外設句柄進行控制,如:HAL_GPIO_Init() 只需要初始化的GPIO編號和具體的初始化參數。
HAL_StatusTypeDef HAL_GPIO_Init (GPIO_TypeDef* GPIOx, GPIO_InitTypeDef Init)
{
/ GPIO 初始化程序…… */
}
最后要分享的是HAL庫的回調函數,這部分允許用戶重定義,并在其中實現用戶自定義的功能,也是我們使用HAL庫的最常用的接口之一:

表7.3.2.4 HAL庫驅動中常用的回調函數接口
至此,我們大概對HAL庫驅動文件的一些通用格式和命名規則有了初步印象,記住這些規則可以幫助我們快速對HAL庫的驅動進行歸類和判定這些驅動函數的用法。
ST官方給我們提供了快速查找API函數的幫助文檔。在路徑“STM32Cube_FW_H7 _V1.6.0\Drivers\STM32H7xx_HAL_Driver”下有幾個chm格式的文檔,根據我們開發板主控芯片STM32H750VBT6我們沒有找到直接可用的,但可以查看型號接近的:STM32H753xx_User _Manual.chm。雙擊打開后,可以看到左邊目錄下有四個主題,我們來查看Modules。以外設GPIO為例,講一下怎么使用這個文檔。點擊GPIO外設的主題下的IO operation functions /functions看看里面的API函數接口描述,如圖7.3.2.1所示。

圖7.3.2.1 文檔的API函數描述
這個文檔提供的信息很全,不看源碼都可以直接使用它來編寫代碼,還給我們指示源碼位置,非常方便。大家多翻一下其他主題了解一下文檔的信息結構,很容易使用。
下面舉個例子,比如我們要讓PB4輸出高電平。先看函數功能,HAL_GPIO_WritePin函數就是我們的GPIO口輸出設置函數。
函數有三個形參:
第一個形參是GPIO_TypeDef *GPIOx,形參描述說:x可以是A到K之間任何一個,而我們是PB4引腳,所以第一個形參確認是GPIOB。
第二個形參是uint16_t GPIO_Pin,看形參描述:該參數可以是GPIO_PIN_x,x可以1到15,那么我們第二個形參就是GPIO_PIN_4。
第三個形參是GPIO_PinState PinState,看形參描述:該參數可以是枚舉里的兩個數,一個是GPIO_PIN_RESET:表示該位清零,另一個是GPIO_PIN_SET:表示設置該位,即置1,我們要輸出1,所以要置1該位,那么我們第三個形參就是GPIO_PIN_SET。
最后看函數返回值:None,沒有返回值。
所以最后得出我們要調用的函數是:
HAL_GPIO_WritePin(GPIOB, GPIO_PIN_4, GPIO_PIN_SET);
文檔的使用就講到這。
7.4 如何使用HAL庫
我們要先知道STM32芯片的某個外設的性能和工作模式,才能借助HAL庫來幫助我們編程,甚至修改HAL庫來適配我們的開發項目。HAL庫的API雖多,但是查找和使用有規律可循,只要學會其中一個,其他的外設就是類似的,只是添加自己的特性的API而已。
7.4.1 學會用HAL庫組織開發工具鏈
需要按照芯片使用手冊建議的步驟去配置芯片。HAL庫驅動提供了芯片的驅動接口,但我們需要強調一個概念是使用HAL庫的開發是對芯片功能的開發,而不是開發這個庫,也不是由這個庫能就直接開發。如果我們對芯片的功能不作了解的話,仍然不知道按照怎樣的步驟和尋找哪些可用的接口去實現想要實現的功能。
ST提供芯片使用手冊《STM32H7xx參考手冊_V7(英文版).pdf》告訴我們使用某一外設功能時如何具體地去操作每一個用到的寄存器的細節,后面我們的例程講解過程也會結合這個手冊來分析配置過程。
嵌入式的軟件開發流程總遵循以下步驟:組織工具鏈、編寫代碼、生成可執行文件、燒錄到芯片、芯片根據內部指令執行我們編程生成的可執行代碼。
在HAL庫學習前期,建議以模仿和操作體驗為基礎,通過例程來學習如何配置和驅動外設。下面根據我們后續要學習的工程梳理出來的基于CMSIS的一個HAL庫應用程序文件結構,幫助讀者學習和體會這些文件的組成意義,如下表7.4.1.1所示。

表7.4.1.1基于CMSIS應用程序文件描述
把這些文件組織起來的方法,我們會在后續章節新建工程中介紹,這只提前告訴一下大家組成我們需要的編譯工具鏈大概需要哪些文件。
7.4.2 HAL庫的用戶配置文件
stm32h7xx_hal_conf.h用于裁剪HAL庫和定義一些變量,官方沒有直接提供這個文件,但在STM32Cube_FW_H7_V1.6.0\Drivers\STM32H7xx_HAL_Driver\Inc這個路徑下提供了一個模版文件《stm32h7xx_hal_conf_template.h》,我們可以直接復制這個文件重命名為stm32h7xx_ hal_conf.h,做一些簡單的修改即可,也可以從在官方的例程中直接復制過來。我們一般都直接從官方的模板例程中直接復制過來即可。因為我們的芯片是STM32H750系列,所以選擇的路徑是:STM32Cube_FW_H7_V1.6.0\Projects\STM32H750B-DK\Templates\Template_Project\ Inc。
(1)stm32h7xx_hal_conf.h文件里面的內容不多,對我們來說最重要的是HSE_VALUE這個參數,這個參數表示我們的外部高速晶振的頻率。這個參數請務必根據我們板子外部焊接的晶振頻率來修改,官方默認是25M。正點原子STM32H750MINI PRO開發板外部高速晶振的頻率是8MHZ。注意事項:我們要修改這個參數,源碼在99行,具體修改如下:

#if !defined (HSE_VALUE) #define HSE_VALUE ((uint32_t)8000000) /* 外部高速振蕩器的值,單位HZ */ #endif /* HSE_VALUE */

(2)還有一個參數就是外部低速晶振頻率,這個官方默認是32.768KHZ,我們開發板的低速晶振也是這個頻率,所以不用修改,源碼在128行。

#if !defined (LSE_VALUE)#define LSE_VALUE ((uint32_t)32768) /* 外部低速振蕩器的值,單位HZ */ #endif /* LSE_VALUE */

其他源碼都可以不作修改,按照默認的配置即可。下面我們再來了解一下其他程序。
(3)用戶配置文件可以用來選擇使能何種外設,源碼配置在37行到90行,代碼如下。

/* ########################## Module Selection ############################# */ /*** @brief This is the list of modules to be used in the HAL driver */ #define HAL_MODULE_ENABLED #define HAL_ADC_MODULE_ENABLED #define HAL_CEC_MODULE_ENABLED #define HAL_COMP_MODULE_ENABLED #define HAL_CORTEX_MODULE_ENABLED ...中間省略... #define HAL_UART_MODULE_ENABLED #define HAL_USART_MODULE_ENABLED #define HAL_WWDG_MODULE_ENABLED 我們只要屏蔽某個外設的宏,則這個外設的驅動代碼機會被屏蔽,從而不可用。比如我們屏蔽GPIO外設的宏,源碼在53行,屏蔽就是把這個宏注釋掉,具體如下。 #define HAL_GPIO_MODULE_ENABLED 然后打開stm32h7xx_hal_gpio.c文件,看到第118行。 #ifdef HAL_GPIO_MODULE_ENABLED #include "stm32h7xx_hal_gpio.h" #endif

這是一個條件編譯符,與#endif配合使用。這里的要表達的意思是,只要工程中定義了HAL_GPIO_MODULE_ENABLED這個宏,#ifdef到#endif之間的程序(119行到550行)就會參與編譯,否則不編譯。所以只要我們屏蔽了stm32h7xx_hal_conf.h文件53行的宏,GPIO的驅動代碼就不被編譯。也就起到選擇使能何種外設的功能,其他外設同理。
可以看官方的示范例程,就是通過屏蔽外設的宏的方法來選擇使能何種外設。好處就是編譯時間會變短,因為屏蔽了沒有用的程序,編譯時間自然就短了。正點原子的例程選擇另外一中方法,就是工程中只保留需要的stm32h7xx_hal_ppp.c,不需要的不添加到工程里,這樣編譯時間就不會太長。
(4)大家看到stm32h7xx_hal_conf.h文件的159行。
#define TICK_INT_PRIORITY ((uint32_t)0x0F) /*!< tick interrupt priority */
宏定義TICK_INT_PRIORITY是滴答定時器的優先級。這個優先級很重要,因為如果其它的外設驅動程序的延時是通過滴答定時器提供的時間基準,來實現延時的話,又由于實現方式是滴答定時器對寄存器進行計數,所以當我們在其它中斷服務程序里調用基于此時間基準的延遲函數 HAL_Delay,那么假如該中斷的優先級高于滴答定時器的優先級,就會導致滴答定時器中斷服務函數一直得不到運行,從而程序卡死在這里。所以滴答定時器的中斷優先級一定要比這些中斷高。
請注意這個時間基準可以是滴答定時器提供,也可以是其他的定時器,默認是用滴答定時器。
(5)下面說一下關于斷言這個功能,這個功能用來判斷函數的形參是否有效,在HAL庫的API里面有用到。這個功能的使能開關代碼是一個宏,在源碼的180行,默認是關閉的,代碼如下。

/* #define USE_FULL_ASSERT 1 */ 通過宏USE_FULL_ASSERT來選擇功能,在源碼413行到432,代碼如下。 /* Exported macro -----------------------------------------------------------*/ #ifdef USE_FULL_ASSERT /*** @brief The assert_param macro is used for function's parameters check.* @param expr: If expr is false, it calls assert_failed function* which reports the name of the source file and the source* line number of the call that failed. * If expr is true, it returns no value.* @retval None*/#define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__)) /* Exported functions ------------------------------------------------------ */void assert_failed(uint8_t* file, uint32_t line); #else#define assert_param(expr) ((void)0U) #endif /* USE_FULL_ASSERT */#ifdef __cplusplus } #endif#endif /* __STM32H7xx_HAL_CONF_H */

也是通過條件編譯符來選擇對應的功能。當用戶自己需要使用斷言功能,怎么做呢?首先需要定義宏USE_FULL_ASSERT來使能斷言功能,即把源碼的180行的注釋去掉即可。然后看到源碼423行的assert_failed()這個函數。其實這個函數是需要我們自己實現的,我們把這個函數定義在正點原子提供的sys.c文件里面。后面再跟大家講sys.c文件,現在我們把assert_failed()這個函數拿出來給大家先講,assert_failed()函數的定義在sys.c的176行到190行,具體如下:

#ifdef USE_FULL_ASSERT/*** @brief 當編譯提示出錯的時候此函數用來報告錯誤的文件和所在行* @param file:指向源文件* line:指向在文件中的行數* @retval 無*/ void assert_failed(uint8_t* file, uint32_t line) { while (1){} } #endif

可以看到這個函數里面沒有實現如何功能,就是一個什么不做的死循環,具體功能請根據自己的需求去實現。file是指向源文件的指針,line是指向源文件的行數。__FILE__是表示源文件名,__LINE__是表示在源文件中的行數。比如我們可以實現打印出這個錯誤的兩個信息等等。
總的來說斷言功能就是,在HAL庫中,如果定義了USE_FULL_ASSERT這個宏,那么所有的HAL庫函數將會檢查函數的形參是否正確。如果錯誤將會調用assert_failed()這個函數,這個函數我們默認是個什么事不做的死循環,用戶請根據自己的需求設計功能。使用斷言功能將會增加了代碼量,減慢運行速度等,所以一般只是在調試的時候用,正式發布的軟件是不推薦的。
7.4.3 stm32h7xx_hal.c文件
這個文件內容比較多,包括HAL庫的初始化、系統滴答、基準電壓配置、IO補償、低功耗、EXTI配置等都集合在這個文件里面。下面我們對該文件進行講解。

  • HAL_Init()函數
    源碼在134行到172行,簡化函數如下:
  • HAL_StatusTypeDef HAL_Init(void) {/* 設置中斷優先級分組 */HAL_NVIC_SetPriorityGrouping(NVIC_PRIORITYGROUP_4);/* 使用滴答定時器作為時鐘基準,配置1ms滴答(重置后默認的時鐘源為HSI) */if(HAL_InitTick(TICK_INT_PRIORITY) != HAL_OK){return HAL_ERROR;}/* 初始化硬件 */HAL_MspInit();/* 返回函數狀態 */return HAL_OK; }

    該函數是HAL庫的初始化函數,在程序中必須優先調用,其主要實現如下功能:
    1)設置NVIC優先級分組為4。
    2)配置滴答定時器每1ms產生一個中斷。
    3)在這個階段,系統時鐘還沒有配置好,因此系統還是默認使用內部高速時鐘源HSI在跑程序。對于H7來說,HSI的主頻是64MHZ。所以如果用戶不配置系統時鐘的話,那么系統將會使用HIS作為系統時鐘源。
    4)調用HAL_MspInit函數初始化底層硬件,HAL_MspInit函數在stm32h7xx_hal.c文件里面做了弱定義。關于弱定義這個概念,后面會有講解,現在不理解沒關系。正點原子的HAL庫例程是沒有使用到這個函數去初始化底層硬件,而是單獨調用需要用到的硬件初始化函數。用戶可以根據自己的需求選擇是否重新定義該函數來初始化自己的硬件。
    注意事項:
    為了方便和兼容性,正點原子的HAL庫例程中的中斷優先級分組設置為分組2,即把源碼的145行改為如下代碼:
    HAL_NVIC_SetPriorityGrouping(NVIC_PRIORITYGROUP_2);
    中斷優先級分組為2,也就是2位搶占優先級,2位響應優先級,搶占優先級和響應優先級的值的范圍均為0-3。

    2. HAL_DeInit ()函數

    源碼在179行到214行,函數如下:

    HAL_StatusTypeDef HAL_DeInit(void) {/* 復位所有外設 */__HAL_RCC_AHB3_FORCE_RESET();__HAL_RCC_AHB3_RELEASE_RESET();__HAL_RCC_AHB1_FORCE_RESET();__HAL_RCC_AHB1_RELEASE_RESET();__HAL_RCC_AHB2_FORCE_RESET();__HAL_RCC_AHB2_RELEASE_RESET();__HAL_RCC_AHB4_FORCE_RESET();__HAL_RCC_AHB4_RELEASE_RESET();__HAL_RCC_APB3_FORCE_RESET();__HAL_RCC_APB3_RELEASE_RESET();__HAL_RCC_APB1L_FORCE_RESET();__HAL_RCC_APB1L_RELEASE_RESET();__HAL_RCC_APB1H_FORCE_RESET();__HAL_RCC_APB1H_RELEASE_RESET();__HAL_RCC_APB2_FORCE_RESET();__HAL_RCC_APB2_RELEASE_RESET();__HAL_RCC_APB4_FORCE_RESET();__HAL_RCC_APB4_RELEASE_RESET();/* 對底層硬件初始化進行復位 */HAL_MspDeInit();/* 返回函數狀態 */return HAL_OK; }

    該函數取消初始化HAL庫的公共部分,并且停止systick,是一個可選的函數。該函數做了一下的事:
    1)復位了AHB1、AHB2、AHB3、AHB4、APB1L、APB1H、APB2、APB3、APB4的時鐘。
    2)調用HAL_MspDeInit函數,對底層硬件初始化進行復位。HAL_MspDeInit也在stm32h7xx _hal.c文件里面做了弱定義,并且與HAL_MspInit函數是一對存在。HAL_MspInit函數負責對底層硬件初始化,HAL_MspDeInit函數則是對底層硬件初始化進行復位。這兩個函數都是需要用戶根據自己的需求去實現功能,也可以不使用。

    3. HAL_InitTick ()函數

    源碼在254行到302行,簡化函數如下:

    __weak HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority) {/* uwTickFreq是個枚舉類型,如果檢測到uwTickFreq為零,則返回 */if((uint32_t)uwTickFreq == 0UL){return HAL_ERROR;}/* 配置滴答定時器1ms產生一次中斷 */if (HAL_SYSTICK_Config(SystemCoreClock /(1000UL / (uint32_t)uwTickFreq))> 0U){return HAL_ERROR;} #endif/* 配置滴答定時器中斷優先級 */if (TickPriority < (1UL << __NVIC_PRIO_BITS)){HAL_NVIC_SetPriority(SysTick_IRQn, TickPriority, 0U);uwTickPrio = TickPriority;}else{return HAL_ERROR;}/* 返回函數狀態 */return HAL_OK; }

    該函數用于初始化滴答定時器的時鐘基準,主要功能如下:
    1)配置滴答定時器1ms產生一次中斷。
    2)配置滴答定時器的中斷優先級。
    3)該函數是__weak定義的“弱函數”,用戶可以重新定義該函數。
    該函數可以通過HAL_Init()或者HAL_RCC_ClockConfig()重置時鐘。在默認情況下,滴答定時器是時間基準的來源。如果其他中斷服務函數調用了HAL_Delay(),必須小心,滴答定時器中斷必須具有比調用了HAL_Delay()函數的其他中斷服務函數的優先級高(數值較低),否則會導致滴答定時器中斷服務函數一直得不到執行,從而卡死在這里。

    4. 滴答定時器相關的函數

    源碼在331行到463行,相關函數如下:
    /* 該函數在滴答定時器時鐘中斷服務函數中被調用,一般滴答定時器1ms中斷一次,
    所以函數每1ms讓全局變量uwTick計數值加1 */

    __weak void HAL_IncTick(void) {uwTick += (uint32_t)uwTickFreq; }/* 獲取全局變量uwTick當前計算值 */ __weak uint32_t HAL_GetTick(void) {return uwTick; }/* 獲取滴答時鐘優先級 */ uint32_t HAL_GetTickPrio(void) {return uwTickPrio; }/* 設置滴答定時器中斷頻率 */ HAL_StatusTypeDef HAL_SetTickFreq(HAL_TickFreqTypeDef Freq) {HAL_StatusTypeDef status = HAL_OK;HAL_TickFreqTypeDef prevTickFreq;assert_param(IS_TICKFREQ(Freq));if (uwTickFreq != Freq){/* 備份滴答定時器中斷頻率 */prevTickFreq = uwTickFreq;/* 更新被HAL_InitTick()調用的全局變量uwTickFreq */uwTickFreq = Freq;/* 應用新的滴答定時器中斷頻率 */status = HAL_InitTick(uwTickPrio);if (status != HAL_OK){/* 恢復之前的滴答定時器中斷頻率 */uwTickFreq = prevTickFreq;}}return status; }/* 獲取滴答定時器中斷頻率 */ HAL_TickFreqTypeDef HAL_GetTickFreq(void) {return uwTickFreq; }/*HAL庫的延時函數,默認延時單位ms */ __weak void HAL_Delay(uint32_t Delay) {uint32_t tickstart = HAL_GetTick();uint32_t wait = Delay;/* Add a freq to guarantee minimum wait */if (wait < HAL_MAX_DELAY){wait += (uint32_t)(uwTickFreq);}while ((HAL_GetTick() - tickstart) < wait){} }/* 掛起滴答定時器中斷,全局變量uwTick計數停止 */ __weak void HAL_SuspendTick(void) {/* 禁止滴答定時器中斷 */SysTick->CTRL &= ~SysTick_CTRL_TICKINT_Msk; }/* 恢復滴答定時器中斷,恢復全局變量uwTick計數 */ __weak void HAL_ResumeTick(void) {/* 使能滴答定時器中斷 */SysTick->CTRL |= SysTick_CTRL_TICKINT_Msk; }

    這些函數不是很難,請參照注釋理解。注意:如果函數被前綴__weak定義,則用戶可以重新定義該函數。更多的內容可以參考8.1.5小節。

    5. HAL庫版本相關的函數

    源碼在465行到517行,相關函數聲明如下:

    uint32_t HAL_GetHalVersion(void); /* 獲取HAL庫驅動程序版本 */ uint32_t HAL_GetREVID(void); /* 獲取設備修訂標識符 */ uint32_t HAL_GetDEVID(void); /* 獲取設備標識符 */ uint32_t HAL_GetUIDw0(void); /* 獲取唯一設備標識符的第一個字 */ uint32_t HAL_GetUIDw1(void); /* 獲取唯一設備標識符的第二個字 */ uint32_t HAL_GetUIDw2(void); /* 獲取唯一設備標識符的第三個字 */

    這些函數了解一下就好了,用得不多。
    6. 芯片內部電壓基準相關函數
    源碼在519行到602行,函數聲明如下:

    void HAL_SYSCFG_VREFBUF_VoltageScalingConfig(uint32_t VoltageScaling); void HAL_SYSCFG_VREFBUF_HighImpedanceConfig(uint32_t Mode); void HAL_SYSCFG_VREFBUF_TrimmingConfig(uint32_t TrimmingValue); HAL_StatusTypeDef HAL_SYSCFG_EnableVREFBUF(void); void HAL_SYSCFG_DisableVREFBUF(void);

    HAL_SYSCFG_VREFBUF_VoltageScalingConfig函數用于配置芯片內部電壓基準大小,形參有四個值可以選擇:
    1)當形參為SYSCFG_VREFBUF_VOLTAGE_SCALE0時,
    電壓輸出基準為2.048V,條件是VDDA >= 2.4V。
    2)當形參為SYSCFG_VREFBUF_VOLTAGE_SCALE1時,
    電壓輸出基準為2.5V,條件是VDDA >= 2.8V。
    3)當形參為SYSCFG_VREFBUF_VOLTAGE_SCALE2時,
    電壓輸出基準為1.5V,條件是VDDA >= 1.8V。
    4)當形參為SYSCFG_VREFBUF_VOLTAGE_SCALE3時,
    電壓輸出基準為1.8V,條件是VDDA >= 2.1V。
    HAL_SYSCFG_VREFBUF_HighImpedanceConfig函數用于配置芯片內部電壓是否與VREF+引腳連接,即是否選擇高阻抗模式,有兩個形參選擇:
    1)當形參為SYSCFG_VREFBUF_HIGH_IMPEDANCE_DISABLE,表示導通。
    2)當形參為SYSCFG_VREFBUF_HIGH_IMPEDANCE_ENABLE,表示高阻抗,即不導通。
    HAL_SYSCFG_VREFBUF_TrimmingConfig函數用于調整校準內部電壓基準。
    HAL_SYSCFG_EnableVREFBUF函數用于使能內部電壓基準參考。
    HAL_SYSCFG_DisableVREFBUF函數用于禁止內部電壓基準參考。
    7. 以太網PHY接口選擇函數
    源碼在605行到619行,函數聲明如下:
    void HAL_SYSCFG_ETHInterfaceSelect(uint32_t SYSCFG_ETHInterface);
    該函數用于以太網PHY接口的選擇,可以是MII或RMII接口。
    8. HAL_SYSCFG_AnalogSwitchConfig()函數
    源碼在622行到650行,函數聲明如下:
    void HAL_SYSCFG_AnalogSwitchConfig(uint32_t SYSCFG_AnalogSwitch ,
    uint32_t SYSCFG_SwitchState );
    當PA0、PA1、PC2、PC3引腳復用為ADC的時候,還有一組對應的可選引腳PA0_C、PA1_C、PC2_C、PC3_C。該函數的作用就是切換這些可選的引腳。關于這個不理解,請參考圖7.4.3.1。該函數操作了SYSCFG_PMCR寄存器,關于該寄存器請查閱參考手冊。

    圖7.4.3.1 連接到ADC輸入的模擬輸入
    9. Booster的使能和禁止函數(用于ADC)
    源碼在653行到676行,函數聲明如下:
    void HAL_SYSCFG_EnableBOOST(void); /* 使能Booster /
    void HAL_SYSCFG_DisableBOOST(void); / 禁止Booster */
    如果使能Booster,當供電電壓低于2.7V時,能夠減少模擬開關總的諧波失真。這樣就使得模擬開關的性能和供電正常的情況時一樣,能夠正常工作。
    10. HAL_SYSCFG_CM7BootAddConfig()函數
    源碼在680行到712行,函數如下:
    void HAL_SYSCFG_CM7BootAddConfig(uint32_t BootRegister, uint32_t BootAddress)
    該函數用于配置程序啟動模式,BOOT=0或者BOOT=1,來選擇啟動地址。詳細的內容請看第九章的9.1小節。
    11. IO補償、低功耗、EXTI等相關函數
    IO補償、低功耗、EXTI等相關函數,這里先不進行講解了,后面用到再進行說明。
    7.4.4 HAL庫中斷處理
    中斷是STM32開發的一個很重要的概念,這里我們可以簡單地理解為:STM32暫停了當前手中的事并優先去處理更重要的事務。而這些“更重要的事務”是由軟件開發人員在軟件中定義的。關于STM32中斷的概念,我們會在中斷例程的講解再跟大家詳細介紹。
    由于HAL庫中斷處理的邏輯比較統一,我們將這個處理過程抽象為圖7.4.4.1所表示的業務邏輯:

    圖7.4.4.1 HAL驅動中斷處理流程
    結合以前的HAL庫文件介紹章節,以上的流程大概就是:設置外設的控制句柄結構體PPP_HandleType和初始化PPP_InitType結構體的參數,然后調用HAL庫對應這個驅動的初始化HAL_PPP_Init(),由于這個API中有針對外設初始化細節的接口Hal_PPP_Mspinit(),我們需要重新實現這個函數并完成外設時鐘、IO等細節差異的設置, 完成各細節處理后,使用HAL_NVIC_SetPriority()、HAL_NVIC_EnableIRQ()來使能我們的外設中斷;定義中斷處理函數PPP_IRQHandler,并在中斷函數中調用HAL_ppp_function_IRQHandler()來判斷和處理中斷標記; HAL庫中斷處理完成后,根據對應中的調用我們需要自定義的中斷回調接口HAL_ PPP_ProcessCpltCallback();如串口接收函數HAL_UART_RxCpltCallback(),我們在這個函數中實現我們對串口接收數據想做的處理;中斷響應處理完成后,stm32芯片繼續順序執行我們定義的主程序功能,按照以上處理的標準流程完成了一次中斷響應。
    7.4.5 正點原子對HAL庫用法的個性化修改
    前面按ST官方建議的HAL庫的使用方法給介紹了一個HAL庫。
    1、將中斷處理函數獨立到每個外設中,便于獨立驅動;同類型的外設驅動處理函數不使用HAL回調函數接口處理操作而直接在中斷函數中處理判斷對應中斷。
    2、我們把原來的中斷分組進行了修改,由搶占式無子優先級改為中斷分組2;便于管理同類外設的優先級響應。
    3、在很多芯片的初始化過程中,我們使用到了delay_ms()、delay_us()等函數進行初始化,使用的是Systick作的精準延時,而HAL庫默認也使用Systick作延時處理,為解決這種沖突和兼容我們大部分的驅動代碼,我們在例程中使用delay.c中的延時函數取代Hal_Delay();取消原來HAL庫的Systick延時設置。

    7.5 HAL庫使用注意事項

    本小節根據經驗跟大家講述一些關于HAL庫使用的注意事項,供讀者參考。
    1、即使我們已經在使用庫函數作為開發工具了,我們可以忽略很多芯片的硬件外設使用上的細節,但當發生問題時,我們仍需要回歸到芯片使用手冊查看當前操作是否違規或缺漏。
    2、使用HAL庫和其它第三方的庫開發類似,把我們需要編寫的軟件和第三方的庫分開成相互獨立的文件,開發過程中我們盡量不去修改第三方的軟件源碼,需要修改的部分盡量在自己的代碼中實現;這樣一旦我們需要更新第三方庫時,我們原來編寫的功能也能很快地匹配新的庫去執行功能。
    3、即使HAL庫目前較以前已經相對更完善了,但它仍無法覆蓋我們要想實現的所有細節功能,甚至可能存在錯誤,我們要有懷疑精神,辯證地去使用好這個工具;如我們在PWM一節編碼時發現HAL庫中有個宏定義TIM_RESET_CAPTUREPOLARITY括號不匹配導致編譯報錯,這時我們不得不修改一下HAL庫的源碼了。
    4、注意HAL庫的執行效率。由于HAL庫的驅動對相同外設大多是可重入的,在執行HAL驅動的API函數的效率沒有直接寄存器操作來得高,如果在對時序要求比較嚴苛的代碼,建議使用簡潔的寄存器操作代替。
    5、我們在例程中使用delay.c中的延時函數取代Hal_Delay();取消原來HAL庫的Systick延時設置;但這會有一個問題:原來HAL庫的超時處理機制不再適用,所以對于設置了超時的函數,可能會導致停留在這個函數的處理中,無法按正常的超時退出。

    總結

    以上是生活随笔為你收集整理的【正点原子STM32连载】第七章 认识HAL库 摘自【正点原子】MiniPro STM32H750 开发指南_V1.1的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    日韩黄色免费看 | 成人黄色av免费在线观看 | 国产 字幕 制服 中文 在线 | a v在线视频 | 最新超碰在线 | 人人干在线观看 | 国产精品久久久久久久免费大片 | 久久国产精品小视频 | 五月视频 | 高清不卡一区二区三区 | 日韩性色| 91九色蝌蚪视频网站 | 日本mv大片欧洲mv大片 | 日本精品久久久久中文字幕 | 在线高清av | 麻豆一精品传二传媒短视频 | 波多野结衣在线视频一区 | 免费观看v片在线观看 | 亚洲少妇激情 | 成人一级电影在线观看 | 国产一区在线看 | www.一区二区三区 | 最近日本韩国中文字幕 | 国产伦理一区二区三区 | 不卡电影免费在线播放一区 | 一区在线播放 | 亚洲精品久久久久久国 | 国产一二区免费视频 | 中文字幕免费国产精品 | 亚洲视屏在线播放 | 婷婷综合激情 | 中文电影网 | 日韩毛片一区 | 99精品国产99久久久久久97 | 亚洲欧美怡红院 | 亚洲欧洲成人精品av97 | 欧美日韩色婷婷 | 日韩在线免费观看视频 | 天天爽网站 | 亚洲日本欧美在线 | 91香蕉国产 | 欧美日韩在线免费观看 | 欧美一区在线观看视频 | av黄色在线播放 | 久久精品视频在线 | 曰韩在线| 色噜噜噜噜 | 丰满少妇在线观看网站 | 九色琪琪久久综合网天天 | 91av在线看| 97国产人人| 国产亚洲视频在线 | 成人久久亚洲 | 精品在线播放 | 成人免费视频播放 | 精品一区二区免费 | 久久久久久国产精品 | 99久久精品免费看国产四区 | 久久99久久99免费视频 | 国产激情小视频在线观看 | 国产一级特黄电影 | 福利视频一二区 | 日本久久久久久久久久 | 欧美精品日韩 | 精品久久久久久综合日本 | 国产一二三四在线观看视频 | 日本精油按摩3 | 欧美在线视频免费 | 91手机视频在线 | 久99视频 | 麻豆国产网站入口 | 色综合久久久久久久 | 亚洲黄色免费电影 | www.色五月.com | 久久久久国产成人免费精品免费 | 日本中文字幕在线观看 | 国产精品美女免费视频 | 最新日韩在线观看视频 | 免费美女久久99 | 国产成人三级 | 18岁免费看片 | 亚洲精品国产精品乱码在线观看 | 日本久久精品 | 97看片网| 国产色视频一区 | 在线观看v片| 69国产盗摄一区二区三区五区 | 91精品国产91 | 高清精品久久 | 五月激情在线 | 亚洲一级国产 | 亚洲综合欧美精品电影 | 日韩久久精品一区二区三区下载 | 97超碰精品 | 奇米影视四色8888 | 人人爽人人爽人人爽 | 国产一线二线三线在线观看 | 福利一区在线视频 | 国精产品999国精产 久久久久 | 日日草天天干 | 99久热在线精品视频 | 91麻豆精品国产91久久久更新时间 | 国内丰满少妇猛烈精品播 | 久久成人综合 | 久草免费色站 | 日韩中文字幕免费在线观看 | 成年人在线观看免费视频 | 欧美俄罗斯性视频 | 国产成人一区二区在线观看 | 亚洲日本国产精品 | 国产免费久久av | 91成人精品国产刺激国语对白 | 亚洲精品乱码久久久久 | 国产在线色视频 | 亚洲综合色丁香婷婷六月图片 | 日韩免费视频在线观看 | 久久精品男人的天堂 | 九月婷婷色 | 亚洲精品一区二区三区四区高清 | 人人插人人舔 | 国产成人av电影在线 | 亚洲伊人天堂 | 99热这里是精品 | 天天射综合 | 粉嫩aⅴ一区二区三区 | 亚洲精品一区二区三区新线路 | 亚洲精品日韩av | 国产亚洲视频在线 | 欧美激情奇米色 | 91精品999| 五月情婷婷 | 99久久影视 | 国内久久视频 | 中文字幕免费观看 | 久草精品视频 | 在线看片一区 | 性色av一区二区三区在线观看 | 蜜臀久久99精品久久久无需会员 | 欧美激情综合五月色丁香小说 | 国产精品久久久久久久av电影 | 极品美女被弄高潮视频网站 | 久久免费视频精品 | 一区二区视频电影在线观看 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 国产福利不卡视频 | 久久国产免 | 亚洲五月综合 | 在线观看免费日韩 | 免费在线播放黄色 | 免费特级黄毛片 | 蜜臀久久99精品久久久无需会员 | 日本精品久久久一区二区三区 | 日韩综合一区二区三区 | 日韩视频免费观看高清完整版在线 | 高清一区二区三区av | 99精品久久久久久久 | 精品国产一区二区在线 | 久久超碰网 | 中文字幕在线网址 | 国产1区2区 | 日韩动漫免费观看高清完整版在线观看 | 久久久天天操 | 免费在线播放av电影 | 国产精品美女久久久久aⅴ 干干夜夜 | 2018亚洲男人天堂 | 久久综合五月天 | 日韩精品一卡 | 人人爽人人 | 国产在线免费观看 | 中文字幕 91 | 午夜久久影院 | 免费观看黄色12片一级视频 | 欧美色伊人 | 午夜久久视频 | 久久久久久久久久久久av | 国产一级视频在线免费观看 | 天天超碰| 探花视频免费观看 | 成人精品久久久 | 欧美午夜理伦三级在线观看 | 在线成人一区 | 中文字幕专区高清在线观看 | 国产区在线视频 | 国产精品久久久久久久久久久杏吧 | av网站在线免费观看 | 精品久久一 | 亚洲午夜久久久久久久久 | 亚洲国产精品电影在线观看 | 亚洲午夜精品福利 | 欧美一级特黄高清视频 | 97在线观看视频国产 | 亚洲黄色av| 亚洲高清视频一区二区三区 | 亚洲女同ⅹxx女同tv | 国产精品久久伊人 | 爱射综合| 日韩毛片在线一区二区毛片 | 中日韩免费视频 | 久久香蕉国产精品麻豆粉嫩av | 免费视频你懂的 | 久久国产色 | 亚洲高清在线观看视频 | 美女网站久久 | 日韩一区二区三区视频在线 | 婷婷资源站 | av黄在线播放 | 国产精品女同一区二区三区久久夜 | 日韩中文在线电影 | 中文字幕一二三区 | 在线黄网站 | 美女黄网久久 | 国产精品大片免费观看 | 久久久三级视频 | 伊人婷婷激情 | 亚洲激情久久 | 黄色91在线| 国产成人一区二区三区在线观看 | 久久精品久久精品久久 | 色婷婷久久 | 色综合天天视频在线观看 | 免费在线黄色av | 丁香婷婷综合激情五月色 | 成人免费一级 | 亚洲欧美日韩精品久久奇米一区 | 国产成人av电影在线观看 | 超碰97人人在线 | 亚洲精品在线资源 | 国产69久久 | 日本中文字幕观看 | 波多野结衣一区 | 天天操天天色天天射 | 日本久久久精品视频 | 激情影音 | 成年人看片网站 | av在线之家电影网站 | 99久久精品国产欧美主题曲 | 国产精品一区一区三区 | 婷婷香蕉 | av解说在线观看 | 国产精品 国产精品 | 成人av资源| 美女搞黄国产视频网站 | 成年人视频在线免费 | 韩国一区二区在线观看 | 97日日 | 久久公开免费视频 | 精品久久久久久久久久久院品网 | 国内精品免费久久影院 | 欧美日韩国产二区 | 最新av电影网站 | 美女免费视频网站 | 中文在线天堂资源 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产91丝袜在线播放动漫 | 摸阴视频 | 视频三区| www.夜夜骑.com | 日韩美在线 | 国产精品国产三级国产专区53 | 久草在线播放视频 | 一二三四精品 | 亚洲va韩国va欧美va精四季 | 国产日韩欧美精品在线观看 | 欧美激情精品久久久久久免费 | 狠狠色婷婷丁香六月 | 九色最新网址 | 96精品高清视频在线观看软件特色 | 国产精品免费一区二区三区在线观看 | 久久99久久99免费视频 | 欧美另类老妇 | 亚洲最新av | 午夜美女av | 在线免费黄色片 | 国产精品永久免费观看 | 最新av在线网站 | 久久久久日本精品一区二区三区 | 美女视频黄在线观看 | 欧美aaa视频 | www五月婷婷 | 丁香婷婷久久 | 国产精品美女在线观看 | 中文字幕亚洲欧美日韩 | 久久狠狠亚洲综合 | 天天干天天干天天射 | 久久久精选 | 911精品美国片911久久久 | av一区二区三区在线播放 | 久久精品这里精品 | 日本黄色大片免费看 | 中文字幕精品在线 | 97超碰福利久久精品 | 91久久人澡人人添人人爽欧美 | 日本精品视频在线播放 | 久热香蕉视频 | 日本中文字幕在线免费观看 | 亚洲精品一区二区三区新线路 | 五月天激情视频在线观看 | 九九久久久 | 日韩久久精品 | 国产乱视频 | 亚洲片在线资源 | 欧美日韩一区二区三区在线观看视频 | 婷婷视频在线观看 | 免费91麻豆精品国产自产在线观看 | 久久久免费观看视频 | 色综合天天综合在线视频 | 久草在线这里只有精品 | 美州a亚洲一视本频v色道 | 永久免费看av | 日韩中文字幕免费视频 | 久久不卡av | 国产精品 日韩 欧美 | www狠狠| 伊人婷婷在线 | 黄色视屏在线免费观看 | 日韩理论电影在线 | 日韩区在线观看 | 中文字幕国产精品一区二区 | 国产精品入口麻豆www | 精品国产一区二区三区久久久蜜月 | 亚洲日韩中文字幕在线播放 | 在线成人免费av | 天天插天天色 | 欧美精品三级在线观看 | 天天色视频 | 午夜免费福利片 | 西西444www大胆高清图片 | 日韩高清 一区 | 日韩一级电影在线 | 日本精油按摩3 | 色婷婷国产 | 午夜国产福利在线 | 国产黄色精品 | a v在线观看 | 国产中文字幕在线观看 | 久久久www成人免费精品张筱雨 | 99国产一区二区三精品乱码 | www.com.日本一级 | 色婷婷国产 | 96亚洲精品久久久蜜桃 | 日韩欧美高清视频在线观看 | 成人av在线看 | 国产视频一区精品 | 国产精品美女久久久久久网站 | 久久经典国产视频 | 国内精品视频在线 | 亚洲精品国产拍在线 | av成人在线电影 | 在线亚洲天堂网 | 精品国产乱码一区二 | 国产一区黄色 | 天天干天天操天天 | 激情www| 日日激情| 国产精品入口麻豆www | 97在线观看免费观看 | 国产不卡毛片 | 成人va天堂| 偷拍精偷拍精品欧洲亚洲网站 | 久草精品视频 | 日韩有码中文字幕在线 | 成人黄色短片 | 色多多视频在线 | 成年在线观看 | 97电影手机 | 国产 在线 高清 精品 | 精品视频在线免费观看 | www黄色 | 亚洲狠狠干 | 久久久久国产a免费观看rela | 久久久在线 | 中文字幕在线免费看 | 欧美性生爱 | 五月婷婷六月丁香 | www色com | 日韩欧美电影网 | www在线免费观看 | 成人夜晚看av | 黄色三级在线看 | 美女免费视频网站 | 国产免费叼嘿网站免费 | 99久久这里有精品 | 在线观看亚洲国产 | 色婷婷综合久久久久 | 国产91精品高清一区二区三区 | 国产不卡免费视频 | 亚洲理论在线 | 超碰在线人人97 | 又大又硬又黄又爽视频在线观看 | 午夜性生活片 | 五月天久久婷 | 欧美性色综合网站 | 久久精美视频 | 久久人人爽人人爽人人 | 国产一区二区三区在线免费观看 | 日韩在线视频观看免费 | 四虎在线观看视频 | 99久久精品国产观看 | 日韩电影在线观看一区二区三区 | 国产精品嫩草影视久久久 | 欧美婷婷综合 | 丰满少妇在线观看资源站 | 国产精品成人一区二区三区 | 啪啪资源| 中文字幕在线日亚洲9 | 在线国产激情视频 | 91女子私密保健养生少妇 | 久久这里只有精品首页 | 久久久精选 | 亚州成人av在线 | 9在线观看免费 | av解说在线观看 | 中文字幕av免费在线观看 | 五月天久久久久久 | 久久歪歪 | 久久99精品视频 | 视频 天天草 | 国产在线91在线电影 | 亚洲五月花 | 丁香六月久久综合狠狠色 | 激情丁香综合五月 | 午夜av不卡 | 亚洲成a人片在线www | 国产香蕉av | 亚洲一二三久久 | 婷婷在线视频 | 国产成人精品一区在线 | 久久超碰免费 | 亚洲色五月 | 波多野结衣在线视频免费观看 | 国产精品麻豆91 | 中文字幕亚洲在线观看 | 精品久久一 | 色5月婷婷| 奇米网8888| 深夜免费福利 | 欧美人操人| 久久伦理 | 国产精品99页 | 国产精品久久久久久电影 | 亚洲首页 | 久久爱资源网 | 波多野结依在线观看 | 综合中文字幕 | 亚洲国产精品视频在线观看 | 99精品免费在线观看 | 国产精品第一 | 欧美 激情 国产 91 在线 | 一区二区激情 | av在线播放一区二区三区 | 韩国三级在线一区 | 免费网站在线观看人 | 久久草视频 | av在线永久免费观看 | 激情小说网站亚洲综合网 | 日韩91在线 | 香蕉影院在线播放 | 欧美亚洲xxx | 久久久久久久久久久影视 | 久久不射网站 | 在线有码中文字幕 | 免费在线观看国产黄 | 欧美91精品久久久久国产性生爱 | www.黄色网.com | 国产精品爽爽久久久久久蜜臀 | 国产专区视频在线观看 | 成人亚洲精品国产www | 国产日韩欧美综合在线 | 亚洲精品9 | 丁香五月网久久综合 | 国产精品一区二区久久久 | 中文字幕在线观看视频一区二区三区 | 蜜臀av.com | 九草视频在线 | 免费国产黄线在线观看视频 | 国产成人久久久77777 | 91成人精品视频 | 婷婷激情综合五月天 | 欧美韩国在线 | 91在线文字幕 | a电影免费看 | 曰本三级在线 | 天天在线视频色 | 国内一级片在线观看 | 色婷婷影视 | 日本久久99| 精品国产伦一区二区三区 | 欧美日韩视频观看 | 亚洲视频高清 | 一区二区三区四区久久 | 亚洲 欧洲 国产 日本 综合 | 久久激情婷婷 | 欧美一级电影片 | 日日夜夜添 | 婷婷 综合 色 | 久久精品国产一区 | 中文字幕一区二区在线观看 | 久久免费看视频 | 国产人成在线观看 | 亚洲午夜精| 欧美日韩高清不卡 | 国产精品视频久久久 | 亚洲2019精品| 一区二区三区四区精品视频 | 日本资源中文字幕在线 | 99精品一区| 一区二精品 | 中文在线a∨在线 | 国产精品一区二区三区免费视频 | 一区二区高清在线 | 中文字幕av在线免费 | 成人午夜片av在线看 | 久久精品专区 | 2019av在线视频 | 亚洲欧洲精品一区 | 99re6热在线精品视频 | 国产不卡片 | 亚洲天堂社区 | 免费黄色看片 | 91精品一区二区三区久久久久久 | 亚洲免费精品视频 | 欧美日韩在线观看一区二区三区 | 精品日韩中文字幕 | 国产精品欧美 | 午夜18视频在线观看 | 黄色网在线免费观看 | 18pao国产成视频永久免费 | 一区二区三区久久 | 国产精品美女在线观看 | 中文一二区 | 欧美性极品xxxx做受 | 日韩在线免费高清视频 | 99c视频高清免费观看 | 视频一区二区三区视频 | 久久久影片 | a级成人毛片 | 国内三级在线 | 亚洲 欧美 成人 | 最近中文字幕免费av | 久久综合九色欧美综合狠狠 | 欧洲色综合 | 人人澡人摸人人添学生av | 成人黄色小视频 | 欧美a级一区二区 | a黄色| 亚洲男模gay裸体gay | 国产精品乱看 | 中文字幕4| 久久69精品| 国产精品一区二区三区电影 | 久色免费视频 | 久久久久久99精品 | 中文在线a√在线 | 激情五月亚洲 | 91精品国自产在线偷拍蜜桃 | 国产在线观看地址 | 国产手机在线 | 美女黄频在线观看 | 久久久伊人网 | 久久久 激情 | 婷婷射五月 | 在线免费观看欧美日韩 | 色视频网站免费观看 | 日韩精品在线观看视频 | 日韩激情影院 | 日韩久久一区二区 | 国产黄色片免费在线观看 | 天天摸日日操 | 亚洲精品在线观看免费 | 日韩美女免费线视频 | 日韩视频精品在线 | 天天干夜夜干 | 久久综合中文色婷婷 | 男女全黄一级一级高潮免费看 | 欧美日本三级 | 五月天狠狠操 | 五月激情久久久 | 91cn国产在线| 中文字幕最新精品 | 国产精品久久艹 | 精品毛片在线 | 91久久精| 五月宗合网 | 99国产精品视频免费观看一公开 | 成年人免费看 | 在线日本看片免费人成视久网 | 黄色国产在线观看 | 亚洲欧洲成人 | 超碰个人在线 | 日韩电影中文字幕在线观看 | 久久精品一二三区 | 91aaa在线观看 | 日韩精品播放 | 五月天综合网站 | 欧美福利片在线观看 | 国产免费叼嘿网站免费 | 免费看一级黄色 | 99精品久久99久久久久 | av中文电影| 在线观看的a站 | 久久手机免费观看 | 天天综合人人 | a视频在线观看免费 | 天天草天天摸 | 日韩精品一区电影 | а天堂中文最新一区二区三区 | 99久久精品国产系列 | 国产精品福利小视频 | 日韩精品一区二区在线观看视频 | 亚洲人成人在线 | 亚洲国产人午在线一二区 | 在线免费国产视频 | 日韩肉感妇bbwbbwbbw | 久久久精品 一区二区三区 国产99视频在线观看 | 91精品国产92久久久久 | 欧美一级高清片 | 在线亚洲播放 | 日韩黄色一区 | 99国产精品一区 | 国产视频一二区 | 蜜桃视频精品 | 一区二区视频在线看 | 成人免费在线观看入口 | 中文字幕电影高清在线观看 | 欧美中文字幕久久 | 日本韩国精品一区二区在线观看 | 中文区中文字幕免费看 | 中日韩欧美精彩视频 | 欧美激情视频一二三区 | 国产区精品在线观看 | 精品福利网站 | 国产69精品久久app免费版 | 国产黄色片免费看 | 中文国产在线观看 | 天天色天天上天天操 | 日韩天堂在线观看 | 91九色综合| 中文字幕在线看片 | 久久在现视频 | 国色天香av | 日韩精品电影在线播放 | 96视频免费在线观看 | 色a综合 | 亚洲国产午夜 | 国产一区二区三区四区大秀 | 国产亚洲情侣一区二区无 | 69国产盗摄一区二区三区五区 | 国产精品夜夜夜一区二区三区尤 | 在线有码中文字幕 | 91资源在线免费观看 | 国产一区二区三区午夜 | 久久久精品欧美一区二区免费 | 亚洲欧美激情精品一区二区 | 91桃色国产在线播放 | 久久私人影院 | 伊人午夜 | 国产成人免费在线 | www黄在线 | 久久男人中文字幕资源站 | 亚洲综合在线五月天 | 最近中文字幕在线播放 | 婷婷视频在线 | 日韩视频欧美视频 | 久久久国产成人 | 国产福利精品一区二区 | 欧美精品乱码久久久久久按摩 | 久久久久国产成人免费精品免费 | 国产精品一区二区免费视频 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 色婷婷午夜 | 色香蕉网| 手机成人av| 天天碰天天操 | 国产网红在线观看 | 日韩在线视 | 九九视频网 | 国产亚洲观看 | 久久视频免费在线观看 | 在线看片中文字幕 | 国产精品麻豆果冻传媒在线播放 | 日韩精品大片 | 欧洲一区二区在线观看 | 69av网| 免费观看性生活大片3 | 国产一二三精品 | 亚洲开心色| 天堂入口网站 | 在线一区电影 | 亚洲视频网站在线观看 | 国产91免费在线观看 | av网址在线播放 | 2023av在线 | 欧美极品xxxxx | 久久久性 | 色综合综合 | 片黄色毛片黄色毛片 | 亚洲欧洲精品一区二区精品久久久 | 亚洲 中文 欧美 日韩vr 在线 | 久久精品一区二区 | 成年人在线免费看视频 | 国产精品久久久久久久久久久免费 | 国产午夜三级一区二区三 | 天天射网| 337p日本欧洲亚洲大胆裸体艺术 | 在线国产片 | 91.精品高清在线观看 | 亚洲网站在线看 | 成人久久精品视频 | 91av蜜桃| 四虎国产精品成人免费4hu | 亚洲国产一区在线观看 | 国内精品视频久久 | 91网免费看 | 日韩精品在线看 | 欧美韩日在线 | 亚洲成人家庭影院 | 亚洲精品h | www免费网站在线观看 | wwwav视频 | 丁香五月缴情综合网 | 久久综合九色综合97婷婷女人 | 国产破处在线视频 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 成人超碰在线 | 日韩在线观看一区二区三区 | 国产精品高清免费在线观看 | 亚洲最大av网 | 欧美a在线免费观看 | 日韩中文字幕视频在线 | 二区三区在线 | 天天干夜夜夜 | 亚洲一级电影在线观看 | 啪啪午夜免费 | 一区二区网 | 国内精品久久久久 | 欧美激情综合五月色丁香 | 久久99精品国产 | 最新av免费在线观看 | 美国人与动物xxxx | 91天堂在线观看 | 韩国精品视频在线观看 | 国产精品一区二区三区在线免费观看 | 免费在线观看国产精品 | 首页av在线 | 在线成人性视频 | 久久精品牌麻豆国产大山 | 国产麻豆剧传媒免费观看 | 波多野结衣电影一区二区 | 五月天久久久 | 国产精品影音先锋 | 看黄色.com | 2023国产精品自产拍在线观看 | 丁香花在线观看免费完整版视频 | 午夜国产福利在线 | 中文字幕最新精品 | 在线电影日韩 | 97视频在线免费播放 | 九九视频在线 | 91一区二区在线 | 日韩手机在线观看 | av免费看在线 | 九九有精品 | 亚洲精选国产 | 91麻豆福利 | 亚洲婷婷网 | 99这里只有久久精品视频 | 精品国产诱惑 | 天天干天天干天天射 | 91视频免费看网站 | 国产免费黄视频在线观看 | 美国三级黄色大片 | 亚洲成人第一区 | 国产麻豆精品在线观看 | 亚洲精品乱码久久 | 欧美性生交大片免网 | 亚洲专区路线二 | 国产视频97 | 欧美国产日韩一区二区三区 | 中文字幕av电影下载 | 69av视频在线 | 成人免费中文字幕 | 97超碰精品 | 日韩精品一区二区在线视频 | 婷婷丁香花五月天 | 亚洲一区二区三区四区精品 | 1024手机看片国产 | 欧美国产大片 | 欧美男同网站 | 久久久黄视频 | 99在线视频免费观看 | 久久久久久久久久久久久久免费看 | 一本一道久久a久久综合蜜桃 | 午夜18视频在线观看 | 91黄色在线视频 | 天天看天天干天天操 | 99久久久久免费精品国产 | 日韩一区二区三区高清免费看看 | 久久久久久久久久伊人 | 午夜手机电影 | 97av.com| 精品久久久久久一区二区里番 | 一级片免费观看 | 国产综合香蕉五月婷在线 | av片一区 | 九九免费精品视频在线观看 | 成人黄色电影视频 | 999久久久久久久久6666 | 久草精品视频在线播放 | 欧美精品在线观看免费 | 99视屏 | 国产精品久久久一区二区 | 国产精品午夜8888 | 青青草国产免费 | 久久草精品 | 日本不卡一区二区三区在线观看 | 成人久久精品视频 | 国产精品一区二区av日韩在线 | 精品在线播放视频 | 欧美成年性| 天天操天天摸天天干 | 丁香婷婷综合五月 | bbw av| 国产精品嫩草69影院 | 激情五月婷婷激情 | 久草在线免费新视频 | 日韩免费av片 | 日韩啪啪小视频 | 一级欧美一级日韩 | 99久久精品免费看国产 | 精品久久久久久一区二区里番 | 欧美另类xxxxx | 91综合在线| 美女视频永久黄网站免费观看国产 | 中文字幕乱码亚洲精品一区 | 深爱激情婷婷网 | 亚洲一二区视频 | 免费视频一二三 | 精品亚洲欧美无人区乱码 | 成人中心免费视频 | 久久精品一区二区三区国产主播 | 欧美日高清视频 | 日韩综合一区二区三区 | 国产精品99视频 | 久久免费黄色 | 亚洲黄色一级大片 | 人人干人人上 | 午夜狠狠操| 国产精品成久久久久 | 午夜免费福利视频 | 999精品网 | 99久在线精品99re8热视频 | 久久精品国产一区二区电影 | 成人黄色在线 | 国产精品久久久久久久99 | 97超碰在线免费 | 亚洲影院色 | 又黄又爽又刺激 | 毛片网站免费 | 亚洲影视九九影院在线观看 | 国产一区二区午夜 | 欧美日韩精品二区第二页 | 精品国产乱码久久久久久天美 | 黄网站app在线观看免费视频 | 中文字幕成人在线 | 国产成人免费网站 | 永久免费看av | 国产免费又爽又刺激在线观看 | 在线视频免费观看 | 成人全视频免费观看在线看 | 精品久久久久久久久中文字幕 | 免费在线国产黄色 | 亚洲黄色在线播放 | 亚洲最大成人免费网站 | 国产不卡在线看 | 国产美女网站在线观看 | 欧美午夜久久 | 在线观看国产区 | 99精品在线播放 | 日韩一级精品 | 精品国内| 91网页版在线观看 | 亚洲 中文字幕av | av黄色av | 午夜婷婷在线观看 | 美女视频黄免费 | 久久综合色影院 | 国产成人久久精品77777综合 | av蜜桃在线 | av电影 一区二区 | 亚洲日本va午夜在线影院 | 日本成址在线观看 | 免费在线观看视频a | 亚洲激情p | 黄色午夜 | 五月天激情开心 | 免费日韩一级片 | 韩日电影在线 | 久久久九色精品国产一区二区三区 | 五月丁色| 精品国产一区二区三区蜜臀 | av片一区二区 | 免费看黄网站在线 | 中文字幕文字幕一区二区 | 久久女教师 | 久久免费精品视频 | 激情欧美国产 | 性色xxxxhd | 久久人人爽 | 久久久久久国产一区二区三区 | 综合天天| 久草精品资源 | 综合色在线观看 | 超碰国产97 | 97福利在线 | 国产成人av电影在线观看 | 日韩免费区 | 91亚·色 | 久久免费视频网 | 婷婷激情综合 | 久久狠狠干 | 97超碰.com | 91看片淫黄大片一级在线观看 | 欧美与欧洲交xxxx免费观看 | 久久情爱| 欧美国产日韩久久 | 黄色片视频免费 | 日韩精品一区二区三区中文字幕 | 天天天综合 | 国产专区视频在线 | 狠狠色综合欧美激情 | 国内精品毛片 | 久操久 | 国产精品永久在线 | 成年人在线免费看视频 | 欧美一级电影免费观看 | 黄色小说免费观看 | 丁香六月在线观看 | 在线观看视频一区二区 | 九九热久久免费视频 | 国产精品18毛片一区二区 | 91日韩在线专区 | 精品欧美乱码久久久久久 | 亚洲国产资源 | www.91成人 | 亚洲最新在线视频 | 日韩免费视频 | 亚洲天堂网站 | 亚洲视频免费 | 看av免费| 久久试看 | 91精品免费在线 | 亚洲一区黄色 | 欧美a影视 | 永久av免费在线观看 | 综合色婷婷 | 超碰97人人射妻 | 中国成人一区 | 免费观看十分钟 | 91成年视频| 色婷婷久久久 | 婷婷视频在线观看 | 久久天天躁| 免费看的黄色录像 | 国产 成人 久久 | 久久久久日本精品一区二区三区 | 久久久九色精品国产一区二区三区 | 午夜影院一级片 | 久久久国产毛片 | 人人爽人人爽人人片 | 亚洲成人av电影 | 特黄色大片 | 又黄又刺激的视频 | 色丁香色婷婷 | 国产视频日韩视频欧美视频 | 欧美成人高清 | 国产精品美女久久久久久久网站 | 亚洲黄色在线免费观看 | 久久久久久不卡 | 久草免费新视频 | 国产精品美女网站 | 四虎在线免费视频 | 日日夜夜网 | 在线观看视频福利 | 97电影手机 | 久久久久久久久久亚洲精品 | 国产在线黄 | 摸bbb搡bbb搡bbbb | 激情五月综合网 | 国产又粗又猛又黄视频 | 久久精品中文视频 | 久久黄色片子 | 人人讲 | 99热99re6国产在线播放 | 国产黄色片在线 | 免费在线播放 | 99久久综合狠狠综合久久 | www.色午夜.com | 国产在线播放不卡 |