亚洲精品久久久久久久久久久,亚洲国产精品一区二区制服,亚洲精品午夜精品,国产成人精品综合在线观看,最近2019中文字幕一页二页

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

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

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

哪幾種情況中必須使用內(nèi)聯(lián)匯編或嵌入型匯編

電子設(shè)計(jì) ? 來源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2020-12-24 12:55 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

ARM系列文章,請點(diǎn)擊以下匯總鏈接:

《從0學(xué)arm合集》

一、gcc 內(nèi)聯(lián)匯編

內(nèi)聯(lián)匯編即在C中直接使用匯編語句進(jìn)行編程,使程序可以在C程序中實(shí)現(xiàn)C語言不能完成的一些工作,例如,在下面幾種情況中必須使用內(nèi)聯(lián)匯編或嵌入型匯編。

程序中使用飽和算術(shù)運(yùn)算(Saturating Arithmetic)程序需要對協(xié)處理器進(jìn)行操作在C程序中完成對程序狀態(tài)寄存器的操作格式:__asm__ __volatile__("asm code"
:output
:input
:changed registers);

asm或__asm__開頭,小括號+分號,括號內(nèi)容寫匯編指令。指令+ 用雙引號引上。

參數(shù)

「asm code」主要填寫匯編代碼:


"mov r0, r0 "
"mov r1,r1 "
"mov r2,r2"

「output(asm->C)」用于定義輸出的參數(shù),通常只能是變量:

:"constraint" (variable)
"constraint"用于定義variable的存放位置:
r 表示使用任何可用的寄存器
m 表示使用變量的內(nèi)存地址
+ 可讀可寫
= 只寫
& 表示該輸出操作數(shù)不能使用輸入部分使用過的寄存器,只能用"+&"或"=&"的方式使用

「input(C->asm)」用于定義輸入的參數(shù),可以是變量也可以是立即數(shù):

:"constraint" (variable/immediate
"constraint"用于定義variable的存放位置:
r 表示使用任何可用的寄存器(立即數(shù)和變量都可以)
m 表示使用變量的內(nèi)存地址
i 表示使用立即數(shù)

Note:

使用__asm__和__volatile__表示編譯器將不檢查后面的內(nèi)容,而是直接交給匯編器。如果希望編譯器為你優(yōu)化,__volatile__可以不加沒有asm code也不能省略""沒有前面的和中間的部分,不可以相應(yīng)的省略:沒有changed 部分,必須相應(yīng)的省略:最后的;不能省略,對于C語言來說這是一條語句匯編代碼必須放在一個(gè)字符串內(nèi),且字符串中間不能直接按回車換行,可以寫成多個(gè)字符串,注意中間不能有任何符號,這樣就會將兩個(gè)字符串合并為一個(gè)指令之間必須要換行,還可以使用 使指令在匯編中保持整齊舉例

例1:無參數(shù),無返回值這種情況,output和input可以省略:

asm
( //匯編指令
"mrs r0,cpsr "
"bic r0,r0,#0x80 "
"msr cpsr,r0 "
);

例2:有參數(shù) ,有返回值讓內(nèi)聯(lián)匯編做加法運(yùn)算,求a+b,結(jié)果存在c中

int a =100, b =200, c =0;
asm

add %0,%1,%2 "
: "=r"(c)
: "r"(a),"r"(b)
: "memory"
);

%0 對應(yīng)變量c%1 對應(yīng)變量a%2 對應(yīng)變量b

例3:有參數(shù) 2 ,有返回值

讓內(nèi)聯(lián)匯編做加法運(yùn)算,求a+b,結(jié)果存在sum中,把a(bǔ)-b的存在d中

asm volatile

"add %[op1],%[op2],%[op3] "
sub %[op4],%[op2],%[op3] "
:[op1]"=r"(sum),[op4]"=r"(d)
:[op2]"r"(a),[op3]"r"(b)
:"memory"
);

%0 對應(yīng)變量c%1 對應(yīng)變量a%2 對應(yīng)變量b

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

    關(guān)注

    0

    文章

    393

    瀏覽量

    22323
  • C程序
    +關(guān)注

    關(guān)注

    4

    文章

    255

    瀏覽量

    37363
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    inline ASM(內(nèi)聯(lián)匯編)的細(xì)節(jié)分享

    內(nèi)聯(lián)匯編,否則,仍然是帶有C++表達(dá)式的內(nèi)聯(lián)江編,此時(shí)\"instructionlist\"的寄存器的寫法需要遵守相關(guān)的規(guī)定: 寄存器前必須
    發(fā)表于 10-31 09:11

    內(nèi)聯(lián)匯編的妙用

    一、問題描述 AES加密模式,有一種CTR模式,其流程如下圖: 加密時(shí),除了明文和密鑰外,還需要一個(gè)初始向量COUNTER1,將其加密的結(jié)果和明文異,即可得到密文;下一塊明文加密
    發(fā)表于 10-31 06:28

    簡單的內(nèi)聯(lián)匯編介紹

    前言1、在程序我們可以嵌入匯編直接對我們加入的硬件進(jìn)行相應(yīng)的操作 2、在RISC-V架構(gòu)定義的CSR寄存器需要使用特殊的 CSR 指令進(jìn)行訪問,如果在 C/C++程序
    發(fā)表于 10-30 08:04

    RISC-V的工具鏈GCC內(nèi)聯(lián)匯編

    具體實(shí)現(xiàn)方法和步驟 在RISC-V架構(gòu)定義的CSR寄存器需要使用特殊的CSR指令進(jìn)行訪問,如果C、C++程序需要訪問CSR寄存器,只能使用內(nèi)嵌匯編指令的方法。在C、C++程序
    發(fā)表于 10-30 06:59

    蜂鳥自定義指令軟件講解和內(nèi)聯(lián)匯編(一)

    內(nèi)聯(lián)匯編介紹 asm volatile(“.insn r 0x7b, 2, 1, x0, %1, x0” : “=r”(zero) : “r”(addr)); (1)GCC內(nèi)聯(lián)匯編
    發(fā)表于 10-24 10:51

    GCC內(nèi)聯(lián)匯編

    需要用到C/C++內(nèi)聯(lián)匯編語法asm volatile(“instructions”) 以在C代碼嵌入
    發(fā)表于 10-24 07:46

    通過內(nèi)聯(lián)匯編調(diào)用乘法指令mulh\\mulhsu\\mulhu

    mulh、mulhu與mulhsu指令,不能直接驗(yàn)證,需要其他方法。因此,我們想到了在C語言中嵌入內(nèi)聯(lián)匯編,分別生成三條指令的接口函數(shù),之后便只需在C語言中調(diào)用者三函數(shù)便可執(zhí)行mulh、mulhu
    發(fā)表于 10-24 06:52

    浮點(diǎn)運(yùn)算單元的實(shí)現(xiàn)——浮點(diǎn)指令內(nèi)聯(lián)匯編(一)

    代碼實(shí)現(xiàn) 在硬件實(shí)現(xiàn)FPU后,可通過內(nèi)聯(lián)匯編的方式,指定浮點(diǎn)指令對其進(jìn)行測試,以下羅列出相關(guān)測試代碼。 //fmadds_test __STATIC_FORCEINLINE float
    發(fā)表于 10-23 06:51

    gcc工具鏈無法匯編硬件浮點(diǎn)指令fsqrt問題

    需要在C代碼嵌入匯編,強(qiáng)制這里的開方操作使用fsqrt.s來執(zhí)行 asm(“fsqrt.s %0,%1”:”=f”(out):”f”(a));
    發(fā)表于 10-20 06:19

    匯編語言教學(xué)中文資料

    電子發(fā)燒友網(wǎng)站提供《匯編語言教學(xué)中文資料.rar》資料免費(fèi)下載
    發(fā)表于 06-30 15:15 ?7次下載

    Windows環(huán)境下32位匯編語言中文資料

    電子發(fā)燒友網(wǎng)站提供《Windows環(huán)境下32位匯編語言中文資料.rar》資料免費(fèi)下載
    發(fā)表于 06-30 15:14 ?0次下載

    分布式存儲有哪幾種類型?

    分布式存儲有哪幾種類型?分布式存儲系統(tǒng)是一種將數(shù)據(jù)分散存儲在多臺獨(dú)立節(jié)點(diǎn)上的技術(shù),根據(jù)數(shù)據(jù)模型可分為鍵值存儲、列式存儲、文檔存儲和圖形存儲等類型;按數(shù)據(jù)存儲單位可分為基于文件、塊和對象的存儲;按
    的頭像 發(fā)表于 02-20 11:00 ?1025次閱讀

    常見的有源變壓器有哪幾種?

    麻煩問一下大家,我們常見的有源變壓器有哪幾種?最關(guān)鍵的問題是,有源變壓器和無源變壓器建模方法相同嗎?有源變壓器如何進(jìn)行建模?真心求教,在線等,謝謝了。
    發(fā)表于 01-22 07:47

    輸入電壓達(dá)到正負(fù)5v、精度比較高最好是12bit以上的,六通道的ADC芯片一般選哪幾種?

    輸入電壓達(dá)到正負(fù)5v、精度比較高最好是12bit以上的,六通道的ADC芯片一般選哪幾種,因?yàn)锳DC之后是直接接FPGA處理的、最好是那種ADC芯片好呢、性能越好越好、
    發(fā)表于 01-22 06:47

    n母接頭的安裝方式有哪幾種

    等多個(gè)領(lǐng)域得到了廣泛應(yīng)用。關(guān)于N母接頭的安裝方式,雖然具體的安裝步驟可能因產(chǎn)品型號和制造商的不同而有所差異,但通??梢詺w納為以下幾種主要方式:  這是N母接
    的頭像 發(fā)表于 11-13 09:23 ?2399次閱讀
    n母接頭的安裝方式有<b class='flag-5'>哪幾種</b>