當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]ADD指令將源操作數(shù)和累加器A中的數(shù)相加,加法的結(jié)果存入累加器A,并且運(yùn)算結(jié)果會(huì)影響PSW中的CY、OV、AC和P標(biāo)志位。ADD指令對(duì)標(biāo)志位的影響如下:當(dāng)加法結(jié)果的第7位有進(jìn)位時(shí),則進(jìn)位標(biāo)志位CY被置1,否則被清0;如果加法結(jié)果的第3位有進(jìn)位,則輔助進(jìn)位標(biāo)志位AC被置1,否則被清0;如果加法結(jié)果的第6位和第7位的進(jìn)位情況不一致,則溢出標(biāo)志位OV被置1,否則被清0;運(yùn)算結(jié)束時(shí),奇偶標(biāo)志位P的值由累加器A中的數(shù)決定,若累加器A中的值以二進(jìn)制表示后,其中“1”的個(gè)數(shù)為奇數(shù)個(gè),則P為1,否則P為0。

算術(shù)運(yùn)算指令包括加、減、乘和除法指令,其語(yǔ)法格式見表3-7。由表3-7可知,算術(shù)運(yùn)算指令會(huì)對(duì)PSW中的某些位產(chǎn)生影響。

1.加法指令A(yù)DD和ADDC

ADD指令將源操作數(shù)和累加器A中的數(shù)相加,加法的結(jié)果存入累加器A,并且運(yùn)算結(jié)果會(huì)影響PSW中的CY、OV、AC和P標(biāo)志位。ADD指令對(duì)標(biāo)志位的影響如下:當(dāng)加法結(jié)果的第7位有進(jìn)位時(shí),則進(jìn)位標(biāo)志位CY被置1,否則被清0;如果加法結(jié)果的第3位有進(jìn)位,則輔助進(jìn)位標(biāo)志位AC被置1,否則被清0;如果加法結(jié)果的第6位和第7位的進(jìn)位情況不一致,則溢出標(biāo)志位OV被置1,否則被清0;運(yùn)算結(jié)束時(shí),奇偶標(biāo)志位P的值由累加器A中的數(shù)決定,若累加器A中的值以二進(jìn)制表示后,其中“1”的個(gè)數(shù)為奇數(shù)個(gè),則P為1,否則P為0。

ADDC指令與ADD指令的唯一區(qū)別是,前者在源操作數(shù)和累加器A的加法基礎(chǔ)上再加上CY中的值。

2.十進(jìn)制調(diào)整指令DA

指令A(yù)DD和ADDC將其源操作數(shù)和目的操作數(shù)作為二進(jìn)制數(shù)(或十六進(jìn)制數(shù))進(jìn)行加法計(jì)算,遵循“逢2進(jìn)1”(或“逢16進(jìn)1”)的二進(jìn)制(或十六進(jìn)制)計(jì)算規(guī)則,得到的運(yùn)算結(jié)果為二進(jìn)制數(shù)(或十六進(jìn)制數(shù))。如果用ADD和ADDC指令進(jìn)行壓縮BCD碼(十進(jìn)制數(shù))的加法計(jì)算,則得不到正確的十進(jìn)制計(jì)算結(jié)果,而使用DA指令可以將ADD和ADDC指令的運(yùn)算結(jié)果調(diào)整為十進(jìn)制的運(yùn)算結(jié)果。

使用“DA A”指令進(jìn)行十進(jìn)制調(diào)整時(shí),必須滿足以下要求:在DA指令之前必須進(jìn)行ADD或ADDC加法運(yùn)算,并且參與加法運(yùn)算的操作數(shù)必須是壓縮BCD碼數(shù)。

“DA A”指令調(diào)整時(shí),先處理“個(gè)位”,再處理“十位”,“個(gè)位”的處理結(jié)果將影響“十位”的調(diào)整,具體步驟如下:

(1)調(diào)整BCD碼運(yùn)算結(jié)果的“個(gè)位”

1)若累加器A中運(yùn)算結(jié)果的“個(gè)位”(即低4位)數(shù)大于9(非BCD碼),則在累加器A的“個(gè)位”上加“6”。這樣做是因?yàn)椋涸贐CD碼計(jì)算時(shí),結(jié)果大于9則應(yīng)產(chǎn)生進(jìn)位,但是ADD和ADDC按照十六進(jìn)制進(jìn)行計(jì)算,只有結(jié)果大于15時(shí)才進(jìn)位,從而導(dǎo)致“晚”進(jìn)位,所以此時(shí)加“6”相當(dāng)于將“逢16進(jìn)1”的十六進(jìn)制運(yùn)算強(qiáng)制調(diào)整為“逢10進(jìn)1”十進(jìn)制運(yùn)算。

2)若累加器A中運(yùn)算結(jié)果的“個(gè)位”(即低4位)產(chǎn)生進(jìn)位(輔助進(jìn)位標(biāo)志位(AC)=1),則在累加器A的“個(gè)位”上加“6”。這樣處理的理由是:“個(gè)位”產(chǎn)生進(jìn)位,意味著BCD碼加法結(jié)果的個(gè)位大于15而產(chǎn)生了進(jìn)位,但是該進(jìn)位將使BCD碼加法結(jié)果的個(gè)位數(shù)被減去16,而正常的十進(jìn)制加法進(jìn)位應(yīng)該使個(gè)位數(shù)被減去10,所以需通過(guò)加“6”操作補(bǔ)上多減去的“6”。

(2)調(diào)整BCD碼運(yùn)算結(jié)果的“十位”

若累加器A中運(yùn)算結(jié)果的“十位”(即高4位)數(shù)大于9(非BCD碼)或累加器A中“十位”產(chǎn)生進(jìn)位(進(jìn)位標(biāo)志位(CY)=1),則在累加器A的“十位”上加“6”。這樣做的原因與步驟(1)相似。

【例3-34】DA指令舉例。

以下程序段可以完成壓縮BCD碼的加法運(yùn)算88H+02H=90H。

3.減法指令SUBB

SUBB指令將累加器A中的數(shù)減去源操作數(shù)和進(jìn)位標(biāo)志位CY,并將減法結(jié)果存入累加器A,其運(yùn)算結(jié)果會(huì)影響PSW中的CY、OV、AC和P標(biāo)志位。SUBB指令對(duì)標(biāo)志位的影響如下:當(dāng)減法的第7位有借位時(shí),則進(jìn)位標(biāo)志位CY被置1,否則被清0;如果減法結(jié)果的第3位有借位,則輔助進(jìn)位標(biāo)志位AC被置1,否則被清0;如果減法結(jié)果的第6位和第7

位的借位情況不一致,則溢出標(biāo)志位被置1,否則被清0;運(yùn)算結(jié)束時(shí),奇偶標(biāo)志位P的值由累加器A中的數(shù)決定,若累加器A中的值以二進(jìn)制表示后,其中“1”的個(gè)數(shù)為奇數(shù)個(gè),則(P)=1,否則(P)=0。

【例3-35】SUBB指令舉例。確定下段程序執(zhí)行后,累加器A和PSW的值。

解:運(yùn)行結(jié)果是(A)=8CH、(PSW)=0C1H(即P=1、OV=0、AC=1和CY=1)。

4.加1指令I(lǐng)NC和減1指令DEC

INC指令和DEC指令分別對(duì)指令中唯一的操作數(shù)進(jìn)行加1和減1操作,并將結(jié)果送回操作數(shù)。除了“INC A”和“DEC A”指令將影響奇偶標(biāo)志位P以外,其他INC和DEC指令均不影響任何標(biāo)志位。注意:這里所說(shuō)的“不影響”是指標(biāo)志位原來(lái)的狀態(tài)保持不變。另外,“INC DPTR”指令進(jìn)行16位數(shù)加1操作,該指令執(zhí)行時(shí),先將DPL加1,若產(chǎn)生進(jìn)位,則將DPH加1,并且DPL加1和DPH加1產(chǎn)生的進(jìn)位不影響AC和CY。另外,無(wú)“DEC DPTR”指令。

還需特別注意的是:若用INC和DEC修改單片機(jī)并行I/O口(P0~P3)的引腳狀態(tài),如指令“INC P0”,則指令執(zhí)行時(shí)采用的是“讀-修改-寫”方式,即先從端口的輸出鎖存器(而不是端口的引腳)讀取端口數(shù)據(jù),然后修改該數(shù)據(jù)(INC指令進(jìn)行加1操作,DEC指令進(jìn)行減1操作),最后將修改結(jié)果輸出到端口引腳上。

5.乘法指令MUL

乘法指令的格式見表3-7,乘法的被乘數(shù)和乘數(shù)均為8位無(wú)符號(hào)數(shù),且默認(rèn)存放在累加器A和寄存器B中。乘積為16位無(wú)符號(hào)數(shù),其低8位存放于累加器A中,高8位存放在寄存器B中,如圖3-2所示。

圖3-2乘法指令示意圖

乘法指令對(duì)標(biāo)志位的影響為:若乘積大于0FFH,則溢出標(biāo)志位OV被置1,否則被清0;進(jìn)位標(biāo)志位總會(huì)被乘法指令清0。

6.除法指令DIV

除法指令的格式見表3-7。與乘法指令相似,除法指令的被除數(shù)和除數(shù)均為8位無(wú)符號(hào)數(shù),被除數(shù)默認(rèn)放在累加器A中,除數(shù)默認(rèn)放在寄存器B中。除法的商和余數(shù)均為8位無(wú)符號(hào)數(shù),分別存于累加器A中和寄存器B中,如圖3-3所示。

圖3-3除法指令示意圖

除法指令對(duì)標(biāo)志位的影響:若除數(shù)不為0,則溢出標(biāo)志位OV和進(jìn)位標(biāo)志位CY均被清0;若除數(shù)為0,則溢出標(biāo)志位(OV)被置為1,且累加器A和寄存器B的值是不確定的。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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