0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于FPGA的實(shí)時(shí)時(shí)鐘設(shè)計(jì)

FPGA技術(shù)江湖 ? 來(lái)源:FPGA技術(shù)江湖 ? 2025-01-06 16:06 ? 次閱讀

大俠好,歡迎來(lái)到FPGA技術(shù)江湖,江湖偌大,相見(jiàn)即是緣分。大俠可以關(guān)注FPGA技術(shù)江湖,在“闖蕩江湖”、"行俠仗義"欄里獲取其他感興趣的資源,或者一起煮酒言歡。

今天給大俠帶來(lái)基于FPGA實(shí)時(shí)時(shí)鐘的設(shè)計(jì),附源碼,獲取源碼,請(qǐng)?jiān)凇癋PGA技術(shù)江湖”公眾號(hào)內(nèi)回復(fù)“基于FPGA實(shí)時(shí)時(shí)鐘的設(shè)計(jì)源碼”,可獲取源碼文件。話不多說(shuō),上貨。

本次設(shè)計(jì)采用了美國(guó)DALLAS公司推出的一種高性能、低功耗、帶RAM的實(shí)時(shí)時(shí)鐘電路 DS1302,它可以對(duì)年、月、日、周、時(shí)、分、秒進(jìn)行計(jì)時(shí),具有閏年補(bǔ)償功能,工作電壓為2.5V~5.5V。采用三線接口與CPU進(jìn)行同步通信,并可采用突發(fā)方式一次傳送多個(gè)字節(jié)的時(shí)鐘信號(hào)或RAM數(shù)據(jù)。DS1302內(nèi)部有一個(gè)31×8的用于臨時(shí)性存放數(shù)據(jù)的RAM寄存器

DS1302芯片的封裝如下:

e4e45486-cbc1-11ef-9310-92fbcf53809c.png

DS1302芯片有8個(gè)引腳,在本次的設(shè)計(jì)中只要驅(qū)動(dòng)3個(gè)引腳就可以了,其他的引腳都是和硬件相連接的,和FPGA連接的有時(shí)鐘sclk,串行數(shù)據(jù)數(shù)據(jù)接口IO,以及CE。

工作原理就是在數(shù)據(jù)的傳送過(guò)程中先把CE拉高,在每個(gè)數(shù)據(jù)的上升沿寫入數(shù)據(jù),在下降沿輸入數(shù)據(jù),一次只能讀寫一位數(shù)據(jù)。最初我們通過(guò)一個(gè)8位的控制指令來(lái)選擇讀寫,如果控制指令是單字節(jié)模式,連續(xù)的8個(gè)脈沖上升沿寫入,下降沿讀出數(shù)據(jù),一次只能讀取一個(gè)字節(jié),如果是突發(fā)模式通過(guò)連續(xù)的脈沖一次性的寫完7個(gè)字節(jié)的時(shí)間寄存器也可以一次性的讀完8--328位的ram數(shù)據(jù)

控制指令有8位,第七位必須為高,如果是0寫入被禁止,第六位0是對(duì)時(shí)鐘寄存器的讀寫操作,為1對(duì)是控制對(duì)RAM區(qū)的讀寫操作。

bit1 -- 5 是對(duì)相關(guān)寄存器的操作,bit0是讀寫操作。

e4fce3fc-cbc1-11ef-9310-92fbcf53809c.png

各個(gè)寄存器的的設(shè)置,和每位的表示如下圖,從圖中我們了解到讀寫時(shí)控制字是多少以及寫入寄存器的地址,和寫入的8位的時(shí)間表示。我們可以通過(guò)下表來(lái)設(shè)置一個(gè)初始的時(shí)間。

e529a9a0-cbc1-11ef-9310-92fbcf53809c.png

涓流寄存器主要決定了DS1302的充電特性,涓流充電選擇位4--7位,1010涓流充電其他禁止充電,二級(jí)管選擇位3--2位,電阻選擇1--0位具體的選擇如下表。

e557bbe2-cbc1-11ef-9310-92fbcf53809c.png

突發(fā)模式下,表示我們可以連續(xù)寫,連讀,連續(xù)寫時(shí)必須寫滿7個(gè)時(shí)鐘寄存器。時(shí)序圖如下,SPI通信。

e5769800-cbc1-11ef-9310-92fbcf53809c.png

下表表示數(shù)據(jù)傳送過(guò)程中數(shù)據(jù)的延遲,時(shí)鐘的周期等時(shí)間。

e5a9c504-cbc1-11ef-9310-92fbcf53809c.png

e5d31602-cbc1-11ef-9310-92fbcf53809c.png

本次設(shè)計(jì)是通過(guò)配置DS1302芯片來(lái)實(shí)現(xiàn)實(shí)時(shí)時(shí)鐘的監(jiān)測(cè),通過(guò)控制2個(gè)按鍵來(lái)選擇我們要在數(shù)碼管上顯示的時(shí)間,按下按鍵1來(lái)顯示周幾,按下按鍵2來(lái)顯示年月日,不按顯示時(shí)分秒,這樣顯示符合實(shí)時(shí)鐘的顯示。思路是先打開(kāi)寫保護(hù),一個(gè)一個(gè)寄存器的寫進(jìn)去,然后關(guān)閉寫保護(hù),然后再讀出數(shù)據(jù)。 設(shè)計(jì)架構(gòu)圖:

e5ea16b8-cbc1-11ef-9310-92fbcf53809c.png

設(shè)計(jì)代碼:(源碼文件可從公眾號(hào)內(nèi)部獲?。?總模塊:

e5fcd078-cbc1-11ef-9310-92fbcf53809c.png

控制模塊:(由于控制模塊代碼較多,只展示部分關(guān)鍵信號(hào),具體代碼如有需要,請(qǐng)公眾號(hào)內(nèi)自行獲?。?/p>

e61e5a04-cbc1-11ef-9310-92fbcf53809c.png

e63fbd98-cbc1-11ef-9310-92fbcf53809c.png

數(shù)碼管模塊:

e6672b80-cbc1-11ef-9310-92fbcf53809c.png

e68a4746-cbc1-11ef-9310-92fbcf53809c.png

e6a61098-cbc1-11ef-9310-92fbcf53809c.png

測(cè)試模塊:(Mmodelsim 仿真

e6d090ca-cbc1-11ef-9310-92fbcf53809c.png

仿真圖:

e6e563f6-cbc1-11ef-9310-92fbcf53809c.png

從仿真測(cè)試圖中,可以清楚的看到在發(fā)送的寄存器命令時(shí),收回總線控制權(quán),讀數(shù)據(jù)時(shí),釋放了總線控制權(quán)。 下圖是突發(fā)讀的時(shí)序圖,此次設(shè)計(jì)是一個(gè)一個(gè)的寫寄存器,必須寫滿7個(gè)時(shí)鐘寄存器,然后突發(fā)的讀,突發(fā)讀的時(shí)候拉高CE,然后不停的讀接收數(shù)據(jù)。拓展也可以做突發(fā)讀寫,原理一樣,感興趣的可以試一試。

e70c2a54-cbc1-11ef-9310-92fbcf53809c.png

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1629

    文章

    21753

    瀏覽量

    604173
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5357

    瀏覽量

    120611
  • 實(shí)時(shí)時(shí)鐘

    關(guān)注

    4

    文章

    246

    瀏覽量

    65828
  • 時(shí)鐘電路
    +關(guān)注

    關(guān)注

    10

    文章

    237

    瀏覽量

    50753

原文標(biāo)題:源碼系列:基于FPGA實(shí)時(shí)時(shí)鐘的設(shè)計(jì)(附源工程)

文章出處:【微信號(hào):HXSLH1010101010,微信公眾號(hào):FPGA技術(shù)江湖】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    STM32 RTC實(shí)時(shí)時(shí)鐘(一)

    STM32處理器內(nèi)部集成了實(shí)時(shí)時(shí)鐘控制器(RTC),因此在實(shí)現(xiàn)實(shí)時(shí)時(shí)鐘功能時(shí),無(wú)須外擴(kuò)時(shí)鐘芯片即可構(gòu)建實(shí)時(shí)時(shí)鐘系統(tǒng)。
    的頭像 發(fā)表于 07-22 15:41 ?4741次閱讀
    STM32 RTC<b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>(一)

    【自制】Arduino:oled0-96實(shí)時(shí)時(shí)鐘顯示(mini桌面時(shí)鐘part12

    實(shí)時(shí)時(shí)鐘Arduino
    新創(chuàng)司XLOT
    發(fā)布于 :2022年03月01日 16:24:34

    基于FPGA實(shí)時(shí)時(shí)鐘設(shè)計(jì)

    基于FPGA實(shí)時(shí)時(shí)鐘設(shè)計(jì)
    發(fā)表于 12-06 20:40

    實(shí)時(shí)時(shí)鐘是什么

    定義:實(shí)時(shí)時(shí)鐘的縮寫是RTC(Real Time Clock).實(shí)時(shí)時(shí)鐘是一個(gè)獨(dú)立的定時(shí)器。RTC模塊擁有一組連續(xù)計(jì)數(shù)的計(jì)數(shù)哭奮,在相應(yīng)軟件配置下,可提供時(shí)鐘日歷的功能。修改計(jì)數(shù)器的值可以重新設(shè)置系統(tǒng)當(dāng)前的時(shí)間和日期。...
    發(fā)表于 08-09 06:18

    實(shí)時(shí)時(shí)鐘模DS1302程序列子

    實(shí)時(shí)時(shí)鐘模DS1302程序列子     /*********************************************************************//* 實(shí)時(shí)時(shí)鐘模塊
    發(fā)表于 07-08 16:26 ?142次下載

    ARM基礎(chǔ)應(yīng)用實(shí)驗(yàn)_實(shí)時(shí)時(shí)鐘

    ARM嵌入式應(yīng)用程序架構(gòu)設(shè)計(jì)實(shí)例精講--ARM基礎(chǔ)應(yīng)用實(shí)驗(yàn)03實(shí)時(shí)時(shí)鐘
    發(fā)表于 07-08 11:08 ?0次下載

    基于實(shí)時(shí)時(shí)鐘模塊 時(shí)鐘芯片DS1302

    基于實(shí)時(shí)時(shí)鐘模塊 時(shí)鐘芯片DS1302
    發(fā)表于 10-16 11:35 ?40次下載
    基于<b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>模塊 <b class='flag-5'>時(shí)鐘</b>芯片DS1302

    實(shí)時(shí)時(shí)鐘芯片有哪些_實(shí)時(shí)時(shí)鐘芯片選型介紹

    本文主要介紹了時(shí)鐘芯片有哪些、時(shí)鐘芯片結(jié)構(gòu)與工作原理,其次介紹了時(shí)鐘芯片布線與時(shí)鐘芯片的作用,最后介紹了時(shí)鐘芯片選型以及愛(ài)普生
    發(fā)表于 01-29 08:44 ?4w次閱讀
    <b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>芯片有哪些_<b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>芯片選型介紹

    實(shí)時(shí)時(shí)鐘芯片應(yīng)用

    對(duì)于一些測(cè)控系統(tǒng)或者手持式設(shè)備,經(jīng)常需要顯示以及設(shè)定時(shí)間。目前,市場(chǎng)上有多種實(shí)時(shí)時(shí)鐘芯片提供了這類功能。這種可編程的實(shí)時(shí)時(shí)鐘芯片內(nèi)置了可編程的日歷時(shí)鐘以及一定的RAM存儲(chǔ)器,用于設(shè)定以及保存時(shí)間
    發(fā)表于 03-16 15:31 ?14次下載
    <b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>芯片應(yīng)用

    實(shí)時(shí)時(shí)鐘的硬件結(jié)構(gòu)_實(shí)時(shí)時(shí)鐘故障怎么解決

     實(shí)時(shí)時(shí)鐘的縮寫是RTC(Real_Time Clock)。RTC 是集成電路,通常稱為時(shí)鐘芯片。
    的頭像 發(fā)表于 11-16 17:10 ?7192次閱讀
    <b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>的硬件結(jié)構(gòu)_<b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>故障怎么解決

    淺談RTC實(shí)時(shí)時(shí)鐘特征與原理

    一、RTC實(shí)時(shí)時(shí)鐘特征與原理 查看STM32中文手冊(cè) 16 實(shí)時(shí)時(shí)鐘(RTC)(308頁(yè)) RTC (Real Time Clock):實(shí)時(shí)時(shí)鐘 實(shí)時(shí)時(shí)鐘是一個(gè)獨(dú)立的定時(shí)器。RTC模塊
    的頭像 發(fā)表于 06-30 15:54 ?1.1w次閱讀

    實(shí)時(shí)時(shí)鐘RTC】MSP430系統(tǒng)實(shí)時(shí)時(shí)鐘RTC學(xué)習(xí)日志(完善中)

    2012.1.11 讀取實(shí)時(shí)時(shí)鐘: 1、 RTCRDY 為0時(shí),不能取讀取實(shí)時(shí)時(shí)鐘 RT0PS源于ACLK,為了實(shí)時(shí)時(shí)鐘日歷的正確的運(yùn)行,ACLK必須是32768Hz。(易出錯(cuò)) 定時(shí)
    發(fā)表于 12-16 16:56 ?10次下載
    【<b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>RTC】MSP430系統(tǒng)<b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>RTC學(xué)習(xí)日志(完善中)

    CW32實(shí)時(shí)時(shí)鐘(RTC)介紹

    CW32實(shí)時(shí)時(shí)鐘(RTC)介紹
    的頭像 發(fā)表于 10-24 15:36 ?1172次閱讀
    CW32<b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>(RTC)介紹

    Arduino篇—實(shí)時(shí)時(shí)鐘

    DS1307時(shí)鐘模塊:** DS1307串行實(shí)時(shí)時(shí)鐘(RTC)是低功耗,全二進(jìn)制編碼的十進(jìn)制(BCD)時(shí)鐘/日歷以及56字節(jié)的NV SRAM。
    的頭像 發(fā)表于 11-01 16:49 ?2260次閱讀
    Arduino篇—<b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>

    使用實(shí)時(shí)時(shí)鐘庫(kù)

    電子發(fā)燒友網(wǎng)站提供《使用實(shí)時(shí)時(shí)鐘庫(kù).pdf》資料免費(fèi)下載
    發(fā)表于 10-22 10:09 ?0次下載
    使用<b class='flag-5'>實(shí)時(shí)時(shí)鐘</b>庫(kù)