• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            2016年9月27日

            使用 Ubuntu Server  難免會遇到需要gui的時候,
            這里介紹一種最簡單的方法

            $sudo tasksel

            這一句就可以了。
            然后會有桌面列表可以選擇,空格鍵選擇,然后回車。
            等待完成。

            posted @ 2016-09-27 17:04 snowman1101 閱讀(1570) | 評論 (0)編輯 收藏

            2016年6月14日

            今天拿到了 Microsoft Surface 3 ,
            測試一個EFI程序的時候總是出問題,
            后來查了一下,發(fā)現(xiàn)在使用EFI_BLOCK_IO 取得外接USB閃存大小的時候
            也就是 BlkIo->Media->LastBlock 取得的大小會比實(shí)際的多出來一個
            估計(jì)是寫固件的人理解出了問題。
            這里是定義
            /**
              Block IO read only mode data and updated only via members of BlockIO
            *
            */
            typedef struct {
              ///
              
            /// The curent media Id. If the media changes, this value is changed.
              
            ///
              UINT32  MediaId;         
               ///
              
            /// TRUE if the media is removable; otherwise, FALSE.
              
            ///    
              BOOLEAN RemovableMedia;
               ///
              
            /// TRUE if there is a media currently present in the device;
              
            /// othersise, FALSE. THis field shows the media present status
              
            /// as of the most recent ReadBlocks() or WriteBlocks() call.  
              
            ///
              BOOLEAN MediaPresent;
              ///
              
            /// TRUE if LBA 0 is the first block of a partition; otherwise
              
            /// FALSE. For media with only one partition this would be TRUE.
              
            ///
              BOOLEAN LogicalPartition;
               ///
              
            /// TRUE if the media is marked read-only otherwise, FALSE.
              
            /// This field shows the read-only status as of the most recent WriteBlocks () call.
              
            ///
              BOOLEAN ReadOnly;
               ///
              
            /// TRUE if the WriteBlock () function caches write data.
              
            ///
              BOOLEAN WriteCaching; 
               ///
              
            /// The intrinsic block size of the device. If the media changes, then
              
            /// this field is updated.  
              
            ///
              UINT32  BlockSize; 
               ///
              
            /// Supplies the alignment requirement for any buffer to read or write block(s).
              
            ///
              UINT32  IoAlign; 
               ///
              
            /// The last logical block address on the device.
              
            /// If the media changes, then this field is updated. 
              
            ///
              EFI_LBA LastBlock; 
              ///
              
            /// Only present if EFI_BLOCK_IO_PROTOCOL.Revision is greater than or equal to
              
            /// EFI_BLOCK_IO_PROTOCOL_REVISION2. Returns the first LBA is aligned to 
              
            /// a physical block boundary. 
              
            ///
              EFI_LBA LowestAlignedLba;
              ///
              
            /// Only present if EFI_BLOCK_IO_PROTOCOL.Revision is greater than or equal to
              
            /// EFI_BLOCK_IO_PROTOCOL_REVISION2. Returns the number of logical blocks 
              
            /// per physical block.
              
            ///
              UINT32 LogicalBlocksPerPhysicalBlock;
              ///
              
            /// Only present if EFI_BLOCK_IO_PROTOCOL.Revision is greater than or equal to
              
            /// EFI_BLOCK_IO_PROTOCOL_REVISION3. Returns the optimal transfer length
              
            /// granularity as a number of logical blocks.
              
            ///
              UINT32 OptimalTransferLengthGranularity;
            } EFI_BLOCK_IO_MEDIA;
            其中那個LastBlock是這樣說明的
              /// The last logical block address on the device.
            所以應(yīng)該是總的block 數(shù)-1.
            不知道微軟的工程師為什么會有這樣的錯誤

            posted @ 2016-06-14 09:28 snowman1101 閱讀(544) | 評論 (0)編輯 收藏

            2013年3月28日

            前言 
             編譯好 EFI程序后,每次都用U盤到另外一臺電腦上測試實(shí)在很麻煩,一天下來U盤要插拔很多次
            無意中發(fā)現(xiàn)
            Oracle VM VirtualBox 的系統(tǒng)選項(xiàng)中有個 支持 EFi 。
            又在網(wǎng)上找了一下發(fā)現(xiàn) VMware Player 也可以支持 EFI
            下面總結(jié)一下方法

            1. 首先到VMWARE官網(wǎng)下載免費(fèi)的 VMware Player 下載
            2.正常安裝VM Player后 創(chuàng)建一個新的虛擬主機(jī),并且類型選擇 64位的OS
            3.到創(chuàng)建的虛擬機(jī)目錄 找到 .
            vmx文件 用記事本打開 然后添加一行 
            firmware = "efi" 
            這樣你的VM虛擬機(jī)就支持UEFI啟動了。


            如果想要測試我們自己編譯的 .EFI 程序的話
            到虛擬主機(jī)的編輯選項(xiàng)中,新添加一個硬盤,然后類型選擇實(shí)際物理磁盤
            根據(jù)個人的需要再選擇整個磁盤或者某一個分區(qū)
            之后把編譯好的EFI文件復(fù)制到指定的磁盤或者分區(qū)中就可以了。
            要注意的是,開啟虛擬機(jī)的時候必須保證指定的磁盤/分區(qū)是關(guān)閉的。同樣復(fù)制文件的時候也要關(guān)閉虛擬機(jī)。






            posted @ 2013-03-28 11:12 snowman1101 閱讀(632) | 評論 (0)編輯 收藏

            僅列出標(biāo)題  
            久久国产成人午夜AV影院| 狠狠色丁香久久婷婷综合蜜芽五月 | 好属妞这里只有精品久久| 久久人人爽人人爽人人片AV麻豆| 久久精品国产72国产精福利| 国产毛片欧美毛片久久久| 久久久久久亚洲Av无码精品专口 | 久久99精品久久久久久9蜜桃 | 国产精品欧美久久久久无广告| 久久免费视频1| 国产一级做a爰片久久毛片| 国产精品综合久久第一页| 中文字幕久久精品无码| 国产成人无码精品久久久免费 | 日本精品久久久中文字幕| 伊人久久大香线焦AV综合影院| 国产精品99久久久久久人| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久影视综合亚洲| 国内精品久久国产| 99久久免费国产精品热| 亚洲伊人久久成综合人影院| 久久亚洲精品无码AV红樱桃| 亚洲人AV永久一区二区三区久久| 久久精品一本到99热免费| 久久夜色精品国产亚洲av| 超级碰久久免费公开视频| 久久国产精品无码一区二区三区 | 久久ww精品w免费人成| 欧美精品福利视频一区二区三区久久久精品| 伊人久久大香线蕉综合Av | 久久久久亚洲精品无码蜜桃| 久久精品国产久精国产果冻传媒| 日本精品久久久久久久久免费| 99国产精品久久| 久久久久亚洲精品天堂| 久久综合国产乱子伦精品免费| 亚洲精品乱码久久久久久蜜桃不卡 | 久久婷婷五月综合97色直播 | 麻豆成人久久精品二区三区免费| 日日狠狠久久偷偷色综合96蜜桃|