跳转指令微型计算机,哪种类型的汇编程序跳转指令最有用?
Ira Baxter..
5
(我已經為匯編程序編寫了40多年;實際上在20世紀70年代早期設計并構建了一個生產多寄存器16位機器).真正有用的是CMP指令和指定該條件的JMP相對.
我建議你讓算術指令產生狀態位
零結果
從結果出發
結果的標志
溢出(簽名)
我們稱之為"條件位".你會發現它們都很有用.
你的比較指令基本上應該做一個減法,然后把答案扔掉,設置條件位.
您的JMP指令應使用16個操作碼之一,3位條件選擇器和PC的9位相對偏移量,例如,與PC的跳轉相對條件.短相對分支在代碼中非常有用.
3位條件選擇器應使用兩位來選擇4個條件中的一個,并使用一位來選擇"反轉".這樣你可以有"jmp zero","jmp not zero"等.
您可以將"跳過無溢出"視為"始終跳躍"; 這些代碼非常方便.(我不明白你怎么想"jmp無條件"和"從子程序返回"可以是同一條指令).
從討論中的評論來看,似乎你沒有任何注冊.從代碼緊湊性(特別是16位指令)和性能(寄存器訪問速度總是快于內存)來看,這是一個嚴重的錯誤.在操作碼命名寄存器后,我會使用2或3或12位.
Aha:在編輯中,OP注意到他有A和B寄存器,可能是由操作碼隱式選擇的.我設計的機器受PDP-11的啟發,但有16個基本操作碼和8個寄存器(留下9位"操作數"),它在編碼方面確實有所不同.大多數指令將這9位分為尋址模式和偏移:直接(使用第二個字作為地址),立即(第二個字),立即(7位,意味著機器可以輕松處理ASCII文本),間接第二個寄存器自動 - 增量,間接第二個寄存器自動遞減,相對于第二個寄存器的短偏移,以及相對于寄存器的第二個字偏移.它沒有堆棧,但您可以使用auto-inc/decrement指令輕松實現一個堆棧,這樣就不會丟失.很高興為您編碼.(它還具有帶陷阱的虛擬內存,以及寄存器集和VM映射之間的硬件上下文切換).
雖然所有這些聽起來都需要復雜的邏輯來解碼,但事實并非如此.我們設法用~~ 120個所謂的"中等規模"芯片(每個芯片4個門,多路復用器,4位加法器片等)實現這臺機器.這些天我希望你能夠在一個FPGA中實現整個過程.
術語混淆,我的壞.GOTO和GOSUB不是一回事,我要在黑板上寫幾百遍. (3認同)
@Psvedman:在硬件復雜性的完整另一端,可變長度指令集可以提供高代碼密度,同時仍然允許大量的操作碼和大量的立即數."轉義序列"操作碼充當下一個操作碼的修飾符.無論如何,并不是說你想要實現這樣的東西,而是[Agner Fog最近的博客文章提出了高性能計算的指令集.](http://www.agner.org/optimize/blog/read. php?i = 421#470)有一些沒有設定的想法.他試圖保留一些x86的好處,同時放棄壞處. (2認同)
總結
以上是生活随笔為你收集整理的跳转指令微型计算机,哪种类型的汇编程序跳转指令最有用?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 百度地图怎么ar导航(登录百度帐号)
- 下一篇: 解释人生苦短及时行乐的意思(这两句话的出