《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 低固存嵌入式系統的uClinux小型化方法
低固存嵌入式系統的uClinux小型化方法
摘要:  針對低固存嵌入式系統,可以通過以上的小型化措施,恨據具體的嵌入式應用定制uClinux,同時增加了系統的可移植性、易擴展性。但由于對原系統的某些功能作了裁剪、刪除,在一定程度上影響了uClinux系統原有的可擴展性和移植性、不過這也是大小與移植性折中后的結果。
Abstract:
Key words :

在許多嵌入式系統中,往往只有低容量的固存,比如MCF5282芯片內只有512k FLASH,而有些微處理器固存可能更低。在不外擴固存容量,降低系統穩定性的條件下,特別是在干擾源嚴重的工控環境下,采用短小、精煉的嵌入式操作系統將具有非常大的實用意義。文中以下內容將針對低固存嵌入式系統,討論uClinux的幾種特殊簡化方法,應用這些方法,將非常有助于開發者開發出適合于自已的嵌入式系統。

  1 內核移植

  移植前首先要搭建交叉編譯平臺,安裝交叉編譯工具鏈,包括GCC,Binutils,uClibc。準備就緒后即可開始進行移植操作,移植過程中最大困難是如何減小uClinux系統的大小。為此文中從以下兩個方面著手:內核配置級裁剪和內核源代碼級裁剪。

  1.1 內核配置級裁剪

  Linux內核采用模塊化的設計,即很多功能塊可以獨立地加上或卸下,開發人員在設計內核時把這些內核模塊作為可選的選項,可以在編譯系統內核時指定。因此一種較通用的做法是對Linux內核重新編譯,在編譯時仔細地選擇嵌入式設備所需要的功能支持模塊,同時刪除不需要的功能。通過對內核的重新配置,可以使系統運行所需要的內核顯著減小,從而縮減資源使用量。對于內核中不支持的設備,可以自已編制設備驅動程序,然后添加進內核。配置完內核,接下來需要對內核源代碼文件的依賴性和完整性進行檢驗,并進行編譯。

  1.2 內核源代碼級裁剪

  Linux核心包括:進程管理模塊、內存管理模塊、文件系統、設備驅動模塊、網絡模塊。在內核中文件系統和設備驅動程序占了大比重,約1/3以上,所以去除不必要的文件系統和設備驅動程序將會使內核大小有較大范圍的縮減,這已在上一步驟中實現。所以文件系統的裁剪是重中之重。考慮到制作整個根文件系統的高昂代價,約有700kbyte大小,而一般嵌入式微處理器的FLASH一般小于512kbyte,根本就不可能固化,所以為了縮減系統的大小必須刪除根文件系統,同時也導致內核與應用程序必須一體化。要刪除根文件系統,并不是簡單刪除源代碼,而是一個錯綜復雜的宏大工程。整個系統的框架如圖1所示。

  

 

  在本系統中刪除了根文件系統,但仍保留VFS,主要保持VFS向上層提供統一接口,隱藏下層具體細節等作用,方便開發應用程序。同時針對文件規模小、數量少的嵌入式系統VFS在這里要減小它的規模和簡化它的功能。規模的減小工作主要靠刪除在嵌入式設備不支持的物理文件系統、設備驅動程序及其系統調用的源碼。功能的簡化主要靠簡化部分數據結構和系統調用,這樣可以進一步使系統規模精簡。ReFS文件系統,是根據嵌入式系統的特性開發的一種新的文件系統。具體參見第3節新型文件系統(ReFS)開發。

  由于根文件系統的缺失帶來一些重大影響,分析如下。

   1.2.1 對系統調用的影響

 

  系統調用約有177個,包括關于進程的調用函數、文件的調用函數,以及其它相關的調用,其中文件系統的調用占了71個。由于沒有根系統,系統調用中涉及到從根文件系統上或掛接在它某個文件節點上的其它文件系統上,裝載、執行可執行文件的系統調用都是沒必要的,所以必須做相應的更改。典型的是系統調用execve(),其執行流程主干線如圖2所示。

  exeeve()

  ↓

  do_exeeve()

  ↓

  open_execve()

  ↓

  prepare_binpma()

  ↓

  search_binary_hanlder()

  圖2 execve()執行流程

  do_execve()是execve()的核心,它調用open_exec()尋找可執行文件并打開,函數open_exec()返回一個file結構指針,代表著讀入可執行文件的上下文,將其保存在數據結構bprm中。然后調用prepare_binprm()完成對bprm的進一步工作,包括從可執行文件頭讀取相關信息,以及拷貝運行環境參數等到bprm 中。內核中有一個叫formats的隊列,隊列中的每個成員只認識并且處理一種特定格式的可執行文件的運行。search_binary_handler()就是在formats的隊列中,尋找跟bprm中信息相符的一個成員,并由此成員來完成可執行文件的裝載并初始化運行。由于不存在從文件系統加載可執行文件,所以bpma數據結構,及涉及prepare_binprm(),search_binary_hanlder()等相關操作都是可以刪除的。

  再者,由于沒有可供mount的文件節點,所以有關掛接的系統調用也必須做出調整。比如:mount()是用于文件系統掛接的系統調用,完全可以刪去;內核函數mount_root()在初始化時用于安裝根文件系統,也是可以刪去的;vfsmount()是內核數據結構,用于描述掛載節點的信息,包括掛載點的根目錄,被掛載系統的級塊指針等信息。vfsmount()完全是跟掛載有關的,可以將它刪除,同時內核中有好多涉及操作此數據結構的函數也必須做出更改。比如alloc_vfsmnt()和free_vfsmnt()是分配和釋放vfsmount結構,完全可以刪去,但有些內核函數只有一部分涉及到對vfsrmnt結構的操作,所以不能全部刪除,必須對相應部分做出修改。

  1.2.2 對內核啟動初始化的影響

  由于init()進程不能從根文件系統加載,所以凡是涉及根文件系統初始化函數的都必須刪除,以支持內核與應用程序一體化。初始化進程init代碼如下:

  static int init(void *unused)

  {……

  if(open("/dev/console",O_RDWR,0)< 0)

  ……

  if(execute_command)

  execve(execute_command,argv_init,envp_init);

  execve("/sbin/init",argv_init;envp_init);

  ……

  panic("No init found.Try passing init= option to kernel");

  }

  init()完成系統的初始化,包括外部設備的初始化,釋放init()前初始化后代碼占用的內存,以及控制臺的初始化,最后從根文件系統加載整個系統的第一個進程init,它是所有進程的“鼻祖”。由于根文件的刪除,所以可以刪除控制臺以及調用init進程。

  1.2.3 對ReFS和外部設備的影響

  ReFS可以像mount_root()那樣直接把ReFS當成根文件系統來裝,但它并不像根文件系統那樣有bash,gretty等應用程序,也不具備掛載其它系統的能力,所以不是真正的根文件系統。內核中有幾個根文件系統和外設相關的重要內核級全局變量:file_system_type,btkdevs[MAX_BLKDEV],chrdevs[MAX_CHRDEV],super_block。

  file_system_type是一個描述系統中所有支持的文件系統的數據結構。VFS在內存中維護這樣一個數據結構的列表,全局指針變量為file_systems。新文件系統必須通過register_filesystem()來注冊以讓系統識別,即是在鏈表file_systems結尾插人一個file_systm_type數據結構。blkdevs[MAX_BLKDEV]和chrdevs[MAX_CHRDEV]分別為塊設備和字符設備的注冊數組,包含主設備號和次設備號,以及有關設備操作的跳轉指針。塊設備和字符設備分別通過register_blkdev()和register_chrdev()向系統注冊設備。super_block是超級塊數據結構,存放著整個文件系統的信息和超級塊操作的函數。在通用內核中根文件系統的安裝的順序是:從file_systems處取得根文件系統的read_super(),read_super()指向具體的驅動程序讀操作,通過讀取得超級塊,然后在內存中創建inode,file,dentry等數據結構,用于文件的讀寫操作。

  在這里,同樣可以用與根文件系統相同的裝載方法來初始化ReFS,但是比前者簡單多,因為后者不涉及安裝掛載點及與此相關的操作。對于外設,內核一般是通過根文件系統搜索到設備文件,再來訪問外設,當中要涉及到搜索路徑和掛接點到外設翻譯的問題,而在這里外設是獨立的,不依賴于根系統,所以實現起來更簡單,可以直接依據內核數據結構blkdevs[]和chrdevs[]提供的操作函數表指針,來操作具體的驅動程序操作外設。2 內核與應用程序的一體化

 

  uClinux的內核有兩種可選的運行方式:Flash運行方式和 運行方式。Flash運行方式直接在Flash上運行,是很多嵌入式系統采用的方法。RAM運行方式運行速度可能更快(RAM 的存取速率要比Flash高),所需的內存也較少,同時這也是標準LinuX系統采用的啟動方式。

  不管采用哪種運行方式,沒有文件系統的uClinux必須要實現內核與應用程序的一體化,一體化可以通過創建進程的方式來實現。創建進程可以采用內核函數do_fork()和do_execve(),也可以仍然用系統調用fork()和execve(),因為沒有MMU的微控制器,內核的運行其實是與應用程序一樣的。但在這里execve()是經過上面修改過的,去掉了其裝載可執行文件的能力后,可采用直接跳轉到可執行文件入口點的方法,運行應用程序。創建一個所有應用程序的跳轉表:

  struct App_table{

  Int(*App_main)();//主程序

  int(*LCD_window)();//A機操作界面管理程序

  int(*AD)();//A/D采樣程序

  ……}

  然后在init()末尾添加如下代碼:

  if(fork()==0) execve(App_table->App_main);

  else panic("No App_main found.");

  3 新型文件系統(ReFS)開發

  在某些嵌入式系統中要保存的文件大都是一條條操作記錄或是系統警告提示信息,有固定的數據格式和長度,就好像數據庫里的記錄。而且針對這種簡單文件系統的操作可能非常簡單,所以借鑒EXT2和JFFS2等其它文件系統的設計開發了一種新的文件系統,文中將之命名為記錄型文件系統(ReFS),其存儲物理結構如圖3所示。

  

文件系統ReFS 結構圖

 

  數據塊的大小是記錄大小的n倍,是數據分配的最小單位,可以事先給不同用戶分配不同的的空間,也可以限制用戶使用的存儲空間,然后動態地分配實際物理塊。一個節點代表一個文件,文件是不同用戶操作記錄的一個集合,可由多個數據塊構成。由于空間有限,可將整個空問構成一個循環鏈表,插入和刪除的動作分別在表頭和表尾進行。隨著時間增長和記錄條數的增加,整個存儲空問會飽和,后面存進的記錄會覆蓋前面的記錄,但數據在被覆蓋前早巳失去應用價值,所以只需對鏈表進行插入、刪除、查找等簡單操作,就可以輕松實現對陵文件系統的管理。待整個文件系統的數據結構和操作函數完成后,把該文件系統加進uClinux中去。該步驟主要是構造超級塊、節點、文件在內存中的結構,然后寫出相應的超級塊、節點、文件操作函數集super_operations,inode_operations,file_operations。再編寫read_super函數和注冊函數init_ReFS_fs,最后在Linux的初始例程filesystem_setup()函數中添加:

  #ifdef CONFIG_ReFS_FS

  init_ReFS_fs();

  #endif

  4 結束語

  針對低固存嵌入式系統,可以通過以上的小型化措施,恨據具體的嵌入式應用定制uClinux,同時增加了系統的可移植性、易擴展性。但由于對原系統的某些功能作了裁剪、刪除,在一定程度上影響了uClinux系統原有的可擴展性和移植性、不過這也是大小與移植性折中后的結果。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久综合久久88| 国产模特精品视频久久久久| 这里只有精品视频| 亚洲韩国一区二区三区| 欧美一区二区精品在线| 亚洲性图久久| 亚洲性图久久| 亚洲综合99| 亚洲私人影吧| 亚洲图片欧洲图片av| 亚洲天堂成人在线观看| 国产精品99久久久久久久vr| 亚洲最快最全在线视频| 亚洲人永久免费| 亚洲精品久久| 日韩天堂在线观看| 一本久久综合亚洲鲁鲁五月天| 亚洲美女精品成人在线视频| 亚洲日本电影在线| 99在线精品视频在线观看| 一本色道久久综合| 亚洲视频图片小说| 午夜国产欧美理论在线播放| 亚洲在线播放| 欧美一区二区三区视频在线观看| 欧美一区二区三区电影在线观看| 欧美一区日韩一区| 亚洲国产成人av好男人在线观看| 亚洲国产91精品在线观看| 亚洲全部视频| 一区二区国产在线观看| 亚洲午夜久久久| 亚洲欧美日韩电影| 久久久青草婷婷精品综合日韩 | 99热在线精品观看| 一本色道久久综合狠狠躁篇的优点| 一区二区三区 在线观看视| 亚洲校园激情| 久久国产精品亚洲va麻豆| 可以免费看不卡的av网站| 欧美成人在线网站| 欧美日韩一区视频| 国产欧美另类| 在线观看日韩专区| 99视频精品全部免费在线| 亚洲欧美日韩系列| 亚洲国产精品成人一区二区| 一本到12不卡视频在线dvd| 亚洲一区二区三区乱码aⅴ| 欧美亚洲综合网| 美女主播一区| 欧美特黄a级高清免费大片a级| 国产日韩欧美成人| 亚洲国产毛片完整版| 国产精品99久久久久久久久久久久 | 欧美日韩免费观看一区| 亚洲三级毛片| 欧美国产激情二区三区| 欧美人成网站| 国产在线欧美| 日韩视频精品| 欧美一级免费视频| 亚洲裸体俱乐部裸体舞表演av| 亚洲欧美另类中文字幕| 猛干欧美女孩| 国产精品国产精品国产专区不蜜| 国产性猛交xxxx免费看久久| 91久久精品国产91久久性色| 亚洲综合不卡| 亚洲精选在线观看| 欧美主播一区二区三区美女 久久精品人| 老**午夜毛片一区二区三区| 欧美午夜电影完整版| 在线观看国产欧美| 亚洲欧美经典视频| 亚洲午夜精品网| 欧美福利专区| 国内外成人免费激情在线视频| 一区二区av| 亚洲精品一区二区网址| 欧美日韩在线免费视频| 欧美精品黄色| 国产揄拍国内精品对白| 亚洲精品在线观| 久久精品成人一区二区三区| 一区二区三区国产在线观看| 久久久天天操| 国产精品久久久久久久浪潮网站| 亚洲成色777777女色窝| 亚洲欧美一区二区精品久久久| 99精品欧美一区| 久久影院亚洲| 国产日韩在线亚洲字幕中文| 一本久道久久综合婷婷鲸鱼| 亚洲人成网站色ww在线| 久久激情婷婷| 国产精品久久久久久妇女6080| 亚洲级视频在线观看免费1级| 性8sex亚洲区入口| 亚洲午夜精品网| 欧美欧美天天天天操| 黄色成人av| 香蕉成人伊视频在线观看| 亚洲一区二区高清视频| 欧美高清不卡| 亚洲国产成人精品久久久国产成人一区| 欧美一级在线亚洲天堂| 欧美亚洲免费高清在线观看| 欧美国产极速在线| 亚洲国产精品日韩| 亚洲第一综合天堂另类专| 在线视频你懂得一区二区三区| 久久九九精品| 欧美视频在线一区二区三区| 亚洲精品乱码久久久久久蜜桃麻豆 | 国产精品theporn88| 日韩性生活视频| 一区二区三区不卡视频在线观看| 欧美电影电视剧在线观看| 在线观看精品| 亚洲精品久久久久久久久久久| 麻豆成人在线观看| 亚洲成人在线网站| 日韩香蕉视频| 欧美日韩在线播放三区| 一区二区三区不卡视频在线观看| 在线中文字幕不卡| 国产精品久久99| 亚洲一区在线观看视频| 欧美一区二区三区精品电影| 国产人妖伪娘一区91| 欧美亚洲一区在线| 久久在线播放| 亚洲人成久久| 亚洲一区二区黄色| 国产精品中文字幕欧美| 欧美一区二区三区视频在线 | 欧美成人精品在线| 亚洲精品久久久一区二区三区| 一区二区三区波多野结衣在线观看| 欧美日韩精品免费观看视频| 99视频有精品| 欧美中日韩免费视频| 激情成人av| 99精品国产福利在线观看免费| 欧美性猛交99久久久久99按摩| 亚洲一区二区三区在线观看视频| 久久精品99国产精品| …久久精品99久久香蕉国产 | 欧美chengren| 99精品久久久| 欧美在线日韩精品| 亚洲福利在线观看| 亚洲亚洲精品在线观看 | 国产麻豆精品视频| 亚洲国产一区二区三区a毛片 | 亚洲在线成人| 久久这里有精品视频| 亚洲电影天堂av| 一区二区三区视频免费在线观看| 国产精品看片资源| 亚洲第一页在线| 欧美三级小说| 亚洲第一福利视频| 欧美日韩一区二区免费视频| 午夜视频在线观看一区二区三区| 久久综合久久综合久久综合| 亚洲精品久久久蜜桃| 欧美在线日韩在线| 亚洲级视频在线观看免费1级| 午夜性色一区二区三区免费视频 | 亚洲欧美一级二级三级| 欧美成人69av| 亚洲午夜精品久久久久久浪潮| 久久免费观看视频| 亚洲精选大片| 久久青草欧美一区二区三区| 99精品国产福利在线观看免费| 久久精品一区四区| aa亚洲婷婷| 欧美成年人网站| 欧美亚洲在线| 欧美午夜片在线观看| 亚洲国产高清aⅴ视频| 国产精品久久久久久av下载红粉| 亚洲国产高潮在线观看| 国产精品毛片a∨一区二区三区|国 | 欧美性久久久| 亚洲精品久久久久久久久久久久久 | 在线看片日韩| 欧美一区=区| 亚洲日产国产精品| 久久久噜噜噜久久人人看| 一本色道久久99精品综合 | 欧美精品久久99久久在免费线| 性色av一区二区三区在线观看 | 欧美性猛片xxxx免费看久爱| 亚洲高清二区| 国产亚洲精品久久久久久| 亚洲五月六月|