簡易電腦的搭建

来源:https://www.cnblogs.com/wangsiyaoa/archive/2023/12/07/17881205.html
-Advertisement-
Play Games

版本 Linux 6.5 背景 在學習cgroupv2的時候,想給子cgroup開啟cpu控制器結果失敗了: # 查看可以開啟哪些控制器 root@ubuntu-vm:/sys/fs/cgroup# cat cgroup.controllers cpuset cpu io memory hugetl ...


簡易電腦的搭建

1、一些無關緊要的前置知識

​ 現代電腦類設備的主流架構一般有兩種:一為馮諾依曼體系架構;一為哈弗架構。

​ 主流電腦採用的架構一般為馮諾依曼體系,是將程式和數據放在一起存儲的架構;

​ 單片機設備一般採用哈弗架構,是將程式與數據分開存儲的一種架構。

以下基本都是有關馮諾依曼架構的知識

​ 馮諾依曼架構提出電腦由四個子系統構成:存儲器(寄存器、記憶體、硬碟)、計算單元(ALU)、控制單元(進行協調各個單元)、輸入輸出單元(外設)。

​ CPU(中央處理器)是由寄存器計算單元控制單元組成。

​ 一般64位機的系統為64bit.

​ CPU和記憶體、硬碟、外設等非CPU內部組件連接的中介為匯流排。匯流排分為 數據匯流排(兩端組件可雙向通信)、地址匯流排(單向)、控制匯流排(單向,用於傳送指令)。

​ 一個機器周期:取指令 ----> 解碼 ----> 執行。有流水線時,可以相較來說同時進行,比如可在解碼時進行下一個周期的取指令。

​ CPU指令架構分為 CISC複雜指令集(一般 x86CPU 電腦)和 RISC精簡指令集(一般 ARM的CPU 手機、單片機)。

2、復用器(選擇器)

​ 復用器的作用是選擇使用哪一個組件輸入進來的數。

​ 最簡單的復用器是輸入兩個二進位位,輸出指定的一個。這個功能可以使用一個單刀雙擲的繼位器實現,控制繼位器的觸點選擇和繼位器的高低電平實現選擇輸出。

​ 多位的復用器可以使用幾個單個復用組成。一個復用器分高低電平,低走下一層第一個復用器,高走下一層第二個復用器,如此反覆可實現多位復用器。

​ 輸入n個二進位位和一個選擇數,選擇數可以是十進位,十進位0即走第零個,以此類推。也可以將十進位拆成二進位來選擇,拆成二進位時,把整個復用器看作好幾個組合成的,最高位走最後一個小的二選一復用器進行次層兩邊的選擇,依此類推。

n位復用器即2^n個輸入和一個位數選擇和一個輸出

3、簡易的計算單元(ALU)

​ 由加法器、減法器(實際電腦中沒使用,這裡直接用了)、與、或和兩個復用器及一些輸入輸出構成。輸入為兩個操作數、一個進位數、一個選擇數(選擇輸出哪個運算結果。截取一下這個選擇數的低一位,作為加法器和減法器的進位/借位選擇,不截取的話複位器要選擇位數多的,造成浪費。)。輸出為一個結果和一個進位/借位。

我們做的ALU會把所有運算都做一遍輸出選擇的運算,有沒有辦法讓它只作我們選擇的運算?

4、PC計數器

​ 一個加法器和一個寄存器和幾個輸入輸出組成。寄存器的輸出傳給加法器的一個操作數,同時寄存器的輸出作為計數器的結果,第一次寄存器的輸出為0,所以計數器從0開始計數;加法器的另一個操作數為1,進位器0;加法器的輸出有兩個,一個相加的結果,放進寄存器的輸入,進行下次加一,另一個輸出為進位,溢出後,相加結果變為零,進行第二輪的計數。寄存器有一個使能開關,和一個時鐘。一次時鐘周期進行一次加一計數。

5、實現一塊記憶體

​ 使用分線器和n個寄存器即可實現一個n位定址的存儲,具體細節略。

6、帶記憶體和寄存器的ALU

​ 只說下原理。可以對PC計數器操作實現從記憶體的不同地址讀出數據(可以通過輸入往記憶體中輸入數據),讀出數據後通過ALU與寄存器中的數相加(寄存器中初始為0),即第一次相加得到第一個數放到寄存器中,如此迴圈,可以實現從記憶體中不斷讀數並不斷相加。

todo

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 上一篇,我們實現了基於 DotNetty 的通信基礎模塊的搭建,本篇,主要實現待發佈 Web 項目的集成。 創建待發佈項目 為了測試, 我創建了一個基於 .NET 4.8 的 Web 項目 OpenDeploy.TestWebProject 我本機的代碼倉儲路徑是: D:\Projects\B ...
  • 1. 什麼是中間件 在ASP.NET Core中,中間件(Middleware)是一個可以處理HTTP請求或響應的軟體管道。 ASP.NET Core中給中間件組件的定位是具有非常特定的用途。例如,我們可能有需要一個中間件組件驗證用戶,另一個中間件來處理錯誤,另一個中間件來提供靜態文件,如JavaS ...
  • 一:背景 1. 講故事 前幾天有位朋友找到我,說他的程式會偶發性的報 存儲空間不足,無法處理此命令 的錯誤,讓我幫忙看下到底怎麼回事,哈哈,人家是有備而來,dump都準備好了,話不多說,直接分析開乾。 二:WinDbg 分析 1. 捕獲dump中的異常 一般來講別人說的只是一個參考,我們需要自己到d ...
  • 在前面的隨筆,我對我們開發的審批工作流做了不少的介紹,其中有包括WInform的、Vue+Element、Bootstrap Asp.net的,在各個框架上,我們都儘量爭取界面能夠一致化,以便客戶能夠在不同的前端上有相同的用戶體驗,並結合不同的前端特點,做了一些優化處理,本篇隨筆對WPF應用框架中工... ...
  • 1. C/S 與 B/S C/S結構系統是什麼 Client/Server結構(C/S結構)是大家熟知的客戶機和伺服器結構。它是軟體系統體繫結構,通過它可以充分利用兩端硬體環境的優勢,將任務合理分配到Client端和Server端來實現,降低了系統的通訊開銷 B/S結構系統是什麼 B/S結構(Bro ...
  • 在 .NET 開發中,Serilog 是一款廣受歡迎的日誌庫,它提供了強大的日誌記錄功能,具有豐富的特性和高度的可擴展性。Serilog 的優秀之處包括: 可擴展性: Serilog 可以輕鬆擴展以滿足不同的日誌記錄需求,例如日誌存儲、格式化和過濾。它支持各種插件和自定義擴展,讓你可以根據項目的具體 ...
  • tmux教程 功能 分屏。 允許斷開Terminal連接後,繼續運行進程。 結構 // 一個tmux可以包含多個session,一個session可以包含多個window,一個window可以包含多個pane。 tmux: session 0: window 0: pane 0 pane 1 pan ...
  • 近幾天發現MarkdownPad有一些小問題,打開時會彈出以下報錯信息,告訴你打開文件的許可權不夠 解決方法如下: 1、複製報錯信息中的文件路徑'C:\Users\Administrator\AppData \Roaming\wyUpdate AU\ApricitySoftware-MarkdownP ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...