當前位置:首頁 > 芯聞號 > 充電吧
[導讀]遇到了幾個問題,都是說 P0 口可以輸出 1 的,P0 口內(nèi)部的電路圖,并不是人人都可以看懂的,很多人都要看文字說明。但是,有些說明寫的,很是差強人意,接口電路的基本功能特點,往往都解釋錯了。在單片機


遇到了幾個問題,都是說 P0 口可以輸出 1 的,


P0 口內(nèi)部的電路圖,并不是人人都可以看懂的,很多人都要看文字說明。

但是,有些說明寫的,很是差強人意,接口電路的基本功能特點,往往都解釋錯了。


在單片機的外部擴充存儲空間時,有一種三總線方式,此時,P0 口,將負責對外部芯片傳送數(shù)據(jù)和低八位地址。

這時,P0 口就是以三態(tài)門的特點來工作,即可以輸出高、低電平,還可以切斷與外界的聯(lián)系,在引腳上呈現(xiàn)“高阻態(tài)”。


就目前來看,絕大部分單片機系統(tǒng)都不使用三總線形式來擴充外部空間了,三態(tài)門的現(xiàn)象,基本上,已經(jīng)看不到了。


現(xiàn)在一般都是把 P0 口當一般的 IO 接口來使用。此時,P0 口就只有兩種狀態(tài):輸出低電平和高阻態(tài)。

想要讓 P0 口輸出 1,單片機就沒有這種能力了。

----------------------

在英文版的 AT89C51 的數(shù)據(jù)文件中,節(jié)選一段關(guān)于 P0 的文字如下:


Port 0

Port 0 is an 8-bit open drain bidirectional I/O port.?

As an output port, each pin can sink eight TTL inputs.?

When 1s are written to port 0 pins, the pins can be used as high-impedance inputs.


Port 0 can also be configured to be the multiplexed low-order address/data bus during accesses to external program and data memory.

In this mode, P0 has internal pull-ups.


利用網(wǎng)上的翻譯軟件,把它們譯成中文,再簡單整理如下:


P0

P0 是一個 8 位漏極開路雙向 I/O 端口。

作為一個輸出端口,每個引腳可以吸收 8 個 TTL 輸入。

當把 1 寫入 P0 引腳,這些引腳可以用作高阻抗輸入。


在訪問期間外部程序和數(shù)據(jù)存儲器期間,P0 也可以被配置為復(fù)用的低位地址/數(shù)據(jù)總線。

在這種模式下,P0 具有內(nèi)部上拉。

----------------------

在上述的數(shù)據(jù)文件中,已經(jīng)明確說明,P0 口的引腳,是“開漏”的。

P0 可以輸出低電平,驅(qū)動 8 個 TTL 器件的輸入引腳。令 P0 輸出 1,它只能當做高阻的輸入端,而輸出不了 1。

只有在訪問期間外部程序和數(shù)據(jù)存儲器時,引腳內(nèi)部才有上拉的功能,這時才是“三態(tài)門”。

----------------------

“P0端口由于輸出有三態(tài)功能,輸入前,端口線已處于高阻態(tài),無需先寫入l后再作讀操作。”

不太明白。從圖中看出P0要是不置位的話,T2就會導通了。輸入信號不都變成0了嗎?


做而論道回答如下:

首先,《P0端口由于輸出有三態(tài)功能,》這句話,就是錯誤的。

作為 IO 口使用時,P0,只有輸出0 和高阻態(tài),兩種,并不能輸出1,談不上三態(tài)。

《P0端口由于輸出有三態(tài)功能,》這句話,用在總線方式,還可以;

但是,總線方式,就和《先寫入1再讀》毫無關(guān)系了。

--------------

第二,《輸入前,端口線已處于高阻態(tài)》這句話,只是作者自己的臆想而已。

輸入前,如果輸出了0,顯然就不是高阻態(tài)。


--追問:

--讀鎖存器,是不是先會將引腳信號通過D鎖存后,再關(guān)閉引腳,然后再讀鎖存器啊。

--如果不是的話,那圖中進入總線的輸入信號從 何而來呢?

?


做而論道回答:

讀鎖存器,就是讀先前曾經(jīng)輸出的內(nèi)容,和引腳無關(guān)。

讀鎖存器,用的是一些特殊的指令,即稱為《讀_改_寫》的指令。

比如:ANL ? P0, #0FH。

這條指令,自動打開圖中上邊的三態(tài)門,信號由 D 經(jīng)過三態(tài)門,流動到內(nèi)部總線(如粗紅線所示);

再和 0FH 相與之后,再寫入鎖存器;

最后輸出到 P0 引腳。


--追問:

--謝謝詳細解答~~。另外,有些不解的是:

--讀鎖存器,是 屬于'輸入'的情況嗎?

--如果是,那輸入的信號只能從下面的”緩沖器“部分進來啊。要不然,讀的是以前的信息,跟外部信息 沒有關(guān)系啊。


做而論道回答:

前面已經(jīng)說過了:讀鎖存器,就是讀先前曾經(jīng)輸出的內(nèi)容,和引腳無關(guān)。

《讀_改_寫》指令,如:ANL ? P0, #0FH

這里的 P0,并非是馬上,去讀一下引腳的信號,而是讀鎖存器,也就是讀出以前曾經(jīng)輸出的。





本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉