基于I2C總線的串行鍵盤電路設(shè)計(jì)
出處:maychang 發(fā)布于:2012-06-08 11:39:46
一、概述
本文介紹一種采用MAX7348 的串行I2C 總線的鍵盤電路以及驅(qū)動(dòng)程序的設(shè)計(jì)。
I2C 需要連線少,僅需一條串行時(shí)鐘線和一條串行數(shù)據(jù)線。允許多主機(jī)控制,具有裁決和同步功能,可隨意添加或摘除總線上的子器件等諸多優(yōu)點(diǎn),所以已經(jīng)被廣泛應(yīng)用。
二、MAX7348
MAX7348 是美國MAXIM 公司生產(chǎn)的2 線接口、低EMI 鍵盤開關(guān)和發(fā)聲控制器,可監(jiān)控多達(dá)40 個(gè)按鍵,可對(duì)按鍵去抖并保存在FIFO 中,去抖時(shí)間用戶可在9 ~ 40ms 之間任意設(shè)置,MAX7348 自帶的音調(diào)發(fā)生器在控制器的作用下可自動(dòng)發(fā)出按鍵聲和報(bào)警聲,在發(fā)聲期間,輸出還可以設(shè)置為高電平或低電平,以驅(qū)動(dòng)電子發(fā)聲器、繼電器或指示燈。
芯片采用400Kps,5.5V 容限2 線串行接口,工作電壓2.4 ~ 3.6V,4 個(gè)I2C 地址選擇。與MAX7348同系列的還有MAX7347 和MAX7349 等。
1. 引腳圖
如圖1 所示,SDA 、SCL 分別是兼容I2C 串行總線的數(shù)據(jù)、時(shí)鐘接口,使用時(shí)通常需要接一個(gè)典型值為4.7kΩ 的上拉電阻;ROW0 ~ ROW8 為鍵盤矩陣行輸入端口,不用時(shí)開路;COL0 ~ COL4為鍵盤矩陣列輸出端口;SOUNDER 為發(fā)聲器輸出端口,該輸出為推挽結(jié)構(gòu),通常與地之間接一個(gè)壓電陶瓷片或其他發(fā)聲設(shè)備;INT 為中斷輸出端口;ADO 為地址輸入端口,用來設(shè)置器件的從地址,該引腳接GND、V+、SDA、SCL 可形成4 種邏輯組合構(gòu)成MAX7348 的4 個(gè)可選的I2C 地址,如表1 ;GND 為接地端,V+ 接電源(2.4 ~ 3.6V)。

表1 2線接口地址分配表

2. 主要內(nèi)部寄存器
?。?) 按鍵FIFO 寄存器(00H) 該寄存器包含與按鍵FIFO 狀態(tài)有關(guān)的信息,以及那些經(jīng)過去抖的事件信息,該寄存器的D0 ~ D5 位表示按鍵中的那些鍵已去抖,D6 指明當(dāng)前去抖按鍵是否是FIFO 中的一個(gè);D7 位是溢出標(biāo)志,它表示按鍵FIFO 是否溢出。讀按鍵掃描FIFO 將清除中斷信號(hào),但是只有通過執(zhí)行足夠次數(shù)的讀操作清空FIFO后才能再次產(chǎn)生中斷(INT)信號(hào)。
?。?)去抖寄存器( 01H) 該寄存器用來設(shè)置每一個(gè)去抖周期的時(shí)間,以及使能和禁用GPO 端口,其中D0 ~ D4 位用來在9 ~ 40ms 范圍內(nèi)設(shè)置去抖時(shí)間,步長(zhǎng)1ms,D5 ~ D7 用來設(shè)置使能那一個(gè)GPO 端口(表2)。
表2 去抖寄存器設(shè)置

?。?)自動(dòng)重復(fù)寄存器( 02H)該寄存器用來設(shè)置自動(dòng)重復(fù)頻率及其延時(shí)。當(dāng)按鍵按下且沒有釋放時(shí),自動(dòng)重復(fù)功能允許連續(xù)觸發(fā)按鍵事件。自動(dòng)重復(fù)延時(shí)規(guī)定了次按下按鍵與開始重復(fù)之間的時(shí)間(如果按鍵沒有釋放)。自動(dòng)重復(fù)頻率規(guī)定了自動(dòng)重復(fù)開始后按鍵事件連續(xù)觸發(fā)的速度。D0 ~ D3設(shè)定自動(dòng)重復(fù)延時(shí),范圍從8 個(gè)去抖周期到128 個(gè)去抖周期。D4 ~ D6 位規(guī)定重復(fù)頻率,范圍是4 到32 個(gè)去抖周期,D7 位是自動(dòng)重復(fù)功能使能位(如表3 所示)。
表3 自動(dòng)重復(fù)寄存器

?。?) 中斷寄存器( 03H) 該寄存器包含與中斷請(qǐng)求功能設(shè)置有關(guān)的信息,以及INT 輸出的狀態(tài),INT 輸出也可配置為GPO.中斷寄存器是只讀寄存器,向該寄存器寫入數(shù)據(jù)無效。
?。?)配置寄存器(04H)該寄存器反映發(fā)聲器的狀態(tài)、控制I2C 總線超時(shí)、使能報(bào)警輸入中斷、使能發(fā)聲器對(duì)報(bào)警輸入和按鍵去抖時(shí)間做出響應(yīng),以及控制器件關(guān)斷等。該寄存器結(jié)構(gòu)如表4 所示,除D1、D2 設(shè)定發(fā)聲器輸出狀態(tài)外,其余每一位對(duì)應(yīng)一個(gè)控制狀態(tài),用戶可根據(jù)需要使能(置"1")或禁止(置"0")。
表4 配置寄存器結(jié)構(gòu)

?。?)按鍵發(fā)聲寄存器( 06H) 如果配置寄存器(04H)中使能按鍵發(fā)聲,那么當(dāng)一個(gè)鍵或一組鍵去抖后,發(fā)聲控制器將發(fā)出聲音,并由按鍵發(fā)聲寄存器設(shè)定發(fā)聲的時(shí)間和頻率。
除以上幾個(gè)主要寄存器外還有端口寄存器、報(bào)警聲寄存器、發(fā)聲器寄存器等多個(gè)寄存器,這些寄存器主要用于控制發(fā)聲器和擴(kuò)展GPO 端口,在此不做詳細(xì)敘述,感興趣的讀者可以自行查閱有關(guān)MAX7348 的技術(shù)資料。
三、電路設(shè)計(jì)
圖2 是筆者設(shè)計(jì)的MAX7348 應(yīng)用電路,該電路以凌陽(SPCE061A)單片機(jī)為主控制器,結(jié)合MAX7348 構(gòu)成了一個(gè)具有40 個(gè)按鍵的鍵盤電路,通過程序可以設(shè)置按鍵發(fā)聲、自動(dòng)連續(xù)按鍵、中斷輸出等功能。MAX7348 的SDA、SCL、INT 分別與SPCE061A 單片機(jī)的IOB0、IOB1、IOB2(注:SPCE061A 單片機(jī)的IOB2 為外部中斷1 的輸入口)連接,由于I2C 總線允許掛接多個(gè)從機(jī),所以在實(shí)際使用中,可以將多個(gè)不同從機(jī)地址的設(shè)備掛接在同一總線上,為單片機(jī)節(jié)約大量的硬件資源。

四、軟件編寫
在圖2 所示的鍵盤電路中,由于MAX7348 只具有兼容的I2C 接口,而SPCE061A 單片機(jī)本身不具備I2C 接口,要實(shí)現(xiàn)二者之間的數(shù)據(jù)傳輸,通常采用通用IO 口軟件模擬I2C 的方式來實(shí)現(xiàn)。圖3 是MAX7348 的總線時(shí)序。

由圖3 所示的時(shí)序圖可以看出,用軟件模擬I2C 總線的傳輸時(shí)序,大致要經(jīng)歷構(gòu)造開始條件、發(fā)送從機(jī)地址(含讀寫標(biāo)志位)、等待從機(jī)響應(yīng)、發(fā)送(或讀?。? 個(gè)字節(jié)數(shù)據(jù)(或命令)、源程序請(qǐng)從www.ele169.com 。
筆者編寫的模擬I2C 總線驅(qū)動(dòng)程序,經(jīng)過多次調(diào)試,程序符合I2C 總線傳輸時(shí)序要求,與I2C總線設(shè)備通訊可靠,但需要注意的一點(diǎn)是:以上代碼是在SPCE061A 單片機(jī)默認(rèn)時(shí)鐘頻率(24M)的情況下編寫的,如果采用較高的系統(tǒng)時(shí)鐘,需要在部分代碼中間添加一些延時(shí)程序,否則會(huì)出現(xiàn)數(shù)據(jù)丟失,造成通訊錯(cuò)誤。
五、小結(jié)
本文介紹的MAX7348 與單片機(jī)的接口具有電路簡(jiǎn)單,易于實(shí)現(xiàn),節(jié)省了單片機(jī)的IO 口,提高了鍵盤電路的穩(wěn)定性和可靠性,在筆者制作的5 層電梯模型中工作穩(wěn)定,性能可靠,是一種值得推廣的鍵盤擴(kuò)展方案,可應(yīng)用在工業(yè)控制、PDA、醫(yī)療器械等多個(gè)領(lǐng)域。
參考文獻(xiàn):
[1]. MAX7348 datasheet http://www.hbjingang.com/datasheet/MAX7348+_1107011.html.
[2]. MAXIM datasheet http://www.hbjingang.com/datasheet/MAXIM+_1062568.html.
[3]. MAX7347 datasheet http://www.hbjingang.com/datasheet/MAX7347+_1107012.html.
[4]. MAX7349 datasheet http://www.hbjingang.com/datasheet/MAX7349+_1107010.html.
[5]. SPCE061A datasheet http://www.hbjingang.com/datasheet/SPCE061A_1082153.html.
版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫電子市場(chǎng)網(wǎng)”的所有作品,版權(quán)均屬于維庫電子市場(chǎng)網(wǎng),轉(zhuǎn)載請(qǐng)必須注明維庫電子市場(chǎng)網(wǎng),http://www.hbjingang.com,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點(diǎn)或證實(shí)其內(nèi)容的真實(shí)性,不承擔(dān)此類作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個(gè)人從本網(wǎng)轉(zhuǎn)載時(shí),必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問題,請(qǐng)?jiān)谧髌钒l(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- ARM技術(shù)架構(gòu)與應(yīng)用開發(fā)實(shí)踐指南2026/1/6 10:40:19
- 嵌入式實(shí)時(shí)操作系統(tǒng)(RTOS)選型與移植技術(shù)指南2025/12/31 10:42:31
- 工業(yè)嵌入式系統(tǒng):通信接口技術(shù)選型與抗干擾設(shè)計(jì)實(shí)踐2025/12/15 14:36:53
- 深入解析嵌入式 OPENAMP 框架:開啟異核通信新時(shí)代2025/7/22 16:27:29
- 一文快速了解OPENWRT基礎(chǔ)知識(shí)2025/7/14 16:59:04
- 高速PCB信號(hào)完整性(SI)設(shè)計(jì)核心實(shí)操規(guī)范
- 鎖相環(huán)(PLL)中的環(huán)路濾波器:參數(shù)計(jì)算與穩(wěn)定性分析
- MOSFET反向恢復(fù)特性對(duì)系統(tǒng)的影響
- 電源IC在惡劣環(huán)境中的防護(hù)設(shè)計(jì)
- 連接器耐腐蝕性能測(cè)試方法
- PCB電磁兼容(EMC)設(shè)計(jì)與干擾抑制核心實(shí)操規(guī)范
- 用于相位噪聲測(cè)量的低通濾波器設(shè)計(jì)與本振凈化技術(shù)
- MOSFET在高頻開關(guān)中的EMI問題
- 電源IC在便攜式設(shè)備中的設(shè)計(jì)要點(diǎn)
- 連接器結(jié)構(gòu)設(shè)計(jì)常見問題分析









