main.c
這個不用解釋了吧
stm32f10x.h
這個是頭文件,它包含了stm32的一些常用宏,寄存器結構體的定義,高版本的庫還放著中斷向量表。
stm32f10x_rcc.c
這個文件里的固件函數包含了一些對復位、時鍾的控制的函數
stm32f10x_gpio.c這個文件里的固件函數包含了對GPIO的操作函數
stm32_eval.c
這個是st公司為其製作的評估板寫的程序
system_stm32f10x.c主要包含了對系統時鍾設置,一般是對倍頻時鍾的設置
三、GPIO_InitTypeDef
GPIO_InitStructure;
ErrorStatus
HSEStartUpStatus;
u8
count=0;
四、void
Delay(vu32
nCount);
void
Turn_On_LED(u8
LED_NUM);
希望您能幫助我,我會給您高分的。回答:
1、因為引腳本來就是16個的啊,從pin0~pin15,GPIOA口有16個腳,GPIOB也有16個,GPIOC也有16個,是這樣區分的,它是相對於一組io口的細分,ALL來代替的是選中了這一組io
2、不可以,呵呵你要選擇到底是GPIOA還是GPIOB還是...C還是...D等等的GPIO_Pin_0
3、GPIO_InitTypeDef、ErrorStatus是兩個結構體,u8是定義的unsigned
char你可以通過keil的go
to
definition選項找到它們的定義,這個是標准C的定義
嗯,是的C語言基礎不太好,以前學單片機主要是用匯編。
回答:
『貳』 為什麼linux中很多頭文件沒有呢譬如:gpio
Linux內核只有晶元商添加了驅動才會有對應的gpio函數,最好自己實現。寄存器的操作比較簡單,直接寫地址就可以了。注意把物理地址轉換為虛擬地址。
『叄』 ARM單片機的頭文件如何用結構體定義地
下面我們以ARM Cortex-M0內核單片機LPC1114的頭文件lpc11xx.h文件進行說明。
1.先說兩句
lpc11xx.h文件是lpc11xx系列單片機包含的頭文件。這個文件的作用和51單片機中的reg51.h頭文件是一個性質,都是用來定義寄存器在單片機中的地址的。
你現在就可以打開reg51.h文件和lpc11xx.h文件看看,對比後你會發現兩個主要的區別,首先是lpc11xx.h文件的寄存器定義是用結構體的形式,而reg51.h文件中,寄存器的定義都是一條一條的很直接的地址定義。然後是reg51.h文件中有sfr這樣的「偽c語言」,而lpc11xx.h中用的是標準的c語言。C語言的最大用武之地就是單片機,要想學c,就在單片機上學,要想學單片機,就先入門c語言。兩者相輔相成的學,效果最好。學以致用,才是學習的最終目標。
2.lpc11xx.h文件中如何定義寄存器地址?
在文件中,定義寄存器地址用到了一下幾方面的c語言基礎知識:
結構體;
結構體指針;
宏定義#define
關鍵字typedef
關鍵字volatile
關鍵字const
lpc11xx.h文件中,把每個模塊都定義了一個結構體,這些模塊有SYSCON、IOCON、UART、GPIO、SSP、I2C、WDT、ADC等。
例如,下面是ADC模塊的結構體定義:
typedef struct
{
__IO uint32_t CR;
__IO uint32_t GDR;
uint32_t RESERVED0;
__IO uint32_t INTEN;
__IO uint32_t DR[8];
__I uint32_t STAT;
} LPC_ADC_TypeDef;
結構體的定義有三種形式,我們這里使用的是「直接說明變數」的形式。
lpc11xx.h文件的第566~584行,給每個模塊的結構體變數定義了結構體指針,並加了宏定義#define,為的是以後寫程序時書寫方便。
把滑鼠放到uint32_t上面,單擊滑鼠右鍵,在彈出的菜單中選擇「Go To Definition Of 『uint32_t』」,如下圖所示:
選擇後,就會跳到它的定義之處,如下圖所示:
typedef是類型重定義關鍵字,所以實際上,CR寄存器的定義是這樣的:
__IO unsigned int CR;
按照同樣的方法,可以找到__IO的定義為:
所以,CR寄存器定義實際上是:
volatile unsigned int CR;
volatile關鍵字的作用是為了讓編譯器不要優化這個變數。
unsigned int關鍵字,用來定義無符號的整形變數。
這時候,有人會問,為什麼不直接寫成這樣呢?答:為了閱讀方便。
__IO uint32_t CR;
看到這條語句,我們就會知道,CR寄存器是一個「32位的可讀可寫寄存器」。
volatile unsigned int CR;
同樣的這句話,我們對它的了解就不是那麼一目瞭然了。
3.如何查看每個寄存器的地址?
上面講到,寄存器的地址是由結構體和結構體指針定義的。現在我們來驗證一下它的正確性。
我們隨便找個寄存器,比如ADC模塊的INTEN寄存器(ADC中斷允許寄存器),打開LPC1114的用戶手冊,找到第25章ADC模塊部分,如下圖所示:
從上面圖中,可以看到INTEN的寄存器的地址是0x4001C00C,接下來,我們打開lpc11xx.c文件來驗證一下吧。
打開lpc11xx.c文件,找到ADC模塊的結構體,如下圖所示:
然後再找到LPC_ADC_TypeDef的結構體指針,如下所示:
結構體指針就是用來指向一個地址的,我們來看看上面語句中的LPC_ADC_BASE是什麼:
再看看上條語句中的LPC_APB0_BASE是什麼:
現在終於挖到底了,原來LPC_ADC_TypeDef指針指向的地址為:
0x40000000+0x1C000=0x4001C000
c語言基礎知識:結構體的第一個變數的地址=結構體指針的地址。
所以結構體的第一個變數地址就是0x4001C000,INTEN前面有3個4位元組的變數,所以INTEN的地址就是0x4001C00C。
驗證完畢。
4.程序中,如何操作寄存器?
C語言基礎知識:用結構體變數指針訪問結構體中的變數,形式有兩種:
*結構體指針變數.變數名
結構體指針變數->變數名
還是拿INTEN寄存器為例,假設我們要給這個寄存器寫0x837,可以這樣寫:
*LPC_ADC.INTEN=0x837;
LPC_ADC->INTEN=0X837;
以上兩種形式,在寫程序的時候,都可以用。人們習慣用第二種形式。
『肆』 stm32頭文件問題
因為,stm32f10x.h中包含了一系列的標准庫頭文件,其中就包括了stm32f10x_gpio.h,但是,一定要確保宏配製正確!
查看一下stm32f10x.h源代碼就清楚了
『伍』 STM32寄存器頭文件定義
這個是寄存器地址的操作問題,地址值,這個地址(或理解為指針)是UINT型而已,對著數據手冊就看明白了。
『陸』 STM32 中_IO 在哪裡定義具體的頭文件名稱是什麼
#define __I volatile const /*!< defines 'read only' permissions */
#define __O volatile /*!< defines 'write only' permissions */
#define __IO volatile /*!< defines 'read / write' permissions */
位於core_cm3.h
『柒』 AM335X 在linux下如何獲取某個GPIO口的中斷,需要速度很快響應處理該中斷,如果有示例代碼最好,謝謝。
gpio_to_irq
『捌』 linux系統中驅動程序中一些頭文件地址的問題
e.h> 模塊頭文件
#include <linux/kernel.h> 驅動要寫入內核,與內核相關的頭文件
#include <linux/fs.h> 文件系統頭文件
#include <linux/init.h> 初始化頭文件
#include <linux/delay.h> 延時頭文件
#include <asm/irq.h> 與處理器相關的中斷
#include <linux/interrupt.h> 操作系統中斷
#include <asm/uaccess.h> 與處理器相關的入口
//#include <asm/arch/regs-gpio.h> 與處理器相關的IO口操作
#include <mach/regs-gpio.h> 同上
//#include <asm/hardware.h> 與處理器相關的硬體
#include <mach/hardware.h> 同上
#include <linux/device.h> 設備驅動文件
#include <linux/poll.h> 輪詢文件
#include <linux/gpio.h> 操作系統相關的IO口文件
#include <stdio.h> 標准輸入輸出
#include <stdlib.h> 標准庫
#include <unistd.h>
#include <sys/ioctl.h> IO控制
以下6個是提供的函數中所需的頭文件
具體我也不詳
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <sys/select.h>
#include <sys/time.h>
#include <errno.h>
『玖』 請教pandaboard上omap4460的GPIO用作外部中斷引腳的配置方法!!
你的引腳要配置成GPIO模式,在board_omap4_panda.c裡面,因為pandaboard的引腳配置大部分在uboot裡面,只有少量臨時的配置在board_omap4_panda.c裡面
『拾』 gpio中斷和irq中斷的區別
這個需要IOxAPIC,把GPIOmap到什麼PIRQX上,然後IRQ24——39對應PIRQx……GPIO就是typein,不用復用。
就這樣玩?不過用GPIO做一個SMI,SCI不是簡單點啊