久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 16339|回復: 0
打印 上一主題 下一主題
收起左側

嵌入式學習之GPIO接口詳解

[復制鏈接]
跳轉到指定樓層
樓主
 一、什么是GPIO

  GPIO----“通用目的輸入/輸出端口”----是一個靈活的軟件控制的數字信號。許多種類的芯片都會提供,嵌入式linux開發者和硬件定制者會對此比較熟悉。每個GPIO提供一位與特定的管腳(或是“球”,BGA(BallGridArray)封裝下)相連。單板電路圖會顯示外部硬件與GPIOs的連接關系。GPIO驅動可寫成通用的,便于單板setup代碼可以將這些管腳配置數據傳遞給驅動。

  SOC處理器非常依賴于GPIO。某些情況下,普通管腳可以被配置為GPIO。大多數芯片至少擁有幾組類似的GPIO。可編程邏輯器件(如FPGAs)可以很容易提供GPIO。一些多功能芯片,如電源管理、聲音解碼等經常具有一些這樣的管腳來彌補SOC芯片上面管腳的不足。同樣,也存在一些GPIO擴展芯片,連接用于I2C或是SPI串行總線。多數PC南橋擁有幾組GPIO兼容的管腳(僅有BIOS固件知道如何使用它們)。

  不同系統間的GPIO的確切作用不同。通用常有下面幾種:

  ----輸出值可寫(高=1,低=0)。一些芯片也可以選擇驅動這些值的方式,以便支持“線-或”或類似方案(開漏信號線)。

  ----輸入值可讀(1,0)。一些芯片支持輸出管腳回讀,這在線或的情況下非常有用(以支持雙向信號線)。GPIO控制器可能具有一個輸入防故障/防反跳邏輯,有時還會有軟件控制。

  ----輸入經常被用作中斷信號,通常是邊沿觸發,但也有可能是電平觸發。這些中斷可以配置為系統喚醒事件,從而將系統從低功耗模式喚醒。

  ----一個GPIO經常被配置為輸入/輸出雙向,根據不同的產品單板需求,但也存在單向的情況。

  ----大多是GPIO可以在獲取到spinlock自旋鎖時訪問,但那些通過串行總線訪問的通常不能如此操作(休眠的原因)。一些系統中會同時存在這兩種形式的GPIO。

  ----在一個給定單板上,每個GPIO用于一個特定的目的,如監控MMC/SD卡的插入/移除,檢查卡寫保護狀態,驅動LED,配置發送器,串行總線位拆,觸發一個硬件看門狗,觸發一個開關之類的。

  二、GPIO的優點(端口擴展器)

  低功耗:GPIO具有更低的功率損耗(大約1μA,μC的工作電流則為100μA)。

  集成IIC從機接口:GPIO內置IIC從機接口,即使在待機模式下也能夠全速工作。

  小封裝:GPIO器件提供最小的封裝尺寸 ― 3mm x 3mm QFN!

  低成本:您不用為沒有使用的功能買單。

  快速上市:不需要編寫額外的代碼、文檔,不需要任何維護工作。

  靈活的燈光控制:內置多路高分辨率的PWM輸出。

  可預先確定響應時間:縮短或確定外部事件與中斷之間的響應時間。

  更好的燈光效果:匹配的電流輸出確保均勻的顯示亮度。

  布線簡單:僅需使用2條就可以組成IIC總線或3條組成SPI總線。

  與ARM 的幾組GPIO引腳,功能相似,GPxCON 控制引腳功能,GPxDAT用于讀寫引腳數據。另外,GPxUP用于確定是否使用上拉電阻。 x為A,B,,H/J,

  GPAUP沒有上拉電阻。

  三、GPIO硬件介紹  1. 通過寄存器來操作GPIO引腳

  GPxCON用于選擇引腳功能,GPxDAT用于讀/寫引腳數據;另外,GPxUP用于確定是否使用內部上拉電阻。x為B、。。.、 H/J,沒有GPAUP寄存器。

  1.1 GPxCON寄存器

  從寄存器的名字可以看出,它用于配置(Configure)-選擇引腳功能。

  PORTA與PORTB~PORT H/J在功能選擇方面有所不同,GPACON中每一位對應一根引腳(共23根引腳)。當某位被設為0時,相應引腳為輸出引腳,此時我們可以在GPADAT 中相應位寫入0或是1讓此引腳為低電平或高電平;當某位被設為1時,相應引腳為地址線或用于地址控制,此時GPADAT無用。一般而言,GPACON通常 被設為全1,以便訪問外部存儲器件。

  PORT B~ PORT H/J在寄存器操作方面完全相同。GPxCON中每兩位控制一根引腳:00表示輸入、01表示輸出、10表示特殊功能、11保留不用。

  1.2 GPxDAT寄存器

  GPxDAT用于讀/寫引腳;當引腳被設為輸入時,讀此寄存器可知相應引腳的電平狀態是高還是低;當引腳被設為輸出時,寫此寄存器相應位可以令此引腳輸出高電平或是低電平。

  1.3 GPxUP寄存器

  GPxUP:某位為1時,相應引腳無內部上拉電阻;為0時,相應引腳使用內部上拉電阻。

  上拉電阻的作用在于:當GPIO引腳處于第三態(即不是輸出高電平,也不是輸出低電平,而是呈高阻態,即相當于沒接芯片)時,它的電平狀態由上拉電阻、下拉電阻確定。

  2、訪問硬件

  2.1 訪問單個引腳

  單個引腳的操作無外乎3種:輸出高低電平、檢測引腳狀態、中斷。對某個引腳的操作一般通過讀、寫寄存器來完成。

  訪問這些寄存器是通過軟件來讀寫它們的地址。比如:S3C2410和S3C2440的GPBCON、GPBDAT寄存器地址都是0x56000010、0x56000014,可以通過如下的指令讓GPB5輸出低電平。

TIle unsigned long *)0x56000010) //long=int 4字節;char 1字節;short 2字節

TIle unsigned long *)0x56000014)

  #define GPB5_out (1《《(582))

  GPBCON = GPB5_out;

  GPBDAT &= ~(1《《5);

  2.2 以總線方式訪問硬件

  并非只能通過寄存器才能發出硬件信號,實際上通過訪問總線的方式控制硬件更為常見。如下圖所示S3C2410/S3C2440與NOR Flash的連線圖,讀寫操作都是16位為單位。

  圖中緩沖器的作用是以提搞驅動能力、隔離前后級信號。NOR Flash(AM29LV800BB)的片選信號使用nGCS0信號,當CPU發出的地址信號處于0x00000000~0x07FFFFFF之間 時,nGCS0信號有效(為低電平),于是NOR Flash被選中。這時,CPU發出的地址信號傳到NOR Flash;進行寫操作時,nWE信號為低,數據信號從CPU發給NOR Flash;進行讀操作時,nWE信號為高,數據信號從NOR Flash發給CPU。

  ADDR1~ADDR20 ------------------》 》--------------------A0~A19

  DATA0~DATA15 《-----------------》 《-------------------》D0~D15

  nOE ------------------》 --------------------》nOE

  nWE ------------------》 --------------------》nWE

  nGCS0 ------------------》 --------------------》nCE

  S3C2410/S3C2440 緩沖器 NOR Flash(AM29LV800BB)

  軟件如何發起寫操作呢,下面有幾個例子的代碼進行講解。

  1)地址對齊的16位讀操作

  unsigned short *pwAddr = (unsigned short *)0x2;

  unsigned short uwVal;

  uwVal = *pwAddr;

  上述代碼會向NOR Flash發起讀操作:CPU發出的讀地址為0x2,則地址總線ADDR1~ADDR20、A0~A19的信號都是1、0.。。、0(CPU的ADDR0 為0,不過ADDR0沒有接到NOR Flash上)。NOR Flash的地址就是0x1,NOR Flash在稍后的時間里將地址上的16位數據取出,并通過數據總線D0~D15發給CPU。

  2)地址位不對齊的16位讀操作

  unsigned short *pwAddr = (unsigned short *)0x1;

  unsigned short uwVal;

  uwVal = *pwAddr;

  由于地址是0x1,不是2對齊的,但是BANK0的位寬被設為16,這將導致異常。我們可以設置異常處理函數來處理這種情況。在異常處理函數中,使用 0x0、0x2發起兩次讀操作,然后將兩個結果組合起來:使用地址0x0的兩字節數據D0、D1;再使用地址0x02讀到D2、D3;最后,D1、D2組 合成一個16位的數字返回給wVal。如果沒有地址不對齊的異常處理函數,那么上述代碼將會出錯。如果某個BANK的位寬被設為n,訪問此BANK時,在 總線上永遠只會看到地址對齊的n位操作。

  3)8位讀操作

  unsigned char *pwAddr = (unsigned char *)0x6;

  unsigned char ucVal;

  ucVal = *pwAddr;

  CPU首先使用地址0x6對NOR Flsh發起16位的讀操作,得到兩個字節的數據,假設為D0、D1;然后將D0取出賦值給變量ucVal。在讀操作期間,地址總線 ADDR1~ADDR20、A0~A19的信號都是1、1、0、。。.、0(CPU的ADDR0為0,不過ADDR0沒有接到NOR Flash上)。CPU會自動丟棄D1。

  4)32位讀操作

  unsigned int *pwAddr = (unsigned int *)0x6;

  unsigned int udwVal;

  udwVal = *pwAddr;

  CPU首先使用地址0x6對NOR Flsh發起16位的讀操作,得到兩個字節的數據,假設為D0、D1;再使用地址0x8發起讀操作,得到兩字節的數據,假設為D2、D3;最后將這4個數據組合后賦給變量udwVal。

  5)16位寫操作

  unsigned short *pwAddr = (unsigned short *)0x6;

  *pwAddr = 0x1234;

  由于NOR Flash的特性,使得NOR Flash的寫操作比較復雜——比如要先發出特定的地址信號通知NOR Flash準備接收數據,然后才發出數據等。不過,其總線上的電信號與軟件指令的關系與讀操作類似,只是數據的傳輸方向相反。

  四、何為上拉電阻、下拉電阻

  上拉電阻是針對NPN來說的,下拉電阻是針對PNP來說的!不管是上拉電阻還是下拉電阻都是為了使集電極有確定的電位!

  比如對NPN來說,當不用上拉電阻的時候,若基集為正,則導通,集電極為0。但當基集為0,則截止,此時集電極是懸空的,電位無法確定!一旦加了上拉電阻,當導通的時候,集電極為0,當截止的時候,集電極為正。

  PNP也一樣,導通的時候集電極為正,截止的時候集電極為0。

  五、GPIO端口配置方法

  單個引腳的操作無非就三種情況:輸出高低電平,檢測引腳狀態,中斷。對引腳的操作一般是通過特定寄存器的配置完成。

  如圖,根據LED 的硬件電路圖,實現點亮LED:

TIle unsigned long *)0x56000050)

TIle unsigned long *)0x56000054)

  #define GPF4_out (1《《(4*2))

  #define GPF5_out (1《《(5*2))

  #define GPF6_out (1《《(6*2))

  #define GPF7_out (1《《(7*2))

  void wait(volatile unsigned long dly)

  {

  for(; dly 》 0; dly--);

  }

  int main(void)

  {

  unsigned long i = 0;

  GPFCON = GPF4_out|GPF5_out|GPF6_out|GPF7_out; // 將LED1-4對應的GPF4/5/6/7三個引腳設為輸出

  while(1){

  wait(30000);

  GPFDAT = (~(i《《4)); // 根據i的值,點亮LED1~4

  if(++i == 8)

  i = 0;

  }

  return 0;

  }


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 精品一区二区不卡 | 成人精品一区二区三区中文字幕 | 国产一区二区欧美 | 国产亚洲欧美另类一区二区三区 | 成人中文字幕av | 欧美精品99 | 美女中文字幕视频 | 欧美一区二区大片 | 草久久| 久久精品国产免费一区二区三区 | 国产高清视频在线观看播放 | 91久久精品国产91久久性色tv | 欧美成人aaa级毛片在线视频 | 亚洲电影中文字幕 | 日韩av免费看 | 免费国产视频在线观看 | 色噜噜狠狠色综合中国 | 午夜免费在线观看 | 久久久久久久久毛片 | 日韩一区二区三区视频 | 久久久久亚洲精品 | 欧美一区二区在线观看 | 成人精品一区亚洲午夜久久久 | 波多野结衣中文视频 | 精品久久国产 | 亚洲国产成人精品一区二区 | 黄色在线免费观看视频网站 | 亚洲欧美中文字幕在线观看 | 色综合天天天天做夜夜夜夜做 | 国产精品99久久久久久人 | 日韩免费视频一区二区 | 久久久久免费观看 | 日韩精品在线播放 | 成人av一区二区三区 | 精品国产色 | 日韩中文字幕2019 | 亚洲人在线观看视频 | 久久免费精品 | 国产成人a亚洲精品 | 国产第一区二区 | 91人人澡人人爽 |