簡易電腦的搭建

来源: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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...