在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

手把手教你分析Linux內核

Q4MP_gh_c472c21 ? 來源:嵌入式ARM ? 2019-12-03 15:55 ? 次閱讀

Linux的最大的好處之一就是它的源碼公開。同時,公開的核心源碼也吸引著無數的電腦愛好者和程序員;他們把解讀和分析Linux的核心源碼作為自己的最大興趣,把修改Linux源碼和改造Linux系統作為自己對計算機技術追求的最大目標。

Linux內核源碼是很具吸引力的,特別是當你弄懂了一個分析了好久都沒搞懂的問題;或者是被你修改過了的內核,順利通過編譯,一切運行正常的時候。那種成就感真是油然而生!而且,對內核的分析,除了出自對技術的狂熱追求之外,這種令人生畏的勞動所帶來的回報也是非常令人著迷的,這也正是它擁有眾多追隨者的主要原因:

首先,你可以從中學到很多的計算機的底層知識,如后面將講到的系統的引導和硬件提供的中斷機制等;其它,象虛擬存儲的實現機制,多任務機制,系統保護機制等等,這些都是非都源碼不能體會的。

同時,你還將從操作系統的整體結構中,體會整體設計在軟件設計中的份量和作用,以及一些宏觀設計的方法和技巧:Linux的內核為上層應用提供一個與具體硬 件不相關的平臺;同時在內核內部,它又把代碼分為與體系結構和硬件相關的部分,和可移植的部分;再例如,Linux雖然不是微內核的,但他把大部分的設備 驅動處理成相對獨立的內核模塊,這樣減小了內核運行的開銷,增強了內核代碼的模塊獨立性。

而且你還能從對內核源碼的分析中,體會到它在解決某個具體細節問題時,方法的巧妙:如后面將分析到了的Linux通過Botoom_half機制來加快系統對中斷的處理。

最重要的是:在源碼的分析過程中,你將會被一點一點地、潛移默化地專業化。一個專業的程序員,總是把代碼的清晰性,兼容性,可移植性放在很重要的位置。他們總是通過定義大量的宏,來增強代碼的清晰度和可讀性,而又不增加編譯后的代碼長度和代碼的運行效率;他們總是在編碼的同時,就考慮到了以后的代碼維護和升 級。 甚至,只要分析百分之一的代碼后,你就會深刻地體會到,什么樣的代碼才是一個專業的程序員寫的,什么樣的代碼是一個業余愛好者寫的。而這一點是任何沒有真 正分析過標準代碼的人都無法體會到的。

然而,由于內核代碼的冗長,和內核體系結構的龐雜,所以分析內核也是一個很艱難,很需要毅力的事;在缺乏指導和交流的情況下,尤其如此。只有方法正確,才能事半功倍。正是基于這種考慮,作者希望通過此文能給大家一些借鑒和啟迪。

由于本人所進行的分析都是基于2.2.5版本的內核;所以,如果沒有特別說明,以下分析都是基于i386單處理器的2.2.5版本的Linux內核。所有源文件均是相對于目錄/usr/src/linux的。

1入手方法

01方法一

要分析Linux內核源碼,首先必須找到各個模塊的位置,也即要弄懂源碼的文件組織形式。雖然對于有經驗的高手而言,這個不是很難;但對于很多初級的Linux愛好者,和那些對源碼分析很有興趣但接觸不多的人來說,這還是很有必要的。

1.Linux核心源程序通常都安裝在/usr/src/linux下,而且它有一個非常簡單的編號約定:任何偶數的核心(的二個數為偶數,例如2.0.30)都是一個穩定地發行的核心,而任何奇數的核心(例如2.1.42)都是一個開發中的核心。

2.核心源程序的文件按樹形結構進行組織,在源程序樹的最上層,即目錄/usr/src/linux下有這樣一些目錄和文件:

◆ COPYING:GPL版權申明。對具有GPL版權的源代碼改動而形成的程序,或使用GPL工具產生的程序,具有使用GPL發表的義務,如公開源代碼;

◆ CREDITS:光榮榜。對Linux做出過很大貢獻的一些人的信息;

◆ MAINTAINERS:維護人員列表,對當前版本的內核各部分都有誰負責;

◆ Makefile:第一個Makefile文件。用來組織內核的各模塊,記錄了個模塊間的相互這間的聯系和依托關系,編譯時使用;仔細閱讀各子目錄下的Makefile文件對弄清各個文件這間的聯系和依托關系很有幫助;

◆ ReadMe:核心及其編譯配置方法簡單介紹;

◆ Rules.make:各種Makefilemake所使用的一些共同規則;

◆REPORTING-BUGS:有關報告Bug 的一些內容;

● Arch/:arch子目錄包括了所有和體系結構相關的核心代碼。它的每一個子目錄都代表一種支持的體系結構,例如i386就是關于intel cpu及與之相兼容體系結構的子目錄。PC機一般都基于此目錄;

● Include/:include子目錄包括編譯核心所需要的大部分頭文件。與平臺無關的頭文件在 include/linux子目錄下,與 intel cpu相關的頭文件在include/asm-i386子目錄下,而include/scsi目錄則是有關scsi設備的頭文件目錄;

● Init/:這個目錄包含核心的初始化代碼(注:不是系統的引導代碼),包含兩個文件main.c和Version.c,這是研究核心如何工作的好的起點之一。

● Mm/:這個目錄包括所有獨立于 cpu 體系結構的內存管理代碼,如頁式存儲管理內存的分配和釋放等;而和體系結構相關的內存管理代碼則位于arch/*/mm/,例如arch/i386/mm/Fault.c;

● Kernel/:主要的核心代碼,此目錄下的文件實現了大多數linux系統的內核函數,其中最重要的文件當屬sched.c;同樣,和體系結構相關的代碼在arch/*/kernel中;

● Drivers/:放置系統所有的設備驅動程序;每種驅動程序又各占用一個子目錄:如,/block 下為塊設備驅動程序,比如ide(ide.c)。如果你希望查看所有可能包含文件系統的設備是如何初始化的,你可以看 drivers/block/genhd.c中的device_setup()。它不僅初始化硬盤,也初始化網絡,因為安裝nfs文件系統的時候需要網 絡;

● Documentation/:文檔目錄,沒有內核代碼,只是一套有用的文檔,可惜都是English的,看看應該有用的哦;

● Fs/:所有的文件系統代碼和各種類型的文件操作代碼,它的每一個子目錄支持一個文件系統, 例如fat和ext2;

● Ipc/:這個目錄包含核心的進程間通訊的代碼;

● Lib/:放置核心的庫代碼;

● Net/:核心與網絡相關的代碼;

● Modules/:模塊文件目錄,是個空目錄,用于存放編譯時產生的模塊目標文件;

● Scripts/:描述文件,腳本,用于對核心的配置;

一般,在每個子目錄下,都有一個 Makefile 和一個Readme 文件,仔細閱讀這兩個文件,對內核源碼的理解很有用。

對Linux內核源碼的分析,有幾個很好的入口點:一個就是系統的引導和初始化,即從機器加電到系統核心的運行;另外一個就是系統調用,系統調用是用戶 程序或操作調用核心所提供的功能的接口。對于那些對硬件比較熟悉的愛好者,從系統的引導入手進行分析,可能來的容易一些;而從系統調用下口,則可能更合適 于那些在dos或Uinx、Linux下有過C編程經驗的高手。這兩點,在后面還將介紹到。
02方法二

從表面上看,Linux的源碼就象一團扎亂無章的亂麻,其實它是一個組織得有條有理的蛛網。要把整個結構分析清楚,除了找出線頭,還得理順各個部分之間的關系,有條不紊的一點一點的分析。

所謂以程序流程為線索、一線串珠,就是指根據程序的執行流程,把程序執行過程所涉及到的代碼分析清楚。這種方法最典型的應用有兩個:一是系統的初始化過程;二是應用程序的執行流程:從程序的裝載,到運行,一直到程序的退出。

為了簡便起見,遵從循序漸進的原理,現就系統的初始化過程來具體的介紹這種方法。系統的初始化流程包括:系統引導,實模式下的初始化,保護模式下的初始化共三個部分。下面將一一介紹。

linux系統的常見引導方式有兩種:Lilo引導和Loadin引導;同時linux內核也自帶了一個bootsect-loader。由于它只能實現 linux的引導,不像前兩個那樣具有很大的靈活性(lilo可實現多重引導、loadin可在dos下引導linux),所以在普通應用場合實際上很少 使用bootsect-loader。當然,bootsect-loader也具有它自己的優點:短小沒有多余的代碼、附帶在內核源碼中、是內核源碼的有 機組成部分,等等。

bootsect-loader在內和源碼中對應的程序是/Arch/i386/boot/bootsect.S。下面將主要是針對此文件進行的分析。

1.幾個相關文件:

<1> /Arch/i386/boot/bootsect.S

<2> /include/linux/config.h

<3> /include/asm/boot.h

<4> /include/linux/autoconf.h

2.引導過程分析:

對于Intel x86 PC , 開啟電源后, 機器就會開始執行ROM BIOS的一系列系統測試動作,包括檢查RAM,keyboard,顯示器,軟硬磁盤等等。執行完bios的系統測試之后,緊接著控制權會轉移給ROM中 的啟動程序(ROM bootstrap routine);這個程序會將磁盤上的第0軌第0扇區(叫boot sector或MBR , 系統的引導程序就放在此處)讀入內存中,并放到自0x07C0:0x0000開始的512個字節處;然后處理機將跳到此處開始執行這一引導程序;也即裝入 MBR中的引導程序后,CS:IP = 0x07C0:0x0000 。加電后處理機運行在與8086相兼容的實模式下。

如果要用 bootsect-loader進行系統引導,則必須把bootsect.S編譯連接后對應的二進制代碼置于MBR; 當ROM BIOS 把bootsect.S編譯連接后對應的二進制代碼裝入內存后,機器的控制權就完全轉交給bootsect; 也就是說,bootsect將是第一個被讀入內存中并執行的程序。

Bootsect接管機器控制權后,將依次進行以下一些動作:

2.1 首先,bootsect將它"自己"(自位置0x07C0:0x0000開始的512個字節)從被ROM BIOS載入的地址0x07C0:0x0000處搬到0x9000:0000處; 這一任務由bootsect.S的 前十條指令完成;第十一條指令“jmpi go,INITSEG”則把機器跳轉到“新”的bootsect的“jmpi go,INITSEG”后的那條指令“go: mov di,#0x4000-12”;之后,繼續執行bootsect的剩下的代碼;在bootsect.S中定義了幾個常量:

BOOTSEG = 0x07C0 bios 載入 MBR的約定位置的段址;

INITSEG = 0x9000 bootsect.S的前十條指令將自己搬到此處(段址)

SETUPSEG =0x9020 裝入Setup.S的段址

SYSSEG =0x1000 系統區段址

對于這些常量可參見/include/asm/boot.h中的定義;這些常量在下面的分析中將會經常用到;

2.2 以0x9000:0x4000-12為棧底,建立自己的棧區;其中0x9000:0x4000-12到0x9000:0x4000的一十二個字節預留作磁盤參數表區;

2.3 在0x9000:0x4000-12到0x9000:0x4000的一十二個預留字節中建立新的磁盤參數表,之所以叫“新”的磁盤參數表,是相對于 bios建立的磁盤參數表而言的。由于設計者考慮到有些老的bios不能準確地識別磁盤“每個磁道的扇區數”,從而導致 bios建立的磁盤參數表妨礙磁盤 的最高性能發揮,所以,設計者就在bios建立的磁盤參數表的基礎上通過枚舉法測試,試圖建立準確的“新”的磁盤參數表(這是在后繼步驟中完成的);并把 參數表的位置由原來的0x0000:0x0078搬到0x9000:0x4000-12;且修改老的磁盤參數表區使之指向新的磁盤參數表;

2.4 接下來就到了load_setup子過程;它調用0x13中斷的第2號服務;把第0道第2扇區開始的連續的setup_sects (為常量4)個扇區讀到緊鄰bootsect的內存區;即0x9000:0x0200開始的2048個字節;而這四個扇區的內容即是 /arch/i386/boot/setup.S編譯連接后對應的二進制代碼; 也就是說,如果要用bootsect-loader進行系統引導,不僅必須把bootsect.S編譯連接后對應的二進制代碼置于MBR,而且還得把 setup.S編譯連接后對應的二進制代碼置于緊跟MBR后的連續的四個扇區中;當然,由于setup.S對應的可執行碼是由bootsect裝載的,所以,在我們的這個項目中可以通過修改bootsect來根據需要隨意地放置setup.S對應的可執行碼;

2.5 load_setup子過程的唯一出口是probe_loop子過程;該過程通過枚舉法測試磁盤“每個磁道的扇區數”;

2.6 接下來幾個子過程比較清晰易懂:打印我們熟悉的“Loading”;讀入系統到0x1000:0x0000; 關掉軟驅馬達;根據的5步測出的“每個磁道的扇區數”確定磁盤類型;最后跳轉到0x9000:0x0200,即setup.S對應的可執行碼的入口,將機 器控制權轉交setup.S;整個bootsect代碼運行完畢;

3.引導過程執行完后的內存印象圖:


出于簡便考慮,在此分析中,我忽略了對大內核的處理的分析,因為對大內核的處理,只是此引導過程中的一個很小的部分,并不影響對整體的把握。完成了系統的引導后,系統將進入到初始化處理階段。系統的初始化分為實模式和保護模式兩部分。

2實模式下的初始化

實模式下的初始化,主要是指從內核引導成功后,到進入保護模式之前系統所做的一些處理。在內核源碼中對應的程序是 /Arch/i386/boot/setup.S;以下部分主要是針對此文件進行的分析。這部分的分析主要是要弄懂它的處理流程和INITSEG (9000:0000)段參數表的建立,此參數表包含了很多硬件參數,這些都是以后進行保護模式下初始化,以及核心建立的基礎。

1.幾個其它相關文件:

<1> /Arch/i386/boot/bootsect.S

<2> /include/linux/config.h

<3> /include/asm/boot.h

<4> /include/ asm/segment.h

<5> /include/linux/version.h

<6> /include/linux/compile.h

2.實模式下的初始化過程分析:

INITSEG(9000:0000)段參數表:(參見Include/linux/tty.h)

* 注:

① Include/linux/tty.h : CL_MAGIC and CL_OFFSET here

②Include/linux/tty.h : unsigned char rsvd_size; /* 0x2c */ unsigned char rsvd_pos; /* 0x2d */

③ 0表示沒有APM BIOS

④ 0x0002置位表示支持32位模式

⑤ 0表示沒有,0x0aa表示有鼠標器

3保護模式下的初始化

保護模式下的初始化,是指處理機進入保護模式后到運行系統第一個內核程序過程中系統所做的一些處理。保護模式下的初始化在內核源碼中對應的程序是/Arch/i386/boot/compressed/head.S 和 /Arch/i386/KERNEL/head.S ;以下部分主要是針對這兩個文件進行的分析。

1.幾個相關文件:

<1> /Arch/i386/boot/compressed/head.S

<2> /Arch/i386/KERNEL/head.S

<3> //Arch/i386/boot/compressed/MISC.c

<4> /Arch/i386/boot/setup.S

<5> /include/ asm/segment.h

<6> /arch/i386/kernel/traps.c

<7> /include/i386/desc.h

<8> /include/asm-i386/processor.h
2.保護模式下的初始化過程分析:

一、/Arch/i386/KERNEL/head.S流程:


二、/Arch/i386/boot/compressed/head.S流程:

1.從流程圖中可以看到,保護模式下的初始化主要干了這樣幾件事: a.解壓內核到0x100000處、 b.建立頁目錄和pg0頁表并啟動分頁功能(即虛存管理功能)、 c.保存實模式下測到的硬件信息到empty_zero_page、初始化命令緩存區、 d.檢測cpu類型、檢查協處理器、 e.重新建立gdt全局描述符表、和中斷描述附表idt;

2.從頁目錄和pg0頁表可以看出,0�;4M物理內存被用作系統區,它被映射到系統段線性空間的0�;4M和3G�;3G+4M;即系統可以通過訪問這兩個段來訪問實際的0�;4M物理內存,也就是系統所在的區域;

3.本來在實模式下初始化時已經建立了全局描述符表gdt,而此處重新建立全局描述符表gdt則主要是出于兩個原因:一個就是若內核是大內核bzimag,則以 前建立的gdt,可能已經在解壓時被覆蓋掉了所以,在這個源碼文件中均只采用相對轉移指令jxx nf或jxx nb;二是以前建立的gdt是建立在實地址方式下的,而現在則是在啟用保護虛擬地址方式之后建立的,也即現在的gdt是建立在邏輯地址(即線性地址)上 的;

4.每次建立新的gdt后和啟用保護虛擬地址方式后都必須重新裝載系統棧和重新初始化各段寄存器:cs,ds,es,fs,gs;

5.從實模式下的初始化和保護模式下的初始化過程可以看出,linux系統由實模式進入到保護模式的過程大致如下:

6.由于分頁機制只能在保護模式下啟動,不能在實模式下啟動,所以第一步是必要的;又因為在386保護模式下gdt和idt是建立在邏輯地址(線性地址)上的,所以第三步也是必要的;

7.經過實模式和保護模式下的初始后,主要系統數據分布如下:

初始后主要系統數據分布表

從上面對Linux系統的初始化過程的分析可以看出,以程序執行流程為線索、一線串珠,就是按照程序的執行先后順序,弄懂程序執行的各個階段所進行的處理,及其各階段之間的相互聯系。而流程圖應該是這種分析方法最合適的表達工具。

事實上,以程序執行流程為線索,是分析任何源代碼都首選的方法。由于操作系統的特殊性,光用這種方法是遠遠不夠的。當然用這種方法來分析系統的初始化過程或用戶進程的執行流程應該說是很有效的。

-END-

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

    關注

    87

    文章

    11469

    瀏覽量

    212899
  • 代碼
    +關注

    關注

    30

    文章

    4891

    瀏覽量

    70306

原文標題:還沒搞懂Linux內核?手把手教你分析

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    手把手教你如何調優Linux網絡參數

    在高并發網絡服務場景中,Linux內核的默認網絡參數往往無法滿足需求,導致性能瓶頸、連接超時甚至服務崩潰。本文基于真實案例分析,從參數解讀、問題診斷到優化實踐,手把手
    的頭像 發表于 05-29 09:21 ?126次閱讀

    【精選直播】手把手教你做星閃無人機第九課:無線通信編程之 SLE 專題

    手把手教你做星閃無人機》系列直播課再度開播!《KaihongOS星閃無人機開發實戰⑨:無線通信編程之SLE專題》↑掃碼入群,領課程講義資料包↑深開鴻資深工程師親臨直播間依托筆電實戰產品案例細致剖析
    的頭像 發表于 05-27 08:05 ?77次閱讀
    【精選直播】<b class='flag-5'>手把手</b><b class='flag-5'>教你</b>做星閃無人機第九課:無線通信編程之 SLE 專題

    明晚七點!手把手教你做PC第九課:全功能TypeC驅動框架適配

    手把手教你做PC》系列直播課再度開播!《KaihongOS筆記本電腦開發實戰第九課:全功能TypeC驅動框架適配》將于5月21日19:00開播↑掃碼入群,領課程講義資料包↑深開鴻資深工程師親臨直播
    的頭像 發表于 05-20 08:07 ?83次閱讀
    明晚七點!<b class='flag-5'>手把手</b><b class='flag-5'>教你</b>做PC第九課:全功能TypeC驅動框架適配

    正點原子Linux系列全新視頻教程來啦!手把手教你MP257開發板,讓您輕松入門!

    正點原子Linux系列全新視頻教程來啦!手把手教你MP257開發板,讓您輕松入門! 一、視頻觀看 正點原子手把手教你學STM32MP257
    發表于 05-16 10:42

    GPU顯卡維修避坑指南:手把手教你識別行業套路!

    的今天,高端顯卡維修已成“暴利暗流”。虛高報價、偷換配件、技術陷阱……用戶稍有不慎,輕則損失數萬,重則設備報廢。今天小助手將揭露行業亂象,手把手教你識別套路,并推薦
    的頭像 發表于 04-02 20:31 ?662次閱讀
    GPU顯卡維修避坑指南:<b class='flag-5'>手把手</b><b class='flag-5'>教你</b>識別行業套路!

    KiCad直播活動(三):在 Windows上編譯KiCad 手把手教您編譯/構建 KiCad 源碼

    Developer Ethan 同學,手把手教您編譯/構建 KiCad 源碼: 開發工具安裝 環境變量配置 使用 VS2022 構建 KiCad 參與直播的小伙伴還有機會獲得 KiCon Badge
    的頭像 發表于 03-24 11:14 ?677次閱讀
    KiCad直播活動(三):在 Windows上編譯KiCad <b class='flag-5'>手把手</b>教您編譯/構建 KiCad 源碼

    《零基礎開發AI Agent——手把手教你用扣子做智能體》

    《零基礎開發AI Agent——手把手教你用扣子做智能體》是一本為普通人量身打造的AI開發指南。它不僅深入淺出地講解了Agent的概念和發展,還通過詳細的工具介紹和實戰案例,幫助讀者快速掌握
    發表于 03-18 12:03

    手把手教你做星閃無人機—KaihongOS星閃無人機開發實戰》系列課程課件匯總

    為助力開發者迅速掌握『KaihongOS輕量系統開發技術』與『星閃無線通信技術』,實現快速上手與深度體驗,“開鴻Developer社區”攜手“電子發燒友”再次聯合推出《手把手教你做星閃無人機
    發表于 03-18 10:33

    手把手教你做PC-KaihongOS筆記本電腦開發實戰》課件匯總

    ”攜手“電子發燒友”聯合推出了 《KaihongOS手把手系列直播課程》,該系列課程以實際產品為案例,詳細講解每個產品的開發全流程。 此次首發內容是《手把手教你做PC-KaihongOS筆記本電腦開發
    發表于 03-18 10:25

    【第四章 定時任務】手把手教你玩轉新版正點原子云

    【第四章 定時任務】手把手教你玩轉新版正點原子云 承接上篇,除了報警聯動這個功能,原子云還有一個特色功能也是各開發者喜歡用的,定時任務功能。 【正點原子】云平臺:原子云(點擊登錄原子云) 前言
    發表于 03-13 10:19

    開發者集結!《手把手教你做星閃無人機》第二課開講啦!

    開發者集結!《手把手教你做星閃無人機》第二課開講啦!
    的頭像 發表于 02-17 19:40 ?299次閱讀
    開發者集結!《<b class='flag-5'>手把手</b><b class='flag-5'>教你</b>做星閃無人機》第二課開講啦!

    手把手教你做星閃無人機》即將開播,鎖定15日晚七點!

    ”再次聯合推出《手把手教你做星閃無人機—KaihongOS星閃無人機開發實戰》系列課程,該課程與《手把手教你做PC—KaihongOS筆記本電腦開發實戰》同步并行,
    的頭像 發表于 01-13 19:42 ?426次閱讀
    《<b class='flag-5'>手把手</b><b class='flag-5'>教你</b>做星閃無人機》即將開播,鎖定15日晚七點!

    手把手教你做PC》課程即將啟動!深開鴻引領探索KaihongOS筆記本電腦開發實戰

    ”攜手“電子發燒友”聯合推出了《KaihongOS手把手系列直播課程》,該系列課程以實際產品為案例,詳細講解每個產品的開發全流程。此次首發內容是《手把手教你做PC-
    的頭像 發表于 01-06 20:46 ?494次閱讀
    《<b class='flag-5'>手把手</b><b class='flag-5'>教你</b>做PC》課程即將啟動!深開鴻引領探索KaihongOS筆記本電腦開發實戰

    Air780E模組LuatOS開發實戰 —— 手把手教你搞定數據打包解包

    本文要說的是低功耗4G模組Air780E的LuatOS開發實戰,我將手把手教你搞定數據打包解包。
    的頭像 發表于 12-03 11:17 ?567次閱讀
    Air780E模組LuatOS開發實戰 —— <b class='flag-5'>手把手</b><b class='flag-5'>教你</b>搞定數據打包解包

    手把手教你通過宏集物聯網工控屏&amp;網關進行協議轉換,將底層PLC/傳感器的數據轉換為TCP協議并傳輸到用戶

    手把手教你通過宏集物聯網工控屏&網關進行協議轉換,將底層PLC/傳感器的數據轉換為TCP協議并傳輸到用戶終端
    的頭像 發表于 08-15 13:29 ?986次閱讀
    <b class='flag-5'>手把手</b><b class='flag-5'>教你</b>通過宏集物聯網工控屏&amp;網關進行協議轉換,將底層PLC/傳感器的數據轉換為TCP協議并傳輸到用戶
    主站蜘蛛池模板: 亚洲午夜视频在线观看 | 亚洲综合情 | 二区三区视频 | 亚洲爱婷婷色婷婷五月 | 国产精品久久久久网站 | 亚洲 欧美 成人 | 亚洲一区亚洲二区 | 网友偷自拍原创区 | 国产美女精品久久久久中文 | 四虎影院免费在线 | 国产片无遮挡在线看床戏 | 免费观看午夜在线欧差毛片 | 伊人精品成人久久综合欧美 | 黄色免费网站在线播放 | 奇米影视一区二区三区 | 视频一区 在线 | 国产综合色在线视频区色吧图片 | 午夜视频在线播放 | 777影院| 日本免费黄色小视频 | 天堂在线精品 | 黄色网一级片 | 人人看操 | 精品三级在线观看 | 中国特黄毛片 | 性色爽爱性色爽爱网站 | 中文字幕一区二区三区精品 | 四虎永久免费地址 | 伊人网99| v天堂网| 日本在线不卡一区二区 | 国产尤物在线视频 | 婷婷色5月 | 美女张开大腿让男人桶 | 四虎影院在线播放 | 国产综合精品久久久久成人影 | 国产成人啪精品午夜在线播放 | 久久久久久久久久久观看 | 特级一级毛片 | 久久99热精品这里久久精品 | 天天干干干 |