欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

標(biāo)題: 請問關(guān)于單片機(jī)C語言尋址方式與匯編語言棧的問題 [打印本頁]

作者: lyonkon    時間: 2023-4-11 20:11
標(biāo)題: 請問關(guān)于單片機(jī)C語言尋址方式與匯編語言棧的問題
一:請問一下c語言尋址方式有幾種,以怎樣的語句流程實現(xiàn)以下的需求的
1:  80H地址 = FFEFH地址的值+P1端口的值       80H=FFEFH+P1         用c語言如何表達(dá)



2:  80H地址 =變量 A的值+P1端口的值
         80H = A+P1           用c語言如何表達(dá)

3: 80H地址 =變量 A的值+0x35
         80H = A+0x35        用c語言如何表達(dá)

4: 80H地址 =數(shù)字0x35+數(shù)字0x35
       80H =0x35+0x35      用c語言如何表達(dá)

二:請問關(guān)于“用棧傳遞參數(shù)”這個詞語。我寫匯編程序的時候,也嘗試用 push  pop給地址賦值,但是用mov指令也可以達(dá)到
       將80h的值賦給81h    mov 81h,80h        
                               push 81h
                               push 80h
                               pop 81h
                               pop 80h         還是棧傳遞參數(shù)比mov指令有特殊的意義

作者: Hephaestus    時間: 2023-4-11 20:55
1)前面4個問題你沒有說明80H位于哪個空間?是idata、pdata還是xdata,所以無法回答。

2)堆棧傳遞函數(shù)是標(biāo)準(zhǔn)c語言的做法,但是c51不是標(biāo)準(zhǔn)c語言,8051這個內(nèi)核太弱了用標(biāo)準(zhǔn)c語言實現(xiàn)過于浪費(fèi)資源,所以你的問題無意義。
作者: zhuls    時間: 2023-4-11 21:34
我記得用MOV會改變C和DC位,而PUSH、POP則不會。
作者: Hephaestus    時間: 2023-4-12 01:13
zhuls 發(fā)表于 2023-4-11 21:34
我記得用MOV會改變C和DC位,而PUSH、POP則不會。

通過ACC的MOV當(dāng)然會改變PSW標(biāo)志位,然而mov 81h,80h這個不通過ACC的指令???
注:mov 81h,80h這句話也是錯的,指令本身沒問題,后面的兩個操作數(shù)大于7fh在邏輯上錯了。

作者: lyonkon    時間: 2023-4-12 07:06
Hephaestus 發(fā)表于 2023-4-11 20:55
1)前面4個問題你沒有說明80H位于哪個空間?是idata、pdata還是xdata,所以無法回答。

2)堆棧傳遞函數(shù) ...

80h是指用@R0,或者@R1 訪問的那個128字節(jié)地址
作者: zhuls    時間: 2023-4-12 08:46
Hephaestus 發(fā)表于 2023-4-12 01:13
通過ACC的MOV當(dāng)然會改變PSW標(biāo)志位,然而mov 81h,80h這個不通過ACC的指令???
注:mov 81h,80h這句話也 ...

不是很懂畢竟沒有系統(tǒng)地學(xué)過,就是在翻書時看到的
作者: 188610329    時間: 2023-4-12 16:23
你的問題,必須匯編 和 C 都懂得才能回答,但是,你的描述,又非常的不確切,讓人無從切入,不如你先把你一 當(dāng)中的問題用匯編表述出來,然后,再跟你講 C 里面如果實現(xiàn)吧。

先回答你  二的問題。
MOV   81H,80H
是把  81H地址的值  賦值到 80H地址, 最終的結(jié)果,是81H 和 80H 地址的 內(nèi)容 完全相等。

而,
PUSH 81H
PUSH 80H
POP 81H
POP 80H
是把  81H  和  80H  兩個地址的 內(nèi)容互相交換,最終  81H 地址的內(nèi)容 為原  80H地址的內(nèi)容,而80H 地址的內(nèi)容為原81地址的內(nèi)容,要達(dá)到這個目的,不使用堆棧的話,不能簡單地用MOV 要用如下指令:
XCH  A,80H
XCH  A,81H
XCH  A,80H
這個最終結(jié)果和通過堆棧 交換數(shù)據(jù)的結(jié)果是一樣的。效率也要高一點,所以,用堆棧交換數(shù)據(jù),實際沒有太大的意義。
作者: lyonkon    時間: 2023-4-12 17:13
188610329 發(fā)表于 2023-4-12 16:23
你的問題,必須匯編 和 C 都懂得才能回答,但是,你的描述,又非常的不確切,讓人無從切入,不如你先把你一 ...

第一個問題,是想知道c語言對 80h地址 片外地址 端口p1  變量 的值 立即數(shù) 的語句流程
1:MOV
      MOV DPTR,#FFEFH
     MOV A,@DPTR
     
     
作者: Hephaestus    時間: 2023-4-12 17:19
lyonkon 發(fā)表于 2023-4-12 07:06
80h是指用@R0,或者@R1 訪問的那個128字節(jié)地址

那你聲明變量的時候加個idata修飾就可以了,指定80h地址毫無意義。
作者: lyonkon    時間: 2023-4-12 17:25
188610329 發(fā)表于 2023-4-12 16:23
你的問題,必須匯編 和 C 都懂得才能回答,但是,你的描述,又非常的不確切,讓人無從切入,不如你先把你一 ...

1:MOV R0,#80H
  MOV DPTR,#FFEFH
   MOV A,@DPTR
   ADD A,P1
   MOV @R0,A
我主要想知道,c語言片內(nèi),片外,尋址語句方式流程。并且運(yùn)算的時候是不是先將地址中的值取到變量再計算。
作者: Hephaestus    時間: 2023-4-12 17:38
lyonkon 發(fā)表于 2023-4-12 17:25
1:MOV R0,#80H
  MOV DPTR,#FFEFH
   MOV A,@DPTR

片內(nèi)0~7fh是data(可以不寫),80h以上要加idata修飾,片外用pdata或者xdata修飾,如果你真的懂了匯編應(yīng)該能馬上理解pdata和xdata的區(qū)別。
作者: 188610329    時間: 2023-4-12 20:35
lyonkon 發(fā)表于 2023-4-12 17:25
1:MOV R0,#80H
  MOV DPTR,#FFEFH
   MOV A,@DPTR

方法一:
unsigned char idata *pd;
unsigned char xdata *px;
pd = 0x80;
px = 0xffef;
*pd = *px + P1;

方法二:
unsigned char idata temp1 _at_ 0x80;
unsigned char xdata temp2 _at_ 0xffef;
temp1 = temp2 + P1;

方法三:
*((unsigned char idata *)0x80) = *((unsigned char xdata *)0xffef) + P1;

以上三個方法,均可達(dá)到你匯編代碼的目的,至于到底該用哪種方法,隨著你C語言學(xué)習(xí)的深入,自己會有決斷。

作者: lyonkon    時間: 2023-4-12 21:26
188610329 發(fā)表于 2023-4-12 20:35
方法一:
unsigned char idata *pd;
unsigned char xdata *px;

依據(jù)您的例程,以下是我理解。c語言的尋址方式是通過聲明地址變量,進(jìn)行間接尋址。類似與@RI,和@dptr。  *pd = *px + P1;可以以間接尋址的形式,參與運(yùn)算表達(dá)式。
非常感謝您的解答,我應(yīng)該理解了。
作者: yuxuesuixing    時間: 2023-4-13 09:21
lyonkon 發(fā)表于 2023-4-12 21:26
依據(jù)您的例程,以下是我理解。c語言的尋址方式是通過聲明地址變量,進(jìn)行間接尋址。類似與@RI,和@dptr。  ...

匯編語言直接對應(yīng)機(jī)器碼,機(jī)器碼的重點是針對不同的機(jī)器乃至不同的型號操作都是不同的。

例如你用匯編訪問寄存器,你是以寄存器的實際地址來訪問的,而且就簡單的MOV指令就分為MOV、MOVC、MOVX,在C中是沒有這三種MOV指令的區(qū)別,乃至你換到其他架構(gòu)系統(tǒng)也是直接轉(zhuǎn)移的,而你的匯編程序要全部重寫一遍。

所謂的高級語言就是通用性更強(qiáng),適配性更強(qiáng)。比如你用c在51 和32之間轉(zhuǎn)換使用,只說算法層面不說外設(shè),你只需要把例如int等數(shù)據(jù)變量重新調(diào)整一下。

你強(qiáng)制讓c去訪問固定地址,編程上是可以的,但是沒有意義,因為對于數(shù)據(jù)來說存無論存儲在20H還是21H都是一樣的,可能你說,不知道地址怎么行,存儲器用滿了怎么辦?編譯器:不用在意我,我會出手。編譯器在編譯時會自動檢測剩余內(nèi)存和其他資源以及錯誤,所以,不要擔(dān)心
作者: Hephaestus    時間: 2023-4-13 12:18
yuxuesuixing 發(fā)表于 2023-4-13 09:21
匯編語言直接對應(yīng)機(jī)器碼,機(jī)器碼的重點是針對不同的機(jī)器乃至不同的型號操作都是不同的。

例如你用匯編 ...

標(biāo)準(zhǔn)c當(dāng)然不區(qū)分,但是C51會區(qū)分這三種指令。
MOV對應(yīng)data(默認(rèn),可以不寫),idata和SFR空間
MOVC對應(yīng)code空間
MOVX對應(yīng)pdata和xdata空間

高級語言通用性強(qiáng),但是死忒慘這個螺螄殼里面很難做道場的,所以C51沒有通用性。
作者: lyonkon    時間: 2024-2-20 17:45
謝謝各位朋友的解答。
直到現(xiàn)在才有能力描述這個問題,當(dāng)時是想模仿c語言寫一套通用的命令子程序集,寫程序時候可以隨意調(diào)。因為不知道具體需要什么功,就相當(dāng)于沒找到需求就擱置了。不曾想現(xiàn)在有了需求;


上面這個程序,因為R0,R1,在子程序中要使用,沒有剩下其他寄存器可用 R0,R1,又無法入,將R0,R1先寫入內(nèi)存 當(dāng)棧使用妥協(xié)辦法。

下面這個程序,將相同功能的程序?qū)懥藘杀椋蓚固化值。因為只使用一次,所以偷點懶感覺沒有問題。



現(xiàn)在的問題是,調(diào)用子程  要傳遞值進(jìn)去,然后子程序執(zhí)行完了結(jié)果還要留著。目前我是使用以下方法,
使用內(nèi)存?zhèn)鬟f值。請老師指點一下。





作者: Hephaestus    時間: 2024-2-20 18:03
R0、R1一共有4組,用register bank區(qū)分,可以不需要壓棧保護(hù)。樓主從去年就開始搞cortex-M和51匯編,為什么到現(xiàn)在還沒有入門?
作者: lyonkon    時間: 2024-2-20 22:27
Hephaestus 發(fā)表于 2024-2-20 18:03
R0、R1一共有4組,用register bank區(qū)分,可以不需要壓棧保護(hù)。樓主從去年就開始搞cortex-M和51匯編,為什么 ...

這樣可以將相同性質(zhì)的數(shù)據(jù)放在一個寄存器頁面。謝謝!
一直在調(diào)試stm32硬件,過程中匯編程序不復(fù)雜。硬件現(xiàn)在調(diào)試差不多了。著手寫復(fù)雜點程序的時候,發(fā)現(xiàn)了問題。程序之間數(shù)據(jù)傳遞,我一直都是放在指定內(nèi)存中使用的。我覺得這樣可能不規(guī)范,所以想規(guī)范一下。相當(dāng)于匯編語言現(xiàn)在才開始學(xué)。
如果是arm內(nèi)核,里面R0--R15只有一個頁面,程序之間傳遞數(shù)據(jù)




歡迎光臨 (http://www.raoushi.com/bbs/) Powered by Discuz! X3.1