跳到主要內容

尾聲-總結,一顆全新的硬碟開始

步驟

  1. 使用 fdisk 等工具查看硬碟的分區情況,確定要裝到哪個分區,記下分區的首磁區磁區號
    $ bximage -q -hd -mode=flat -size=120 120m.img
    $ fdisk 120m.img
    磁碟 120m.img: 125 MB,125411328 位元組
    255 磁頭,63 磁區/磁軌,15 磁柱,總計 244944 磁區
    單位 = 磁區 之於 1 * 512 = 512 位元組
    磁區大小 (邏輯/實體):512 位元組 / 512 位元組
    I/O 大小 (最小/最佳化):512 位元組 / 512 位元組
    磁碟識別碼:0x00000000
    
    所用裝置 開機      開始         結束      區塊   識別號  系統
    120m.img1            2048       43007       20480   83  Linux
    120m.img2           43008      244943      100968    5  延伸
    120m.img5           45056      147455       51200   83  Linux
    120m.img6   *      149504      190463       20480   99  未知
    120m.img7          192512      244943       26216   83  Linux

    看得出來,我們預計安裝在 120m.img6,其根磁區為 149504(即 0x24800),大小為 40960(即 0xA000,190463-149504+1)
  2. 算出分區的次設備號:120m.img6,即為 hd2b
  3. 修改 boot/include/load.inc 的 ROOT_BASE 為 0x24800
  4. 修改 include/sys/const.h,大約在第 263 行,新增
    #define MINOR_hd2b      (MINOR_hd1a+NR_SUB_PER_PART+1)
  5. 修改 include/sys/config.h 的 MINOR_BOOT 為 MINOR_hd2b
  6. 修改 include/sys/config.h 的 INSTALL_START_SECT 為 0x8F00 (必須小於 0xA000 - 0x800 - 0x800 = 0x9000)
  7. 編譯印象檔:make image
  8. 將 hdboot.bin 寫入分割區 120m.img6 的開機磁區
  9. 寫入 GRUB 的 stage1 和 stage2 到硬碟 120m.img
  10. 用軟碟開機,以安裝作業系統到分割區 120m.img6
  11. 從硬碟啟動,待出現 grub 提示符,輸入命令
    grub > rootnoverify (hd0, 5)
    grub > chainloader +1
    grub > boot
  12. 啟動成功
執行結果

接著呢?何不安裝在自己的硬碟?:P

留言

這個網誌中的熱門文章

用 C# 批次控制 Word 合併列印

前由 我有全區的電話資料,問題在於我要依不同里別來製作出電話簿。結果如下圖: 單純採用合併列印無法達成我的需求。解決方法係用「功能變數」儲存上一個里別,與現在里別進行比較:若不同,則換頁。不過,這樣功能變數還蠻長的。最後,我還是採用 C# 來解決。 解決方案 用 C# 控制 WORD 中合併列印的「資料來源 Data Source」,給予不同里別的「sqlstatement」。迴圈處理不同的里別即可。但可預見其處理過程會很慢,不過還好,我可以不用在意它,有跑出結果即可。 程式碼 IList<string> areas = new List<string>() { "後壁", "侯伯", "嘉苳", "土溝", "嘉田", "嘉民", "菁豊", "崁頂", "後廍", "墨林", "菁寮", "新嘉", "頂長", "平安", "仕安", "竹新", "新東", "長安", "頂安", "福安", "烏樹" }; string root = @"D:\"; // 根目錄 string data = root + @"\data.docm"; // 資料檔(即資料來源) string template = root + @"\template.docx"; // 已設定好格式與合併欄位的 Word 檔 string output = @"d:\Final"; // 輸出之資料夾 object oMissing = System.Reflection.Missing.Va...

VLC c# 順利編譯

原文網址: http://www.cnblogs.com/haibindev/archive/2011/12/21/2296173.html 原文作者: haibindev 原文標題:c#万能视频播放器 本文的重點在於修正 class VlcPlayer,使其能順利在 VC# Express 2010 .Net Framework 4 下順利編譯。 修正重點在於 CallingConvention = CallingConvention. StdCall 改成 CallingConvention = CallingConvention. Cdecl using System; using System.Runtime.InteropServices; using System.Security; using System.Text; namespace VlcDotNet { class VlcPlayer { private IntPtr libvlc_instance_; private IntPtr libvlc_media_player_; private double duration_; public VlcPlayer(string pluginPath) { string plugin_arg = "--plugin-path=" + pluginPath; string[] arguments = { "-I", "dummy", "--ignore-config", "--no-video-title", plugin_arg }; libvlc_instance_ = LibVlcAPI.libvlc_new(arguments); libvlc_media_player_ = LibVlcAPI.libvlc_media_player_new(libvlc_instance_); } public ...

[Symfony+Doctrine] 透過非 Id 來使用 Pessimistic Lock

根據 文件 ,Doctrine 有 Pessimistic Lock,又分為兩種: LockMode::PESSIMISTIC_WRITE:對應至 MySQL 的 Select FOR UPDATE LockMode::PESSIMISTIC_READ:對應至 MySQL 的 Select LOCK IN SHARE MODE 差別在於 LOCK IN SHARE MODE 會將在 row 的資料鎖定(row-level lock),在非同一交易(Transaction)下,不給寫入,其他交易可以讀取, 且可以繼續 Select LOCK IN SHARE MODE 。而 FOR UPDATE 不僅鎖定該資料,在非同一交易下,不給寫入,其它交易可以讀取, 但不能 Select LOCK IN SHARE MODE 。MySQL 文件有更詳細的比較與情境使用的說明,參考 網址 。 現在問題是,我們要完全採用 ORM 來處理資料。Doctrine 的文件提到 EntityManager::find 可以採用 Pessimistic Lock, 但 find 是透過 id 來處理 。而其他 find 系列函數(包括:findAll, findBy, findOneBy)皆不支援 LockMode。 因此,勢必要有方法來「透過非 id 來使用 Pessimistic Lock」。透過查看原始碼,簡單的方法是有的,解法之範例如下: 19 public function depositAction() 20 { 21 22 $em = $this->getDoctrine()->getManager(); 23 24 $em->transactional(function ($em) { 25 $entityName = 'AcmeTrainingBundle:Account'; 26 $lockMode = LockMode::PESSIMISTIC_READ; 27 $orderBy = null; 28 $...