91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

Cortex A9架構(gòu)下為何使用結(jié)構(gòu)體效率會更高一些

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

掃碼添加小助手

加入工程師交流群

作為過來人,我發(fā)現(xiàn)很多程序猿新手,在編寫代碼的時候,特別喜歡定義很多獨立的全局變量,而不是把這些變量封裝到一個結(jié)構(gòu)體中,主要原因是圖方便,但是要知道,這其實是一個不好的習慣,而且會降低整體代碼的性能。

另一方面,最近有幸與大神「公眾號:裸機思維」的傻孩子交流的時候,他聊到:“其實Cortex在架構(gòu)層面就是更偏好面向?qū)ο蟮模呐履阒皇鞘褂昧私Y(jié)構(gòu)體),其表現(xiàn)形式就是:「Cortex所有的尋址模式都是間接尋址」——換句話說「一定依賴一個寄存器作為基地址」。

舉例來說,同樣是訪問外設(shè)寄存器,過去在8位和16位機時代,人們喜歡給每一個寄存器都單獨綁定地址——當作全局變量來訪問,而現(xiàn)在Cortex在架構(gòu)上更鼓勵底層驅(qū)動以寄存器頁(也就是結(jié)構(gòu)體)為單位來定義寄存器,這也就是說,同一個外設(shè)的寄存器是借助擁有同一個基地址的結(jié)構(gòu)體來訪問的?!?/p>

以Cortex A9架構(gòu)為前提,下面一口君詳細給你解釋為什么使用結(jié)構(gòu)體效率會更高一些。

一、全局變量代碼反匯編

1. 源文件

「gcd.s」

text
.global _start
_start:
ldr sp,=0x70000000 get stack top pointer
b main

「main.c」


* main.c

* Created on: 2020-12-12
* Author: pengdan

int xx=0;
int yy=0;
int zz=0;
int main(void)

xx=0x11;
yy=0x22;
zz=0x33;
while(1);
return 0;

「map.lds」

OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
OUTPUT_FORMAT("elf32-arm", "elf32-arm", "elf32-arm")
OUTPUT_ARCH(arm)
ENTRY(_start)
SECTIONS

. = 0x40008000;
. = ALIGN(4);
.text :

gcd.o(.text)
*(.text)

. = ALIGN(4);
.rodata :
{ *(.rodata) }
. = ALIGN(4);
.data :
{ *(.data) }
. = ALIGN(4);
.bss :
{ *(.bss) }

「Makefile」

TARGET=gcd
TARGETC=main
all:
arm-none-linux-gnueabi-gcc -O1 -g -c -o $(TARGETC).o $(TARGETC).c
arm-none-linux-gnueabi-gcc -O1 -g -c -o $(TARGET).o $(TARGET).s
arm-none-linux-gnueabi-gcc -O1 -g -S -o $(TARGETC).s $(TARGETC).c
arm-none-linux-gnueabi-ld $(TARGETC).o $(TARGET).o -Tmap.lds -o $(TARGET).elf
arm-none-linux-gnueabi-objcopy -O binary -S $(TARGET).elf $(TARGET).bin
arm-none-linux-gnueabi-objdump -D $(TARGET).elf > $(TARGET).dis
clean:
rm -rf *.o *.elf *.dis *.bin

【交叉編譯工具,自行搜索安裝】

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

    關(guān)注

    0

    文章

    396

    瀏覽量

    22507
  • Cortex
    +關(guān)注

    關(guān)注

    2

    文章

    220

    瀏覽量

    48902
  • ARM架構(gòu)
    +關(guān)注

    關(guān)注

    15

    文章

    185

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    鴻蒙智能上/下、升級流程介紹

    執(zhí)行上操作,并且已經(jīng)審核通過的智能,才能被其他用戶搜索并使用。 升級審核未通過的智能,線上依舊保留上次通過審核的智能版本提供給其他
    發(fā)表于 02-10 10:38

    Cortex-M0 處理器介紹

    功耗的32位處理器。 Cortex-M0是Cortex-M家族中的M0系列。最大特點是低功耗的設(shè)計。Cortex-M0為32位、3級流水線RISC處理器,其核心仍為馮.諾依曼結(jié)構(gòu),是指
    發(fā)表于 01-16 08:04

    C語言中一些令人震驚的結(jié)構(gòu)介紹

    C語言同意一些令人震驚的結(jié)構(gòu),下面的結(jié)構(gòu)是合法的嗎,如果是它做些什么? int a = 5, b = 7, c; c = a+++b;
    發(fā)表于 12-23 08:15

    為什么不建議用匿名結(jié)構(gòu)

    說起匿名結(jié)構(gòu),想必大家第感覺就是看著好高大上的名字,但實際上也就那樣。 typedef struct { union { struct { uint8_t bit_0:1
    發(fā)表于 12-04 07:39

    C語言結(jié)構(gòu)使用

    有時候需要將不同類型的數(shù)據(jù)組合為個整體,以便于引用。例如,名學生有學號、姓名、性別、年齡等屬性,如果針對每個屬性都單獨定義個變量,那么當有多名學生時變量就難以分清。結(jié)構(gòu)
    發(fā)表于 11-12 08:30

    基于蜂鳥E203架構(gòu)的指令集K擴展

    蜂鳥E203是款基于RISC-V架構(gòu)的微處理器,其指令集包含RV32I的基本指令集,RV32M的乘法擴展指令集,以及一些常用的定點指令和控制指令。如果需要擴展其指令集,可以考慮使用RISC-V的可
    發(fā)表于 10-21 09:38

    迅為Hi3403V610開發(fā)板海思Cortex-A55架構(gòu)核心板卡

    迅為電子重磅推出基于海思Hi3403處理器的高性能核心板,采用先進的四核Cortex-A55架構(gòu),主頻高達1.4GHz,以強勁算力、超凡能效比與卓越的圖像處理能力,為千行百業(yè)的智能化升級注入核心動力。無論是智能視覺、工業(yè)互聯(lián),還是AIoT邊緣計算,它都能輕松駕馭,助您暢快
    的頭像 發(fā)表于 09-30 14:18 ?761次閱讀
    迅為Hi3403V610開發(fā)板海思<b class='flag-5'>Cortex-A</b>55<b class='flag-5'>架構(gòu)</b>核心板卡

    線上研討 | @9/23 Tinyswitch5不Tiny,擁有更高效、更高瓦更精簡的變頻反馳式架構(gòu)

    9月23日,大聯(lián)大詮鼎集團攜手PI將做客大大通直播間帶來“Tinyswitch5不Tiny,擁有更高效、更高瓦、更精簡的變頻反馳式架構(gòu)”主題研討
    的頭像 發(fā)表于 09-18 08:18 ?335次閱讀
    線上研討<b class='flag-5'>會</b> | @<b class='flag-5'>9</b>/23 Tinyswitch5不Tiny,擁有<b class='flag-5'>更高</b>效、<b class='flag-5'>更高</b>瓦更精簡的變頻反馳式<b class='flag-5'>架構(gòu)</b>

    瑞芯微RK3562一體機產(chǎn)品概述

    在工業(yè)控制、邊緣計算和智能顯示等場景中,設(shè)備需同時滿足高算力、低延遲、長續(xù)航三大核心需求。然而,性能與功耗往往是對矛盾:追求極致性能可能導致發(fā)熱量激增、續(xù)航縮短;過度壓低功耗又可能犧牲計算效率。瑞芯微RK3562
    的頭像 發(fā)表于 09-04 14:46 ?1848次閱讀
    瑞芯微RK3562<b class='flag-5'>一體</b>機產(chǎn)品概述

    迅為iTOP-3588S開發(fā)板核心板引腳240PIN全部引出8GB內(nèi)存32GBEMMC存儲

    性能強 iTOP-3588S開發(fā)板采用瑞芯微RK3588S處理器,是全新代AloT高端應用芯片,搭載八核64位CPU,四核Cortex-A76和四核Cortex-A55架構(gòu)主頻高達2
    發(fā)表于 06-23 11:19

    瑞迅科技RK3568主板賦能健康檢測一體機創(chuàng)新應用

    硬件平臺,RK3568主板的創(chuàng)新應用正在重新定義健康服務的效率與體驗。 、RK3568主板:健康檢測一體機的“智慧心臟” 瑞迅科技自主研發(fā)的RK3568主板,搭載四核ARM Cortex-A
    的頭像 發(fā)表于 05-22 15:45 ?861次閱讀
    瑞迅科技RK3568主板賦能健康檢測<b class='flag-5'>一體</b>機創(chuàng)新應用

    iTOP-3588S開發(fā)板四核心架構(gòu)GPU內(nèi)置GPU可以完全兼容0penGLES1.1、2.0和3.2。

    性能強 iTOP-3588S開發(fā)板采用瑞芯微RK3588S處理器,是全新代AloT高端應用芯片,搭載八核64位CPU,四核Cortex-A76和四核Cortex-A55架構(gòu)主頻高達2
    發(fā)表于 05-15 10:36

    《FDTD Solutions仿真全面教程:超構(gòu)表面與光束操控的前沿探索》

    FDTD仿真實例及論文復現(xiàn) Q 實例內(nèi)容: ()設(shè)置Pancharatnam–Berry型超構(gòu)表面結(jié)構(gòu),單元旋向及位置 (二)傳輸型超構(gòu)表面單元的
    發(fā)表于 04-22 11:59

    迅為iTOP-RK3588S開發(fā)板/核心板瑞芯微RK3588S處理器6TOPS算力內(nèi)置NPU

    性能強 iTOP-3588S開發(fā)板采用瑞芯微RK3588S處理器,是全新代AloT高端應用芯片,搭載八核64位CPU,四核Cortex-A76和四核Cortex-A55架構(gòu)主頻高達2
    發(fā)表于 04-10 11:13

    iTOP-3588開發(fā)板采用瑞芯微RK3588處理器四核心架構(gòu)GPU內(nèi)置獨立NPU強大的視頻編解碼

    55架構(gòu),主頻高達2.4GHz。 四核心架構(gòu)GPU 集成Mali G610 MP4四核GPU、支持OpenGLES 1.1.2.0、 3.2, OpenCL 2.2和Vulkan1.2。帶有MMU的特殊2D
    發(fā)表于 04-09 16:09