精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

Linux中的32位與64位

Linux愛好者 ? 來源:Linux愛好者 ? 作者:Linux愛好者 ? 2020-12-11 16:00 ? 次閱讀

在通用PC領域,不論是windows還是linux界,我們都會經常聽到"32位"與"64位"的說法,類似的還有"x86"與"x86_64","i386"與"amd64",這兩組概念之間有著怎樣的聯系和區別呢?

實際上這兩組概念涉及了三個層次:硬件,系統和軟件。

1、硬件

早期的intel處理器,如i386,486,586,奔騰系列的CPU架構,都是32位的(32位的寄存器,32位的虛擬地址空間),統稱為x86架構。

隨著技術的發展,32位CPU已經無法滿足需求,intel與AMD采用不同的方法開發64位架構的CPU,intel使用與x86完全不同的IA64架構,由于與原來的X86完全不兼容,因此在PC領域沒有得到應用,只在服務器領域有一些使用。

而AMD開發的架構稱為amd64(將寄存器擴充為64位,支持64位虛擬地址),能夠完全兼容x86指令集,不用任何修改就能運行老的操作系統和應用軟件,在PC界得到廣泛的應用,現在市場上幾乎所有的PC用途的CPU都是支持amd64指令集的了。

當然intel也很快開發出支持該指令集的CPU,不過intel將其稱為x64架構,而不是用amd64這個名字。而在linux中則稱為x86_64,即x86架構的64位擴展。

有關x86_64的詳細描述可翻閱《深入理解計算機系統》一書。

在linux中查看CPU是否64位的方法:如果/proc/cpuinfo內的flags字段中含有"lm",則表示使用的是64位CPU(運行“grep 'lm' /proc/cpuinfo”命令,輸出不為空)。

2、系統

系統同樣可分為32位與64位。在x86_64架構的CPU出現之前,PC的操作系統都是用32位,例如windows 2000,xp,當時的unix,linux等。

在x86_64架構出現后,系統也就有了兩個版本:32位和64位,兩者的主要區別在于與硬件體系結構相關的操作中。

由于x86_64架構完全兼容x86架構,因此,32位的系統完全可以在x86_64位上運行,只不過它只使用了x86部分,沒有完全發揮硬件的功能而已。

而64位系統專門針對64位的擴展功能而開發的,就是為了最大限度地發揮硬件的能力,它無法在x86架構的cpu上運行。

另外,不論是windows還是linux,驅動程序都需要加載到內核空間中,因此它的類型(32位或64位)需要跟系統完全相同。

系統與CPU的關系如下圖所示:

68279c0a-348a-11eb-a64d-12bb97331649.jpg

查看linux系統是32位還是64位的方法:執行shell命令“arch”,顯示為x86_64表示當前系統為64位,顯示為i386,i486等表示系統是32位的。

3、軟件

在系統上運行的應用軟件同樣有32位和64位之分,老的應用軟件運行在32位CPU及32位系統中,屬于32位軟件。

出現了64位系統之后,也出現了專門運行在64位系統,能夠最大限度使用64位系統的擴展功能的原生64位程序。

對于C程序來說,64位程序相比32位程序最大的區別就是int,long以及指針數據類型的長度都是64位的,可以使用64位的虛擬地址空間。

實際遠不止這些,編繹器在將64位C程序翻譯成匯編語言或者機器語言時,會盡量使用64位處理器的寄存器,盡量避免訪問內存,例如把函數的參數,及局部變量優先放在寄存器,而不是在用戶棧中。

另外在64位系統中,為了兼容數量眾多的老的應用程序,系統都會增加一個虛擬層,用來翻譯x86指令,這樣32位程序也可以在64位系統中運行(windows和linux都支持)。

同樣在64位系統中,使用64位編繹器一般也可以選擇編譯成32位程序(gcc使用-m32編譯成32位可執行文件)。

另外在PC上,軟件能否運行,只需看系統是否支持即可,可以不用理會CPU的架構。軟件與系統的關系如下圖所示:

68490b10-348a-11eb-a64d-12bb97331649.jpg

linux中查看可執行文件是32位還是64位的方法:執行shell命令“file /usr/bin/xxx", 如果是32位程序,顯示為"ELF 32-bit ...";如果是64位,則顯示為:"ELF 64-bit..."。

4、linux發行版與內核

在linux發行版中,一般會針對不同的架構發布不同的安裝光盤,以debian為例,可用于PC的就有i386和amd64這兩個版本。

根據上面的描述,這兩個版本的系統都可以安裝在使用64位的CPU的機器上,而使用32位CPU的機器上則只能安裝i386版本的系統。

在debian amd64光盤中帶的內核及軟件包全都是64位版本的,而debian i386光盤中則有32位和64位的內核,以及32位的軟件,可能是考慮到有些用戶想用64位內核來運行32位程序吧。

內核源代碼是沒有32位,64位之分的,在編譯內核時可以用ARCH參數手工指定編譯成哪一個架構。例如:"make ARCH=i386 menuconfig","make ARCH=i386"用于配置,編譯32位內核;

而"make ARCH=x86_64 menuconfig","make ARCH=x86_64"則用于配置,編譯64位內核。

但是,在debian amd64光盤安裝的系統里編譯的32位內核是無法引導的,因為系統安裝的所有軟件包都是原生64位程序,無法在32位內核上運行,典型的錯誤是提示引導時找不到能運行的init程序;

而使用debian i386光盤安裝的系統中編譯的64位內核卻可以使用,只是需要在配置內核時加上IA32 Emulation支持(menuconfig的:"Executable file formats/Emulations"-->"IA32 Emulation")。

基于這樣的原因,我原來用搭建的debian amd64光盤安裝的系統(http://www.cnblogs.com/xiongyuanxiong/p/3523306.html),現在也改成用debian i386光盤來安裝了,這樣就能同時編譯新的32位和64位官方內核進行對比測試。

責任編輯:lq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19165

    瀏覽量

    229130
  • 寄存器
    +關注

    關注

    31

    文章

    5317

    瀏覽量

    120008
  • Linux
    +關注

    關注

    87

    文章

    11229

    瀏覽量

    208927

原文標題:Linux 中的32位與64位

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    gd32vf103 timer內部計數器是自增的,64,溢出后是從0開始嗎?

    timer內部計數器是自增的,64,溢出后是從0開始嗎?有知道的小伙伴嗎?官方參考手冊也沒有說明。
    發表于 09-27 07:09

    gd32vf103 timer內部計數器是自增的,64,溢出后是從0開始嗎?

    timer內部計數器是自增的,64,溢出后是從0開始嗎?有知道的小伙伴嗎?官方參考手冊也沒有說明。
    發表于 09-27 06:28

    RV6464地址指令

    (word),雙字(doubleword)和長整數(long)版本的指令,并將所有寄存器(包括 PC)擴展為 64 。因此,RV64I 的 sub 操作的是兩個
    發表于 09-04 15:15

    變送器如何調節液參數

    變送器是一種用于測量和監控液體或氣體在容器的液高度的儀器。它廣泛應用于石油、化工、水處理、食品飲料等行業。液變送器的調節液參數對
    的頭像 發表于 07-31 09:43 ?1467次閱讀

    MPU進入64時代,Microchip推出PIC64系列產品

    ,MCU和MPU之間的界限也越來越小,以適應更多新的應用。Microchip作為嵌入式解決方案的領導者,近日推出了全新的PIC64GX MPU,這也是Microchip推出的首款64MPU產品
    的頭像 發表于 07-24 00:12 ?3520次閱讀

    Traveo T2G SRAM不是32的嗎?如何得到一個64的?

    ]ECC_P7_SW) 奇偶校驗[6:0]為 32 比特 ACTUALWORD[127:0] 提供 7 比特奇偶校驗。 請問,SRAM不是32的嗎?如何得到一個64的ACTUALWORD[63:0]?比如
    發表于 06-03 08:49

    請問STM8能處理64的數據嗎?

    IAR for stm8 64數據變量賦值時出現integer constant is too large的錯誤。 問下STM8能處理64
    發表于 05-14 08:13

    ICMAN多點液檢測

    檢測
    ICman
    發布于 :2024年04月02日 09:31:20

    stm32F4 64變量操作異常怎么解決?

    stm32F4 64變量使用報錯解決
    發表于 04-02 07:16

    CodeWeavers發布CrossOver 24版,初試32應用運行功能

    由于蘋果已在macOS Catalina系統刪除了對32軟件的支持,因此在未來的操作系統版本,舊版軟件可能將不再能夠運行。但借助Wine 9.0帶來的超過7000項改進,CrossOver可以實現在
    的頭像 發表于 02-23 11:18 ?985次閱讀

    入門級64ARM?CORTEX?-A55 MPU數據手冊

    電子發燒友網站提供《入門級64ARM?CORTEX?-A55 MPU數據手冊.pdf》資料免費下載
    發表于 02-19 10:59 ?1次下載
    入門級<b class='flag-5'>64</b><b class='flag-5'>位</b>ARM?CORTEX?-A55 MPU數據手冊

    STM32開發運算以及帶操作

    STM32開發運算以及帶操作? 運算是計算機中常用的一種操作方式,特別適用于對數據的單個或多個位進行操作。在STM32開發
    的頭像 發表于 02-02 14:38 ?1498次閱讀

    關于32/64Altium Designer與Access數據庫兼容的問題

    Database Libraries(Dblib)是一個功能強大的元器件管理方案,但對于3264版本的Altium Designer在使用Microsoft Access作為后端數據庫時是有區別的。
    的頭像 發表于 01-24 14:40 ?1943次閱讀

    玄鐵的rv64ilp32之路 - 32Linux的未來

    計算機科學巨擘、圖靈獎得主唐納德在2008年的博客中曾發表過一段著名的言論,他抱怨道:在編譯內存需求不足4GB的程序時,使用64指針是非常不明智的。因為當這些指針值出現在結構體
    的頭像 發表于 01-23 16:25 ?1996次閱讀
    玄鐵的rv<b class='flag-5'>64</b>ilp32之路 - 32<b class='flag-5'>位</b><b class='flag-5'>Linux</b>的未來

    IGBT驅動電路的鉗電路

    IGBT驅動電路的鉗電路
    的頭像 發表于 11-30 18:05 ?2500次閱讀
    IGBT驅動電路<b class='flag-5'>中</b>的鉗<b class='flag-5'>位</b>電路