亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? gpt.c

?? Util-linux 軟件包包含許多工具。其中比較重要的是加載、卸載、格式化、分區(qū)和管理硬盤驅(qū)動器
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*    gpt.[ch]    Copyright (C) 2000-2001 Dell Computer Corporation <Matt_Domsch@dell.com>     EFI GUID Partition Table handling    Per Intel EFI Specification v1.02    http://developer.intel.com/technology/efi/efi.htm    This program is free software; you can redistribute it and/or modify    it under the terms of the GNU General Public License as published by    the Free Software Foundation; either version 2 of the License, or    (at your option) any later version.    This program is distributed in the hope that it will be useful,    but WITHOUT ANY WARRANTY; without even the implied warranty of    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the    GNU General Public License for more details.    You should have received a copy of the GNU General Public License    along with this program; if not, write to the Free Software    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA*/#define _FILE_OFFSET_BITS 64#include <stdio.h>#include <string.h>#include <stdlib.h>#include <inttypes.h>#include <sys/stat.h>#include <sys/ioctl.h>#include <fcntl.h>#include <unistd.h>#include <errno.h>#include <asm/byteorder.h>#include "crc32.h"#include "gpt.h"#include "partx.h"#define BLKGETLASTSECT  _IO(0x12,108)   /* get last sector of block device */#define BLKGETSIZE _IO(0x12,96)	        /* return device size */#define BLKSSZGET  _IO(0x12,104)	/* get block device sector size */#define BLKGETSIZE64 _IOR(0x12,114,sizeof(uint64_t))	/* return device size in bytes (u64 *arg) */struct blkdev_ioctl_param {        unsigned int block;        size_t content_length;        char * block_contents;};/** * efi_crc32() - EFI version of crc32 function * @buf: buffer to calculate crc32 of * @len - length of buf * * Description: Returns EFI-style CRC32 value for @buf *  * This function uses the little endian Ethernet polynomial * but seeds the function with ~0, and xor's with ~0 at the end. * Note, the EFI Specification, v1.02, has a reference to * Dr. Dobbs Journal, May 1994 (actually it's in May 1992). */static inline uint32_tefi_crc32(const void *buf, unsigned long len){	return (crc32(~0L, buf, len) ^ ~0L);}/** * is_pmbr_valid(): test Protective MBR for validity * @mbr: pointer to a legacy mbr structure * * Description: Returns 1 if PMBR is valid, 0 otherwise. * Validity depends on two things: *  1) MSDOS signature is in the last two bytes of the MBR *  2) One partition of type 0xEE is found */static intis_pmbr_valid(legacy_mbr *mbr){	int i, found = 0, signature = 0;	if (!mbr)		return 0;	signature = (__le16_to_cpu(mbr->signature) == MSDOS_MBR_SIGNATURE);	for (i = 0; signature && i < 4; i++) {		if (mbr->partition[i].sys_type ==                    EFI_PMBR_OSTYPE_EFI_GPT) {			found = 1;			break;		}	}	return (signature && found);}/************************************************************ * get_sector_size * Requires: *  - filedes is an open file descriptor, suitable for reading * Modifies: nothing * Returns: *  sector size, or 512. ************************************************************/static intget_sector_size(int filedes){	int rc, sector_size = 512;	rc = ioctl(filedes, BLKSSZGET, &sector_size);	if (rc)		sector_size = 512;	return sector_size;}/************************************************************ * _get_num_sectors * Requires: *  - filedes is an open file descriptor, suitable for reading * Modifies: nothing * Returns: *  Last LBA value on success  *  0 on error * * Try getting BLKGETSIZE64 and BLKSSZGET first, * then BLKGETSIZE if necessary. *  Kernels 2.4.15-2.4.18 and 2.5.0-2.5.3 have a broken BLKGETSIZE64 *  which returns the number of 512-byte sectors, not the size of *  the disk in bytes. Fixed in kernels 2.4.18-pre8 and 2.5.4-pre3. ************************************************************/static uint64_t_get_num_sectors(int filedes){	unsigned long sectors=0;	int rc;#if 0        uint64_t bytes=0; 	rc = ioctl(filedes, BLKGETSIZE64, &bytes);	if (!rc)		return bytes / get_sector_size(filedes);#endif        rc = ioctl(filedes, BLKGETSIZE, &sectors);        if (rc)                return 0;        	return sectors;}/************************************************************ * last_lba(): return number of last logical block of device *  * @fd *  * Description: returns Last LBA value on success, 0 on error. * Notes: The value st_blocks gives the size of the file *        in 512-byte blocks, which is OK if *        EFI_BLOCK_SIZE_SHIFT == 9. ************************************************************/static uint64_tlast_lba(int filedes){	int rc;	uint64_t sectors = 0;	struct stat s;	memset(&s, 0, sizeof (s));	rc = fstat(filedes, &s);	if (rc == -1) {		fprintf(stderr, "last_lba() could not stat: %s\n",			strerror(errno));		return 0;	}	if (S_ISBLK(s.st_mode)) {		sectors = _get_num_sectors(filedes);	} else {		fprintf(stderr,			"last_lba(): I don't know how to handle files with mode %x\n",			s.st_mode);		sectors = 1;	}	return sectors - 1;}static ssize_tread_lastoddsector(int fd, uint64_t lba, void *buffer, size_t count){        int rc;        struct blkdev_ioctl_param ioctl_param;        if (!buffer) return 0;         ioctl_param.block = 0; /* read the last sector */        ioctl_param.content_length = count;        ioctl_param.block_contents = buffer;        rc = ioctl(fd, BLKGETLASTSECT, &ioctl_param);        if (rc == -1) perror("read failed");        return !rc;}static ssize_tread_lba(int fd, uint64_t lba, void *buffer, size_t bytes){	int sector_size = get_sector_size(fd);	off_t offset = lba * sector_size;        ssize_t bytesread;	lseek(fd, offset, SEEK_SET);	bytesread = read(fd, buffer, bytes);        /* Kludge.  This is necessary to read/write the last           block of an odd-sized disk, until Linux 2.5.x kernel fixes.           This is only used by gpt.c, and only to read           one sector, so we don't have to be fancy.        */        if (!bytesread && !(last_lba(fd) & 1) && lba == last_lba(fd)) {                bytesread = read_lastoddsector(fd, lba, buffer, bytes);        }        return bytesread;}/** * alloc_read_gpt_entries(): reads partition entries from disk * @fd  is an open file descriptor to the whole disk * @gpt is a buffer into which the GPT will be put   * Description: Returns ptes on success,  NULL on error. * Allocates space for PTEs based on information found in @gpt. * Notes: remember to free pte when you're done! */static gpt_entry *alloc_read_gpt_entries(int fd, gpt_header * gpt){	gpt_entry *pte;        size_t count = __le32_to_cpu(gpt->num_partition_entries) *                __le32_to_cpu(gpt->sizeof_partition_entry);        if (!count) return NULL;	pte = (gpt_entry *)malloc(count);	if (!pte)		return NULL;	memset(pte, 0, count);	if (!read_lba(fd, __le64_to_cpu(gpt->partition_entry_lba), pte,                      count)) {		free(pte);		return NULL;	}	return pte;}/** * alloc_read_gpt_header(): Allocates GPT header, reads into it from disk * @fd  is an open file descriptor to the whole disk * @lba is the Logical Block Address of the partition table *  * Description: returns GPT header on success, NULL on error.   Allocates * and fills a GPT header starting at @ from @bdev. * Note: remember to free gpt when finished with it. */static gpt_header *alloc_read_gpt_header(int fd, uint64_t lba){	gpt_header *gpt;	gpt = (gpt_header *)	    malloc(sizeof (gpt_header));	if (!gpt)		return NULL;	memset(gpt, 0, sizeof (*gpt));	if (!read_lba(fd, lba, gpt, sizeof (gpt_header))) {		free(gpt);		return NULL;	}	return gpt;}/** * is_gpt_valid() - tests one GPT header and PTEs for validity * @fd  is an open file descriptor to the whole disk * @lba is the logical block address of the GPT header to test * @gpt is a GPT header ptr, filled on return. * @ptes is a PTEs ptr, filled on return. * * Description: returns 1 if valid,  0 on error. * If valid, returns pointers to newly allocated GPT header and PTEs. */static intis_gpt_valid(int fd, uint64_t lba,             gpt_header ** gpt, gpt_entry ** ptes){	int rc = 0;		/* default to not valid */	uint32_t crc, origcrc;	if (!gpt || !ptes)                return 0;	if (!(*gpt = alloc_read_gpt_header(fd, lba)))		return 0;	/* Check the GUID Partition Table signature */	if (__le64_to_cpu((*gpt)->signature) != GPT_HEADER_SIGNATURE) {

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品在线免费观看| 欧美三级资源在线| 亚洲成a人片在线观看中文| 久久久精品人体av艺术| 欧美综合欧美视频| 东方aⅴ免费观看久久av| 视频一区二区三区入口| 亚洲三级理论片| 久久久综合网站| 欧美精品一级二级三级| 成人高清av在线| 国内精品久久久久影院一蜜桃| 亚洲欧美激情小说另类| 日本一二三不卡| 337p粉嫩大胆噜噜噜噜噜91av| 欧美日本国产视频| 欧美午夜一区二区三区| 91在线免费看| 成人av资源下载| 国产精品自拍一区| 激情五月婷婷综合| 日韩av在线播放中文字幕| 亚洲国产va精品久久久不卡综合| 中文字幕视频一区| 国产精品私房写真福利视频| 久久品道一品道久久精品| 日韩一区二区视频| 51精品秘密在线观看| 欧美精品 国产精品| 欧美性感一区二区三区| 色哟哟一区二区三区| 91麻豆免费看片| 99国产精品久久久久久久久久| 成人午夜又粗又硬又大| 国产成人日日夜夜| 国产suv精品一区二区三区| 精品在线一区二区| 精品亚洲国产成人av制服丝袜| 精品无人码麻豆乱码1区2区 | 国产婷婷一区二区| www国产精品av| 2017欧美狠狠色| 久久久.com| 欧美国产日韩在线观看| 国产精品久久久久永久免费观看 | 99精品久久免费看蜜臀剧情介绍| 成人av午夜电影| 99精品国产99久久久久久白柏| www.欧美精品一二区| 91在线精品一区二区| 91久久精品一区二区二区| 在线观看日韩精品| 欧美色综合网站| 日韩欧美一区二区不卡| 精品国产乱码久久久久久夜甘婷婷 | 精品一区二区av| 国产夫妻精品视频| 成人深夜福利app| 色老头久久综合| 欧美欧美欧美欧美| 精品国产三级电影在线观看| 国产午夜精品一区二区三区视频| 日本一区二区成人| 尤物视频一区二区| 青青草97国产精品免费观看无弹窗版| 美女视频黄 久久| 国产成人精品免费视频网站| 91一区二区在线| 欧美一区二区三区在线看| 久久青草欧美一区二区三区| 亚洲视频一区二区免费在线观看| 亚洲国产精品视频| 国内不卡的二区三区中文字幕 | 国产九九视频一区二区三区| 91尤物视频在线观看| 欧美精品久久99久久在免费线 | 欧美精品一区二区三区在线 | 欧美日韩国产中文| 久久久国产一区二区三区四区小说| 亚洲人妖av一区二区| 日韩激情av在线| 成人一级黄色片| 欧美日韩电影在线播放| 国产日产欧美一区二区视频| 一区二区三区美女| 国产精品一区二区果冻传媒| 欧美色综合网站| 中文一区在线播放| 日韩精品高清不卡| av不卡在线观看| 欧美大度的电影原声| 玉米视频成人免费看| 国产伦理精品不卡| 欧美日本一区二区| 国产精品高潮呻吟久久| 久久国产精品99久久久久久老狼| 99re这里只有精品6| 精品美女一区二区三区| 亚洲综合丁香婷婷六月香| 国产成人8x视频一区二区| 51午夜精品国产| 亚洲一区二区在线免费看| 国产激情视频一区二区在线观看| 制服.丝袜.亚洲.中文.综合| ...av二区三区久久精品| 国产一区二三区| 91精品中文字幕一区二区三区| 亚洲欧美另类图片小说| 国产成人综合在线观看| 日韩欧美一二三| 天天亚洲美女在线视频| 91美女片黄在线| 国产精品不卡在线观看| 国产91色综合久久免费分享| 91精品国产综合久久久久久久| 亚洲男人的天堂av| jlzzjlzz国产精品久久| 国产欧美日韩在线观看| 国产一区久久久| 26uuu亚洲综合色欧美| 久久99精品国产.久久久久久| 欧美日本在线视频| 亚洲国产精品久久不卡毛片 | 欧美一区二区久久| 天堂va蜜桃一区二区三区| 欧美综合在线视频| 一区二区三区欧美久久| 92国产精品观看| 亚洲柠檬福利资源导航| 99精品久久99久久久久| 综合色中文字幕| 日本精品裸体写真集在线观看| 中文字幕亚洲精品在线观看| www.一区二区| 亚洲视频在线一区| 91激情五月电影| 亚洲一区在线免费观看| 欧美日韩一级黄| 婷婷丁香激情综合| 日韩午夜在线观看| 精品在线免费视频| 久久只精品国产| 成人h动漫精品一区二区| 国产精品美女久久久久久久网站| 粉嫩蜜臀av国产精品网站| 中文字幕中文字幕中文字幕亚洲无线 | 日韩精品免费视频人成| 日韩一级片网站| 国产伦精品一区二区三区在线观看 | 久久国产精品99久久人人澡| 久久网站最新地址| 成人午夜激情视频| 亚洲精品日韩一| 欧美日韩电影在线播放| 另类小说色综合网站| 久久久91精品国产一区二区精品| 成人精品国产免费网站| 伊人色综合久久天天人手人婷| 欧美日韩在线亚洲一区蜜芽| 日韩福利电影在线| 久久久精品tv| 色偷偷88欧美精品久久久| 亚洲高清不卡在线观看| 日韩精品一区二区三区蜜臀| 国产高清一区日本| 一区av在线播放| 欧美电影免费提供在线观看| 国产成人小视频| 亚洲一区二区黄色| 久久亚洲综合av| 91免费观看在线| 蜜臀a∨国产成人精品| 国产欧美精品一区二区色综合| 一本大道久久a久久综合婷婷| 日韩中文字幕麻豆| 日本一二三四高清不卡| 国产精品国产自产拍在线| 欧美午夜寂寞影院| 久久er99精品| 亚洲综合视频网| 2023国产精品| 欧美色涩在线第一页| 国精产品一区一区三区mba桃花 | 国产不卡免费视频| 午夜成人免费视频| 欧美激情一区二区三区在线| 欧美性猛交xxxx乱大交退制版 | 成人网男人的天堂| 日韩在线一区二区三区| 国产精品剧情在线亚洲| 日韩欧美国产一区二区三区| 91香蕉视频mp4| 国产一区二区三区精品欧美日韩一区二区三区 | 成人av资源在线| 精品一区二区在线视频| 伊人色综合久久天天| 日本一区二区视频在线| 欧美va亚洲va国产综合| 欧美性色aⅴ视频一区日韩精品| 成人av资源网站|