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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? arytst.c

?? create raid tool at linux
?? C
字號:
/* * Array Test * * Regression test utility for raidreconf * (C) 2000, by Jakob Oestergaard * * This software is licensed under the GNU Public License. * * Usage: *     arytst {-w|-r} -l <raid level, {0,1,4,5,20,30}> -c <chunksize (blocks)> -s <array size (blocks)> <dev0> <dev1> ... * A block is 1024 bytes * Array level 20 :  linear * Array level 30 : single disk * * arrays are filled with 64-bit words holding *   [gblock number : 32 bit] *   [origin level : 8 bit] *   [origin disk-chunk : 16 bit] *   [padding : 8 bit] */#define BLOCK_SIZE 1024#include "common.h"#include <popt.h>#include <stdio.h>#include <errno.h>#include <string.h>long array_size = 0;long chunk_size = 0;int array_level = -1;char opt_write = 0, opt_read = 0;char ** args = 0;struct fillword {  unsigned int block_num;  char org_level;  unsigned short org_dchunk;  char padding;};#define GBLK_SIZE 1024#define PADNUM 42void print_fillword(const struct fillword*);void init_fillword(struct fillword*, unsigned gblock, unsigned dchunk);void init_block_buf(char*, unsigned gblock, unsigned dchunk);int check_fillword(const struct fillword*, unsigned gblock, unsigned dchunk);int check_block_buf(const char*, unsigned gblock, unsigned dchunk);static void ary_progress(const char*, unsigned now, unsigned total);static void endary_progress(const char*);int write_single(void);int read_single(void);int write_raid0(void);int read_raid0(void);int main(int argc, const char** argv){    poptContext optCon;  int i;  struct poptOption optionsTable[] = {    {"write", 'w', POPT_ARG_NONE, &opt_write, 0},    {"read", 'r', POPT_ARG_NONE, &opt_read, 0},    {"level", 'l', POPT_ARG_INT, &array_level, 0},    {"chunksize", 'c', POPT_ARG_LONG, &chunk_size, 0},    {"arraysize", 's', POPT_ARG_LONG, &array_size, 0},    {0, 0, 0, 0, 0}   } ;    /*   * Parse options   */  optCon = poptGetContext("arytst", argc, argv, optionsTable, 0);  if ((i = poptGetNextOpt(optCon)) < -1) {    fprintf(stderr, "%s: %s\n", 	    poptBadOption(optCon, POPT_BADOPTION_NOALIAS),	    poptStrerror(i));    return -1;  }  args = (char **)poptGetArgs(optCon);  if(!args) {    fprintf(stderr, "No devices given\n");    return -1;  }  /*    * Make sure mandatory arguments are given   */  if(!opt_read && !opt_write) {    fprintf(stderr, "Must either read or write\n");    return -1;  }  if(opt_read && opt_write) {    fprintf(stderr, "Cannot both read and write\n");    return -1;  }  if(array_level != 0 && array_level != 30) {    fprintf(stderr, "We only know raid level 0 and 30 (single disk) for now\n");    return -1;  }  if(chunk_size <= 0) {    fprintf(stderr, "Chunk size must be specified\n");    return -1;  }  if(array_size <= 0) {    fprintf(stderr, "Array size must be specified\n");    return -1;  }  /*   * Choose action   */  if(opt_write) {    switch(array_level) {    case 0:      return write_raid0();     case 30:      return write_single();    default:      fprintf(stderr, "Unknown level\n");      return -1;    }  }  if(opt_read) {    switch(array_level) {    case 0:      return read_raid0();    case 30:      return read_single();    default:      fprintf(stderr, "Unknown level\n");      return -1;    }  }  return 0;}void print_fillword(const struct fillword* fw){  fprintf(stderr, 	  "block_num   = %u\n"	  "org_level   = %i\n"	  "org_dchunk  = %u\n"	  "padding     = %i\n",	  fw->block_num, fw->org_level,	  fw->org_dchunk, fw->padding);}void init_fillword(struct fillword* fw, unsigned gblock, unsigned dchunk){  fw->block_num = gblock;  fw->org_level = array_level;  fw->org_dchunk = dchunk;  fw->padding = PADNUM;}void init_block_buf(char* buf, unsigned gblock, unsigned dchunk){  int pos;  for(pos = 0; pos != GBLK_SIZE / sizeof(struct fillword); pos++)    init_fillword((struct fillword*)(buf + sizeof(struct fillword) * pos), gblock, dchunk);}int check_fillword(const struct fillword* fw, unsigned gblock, unsigned dchunk){  if(fw->block_num != gblock) {    fprintf(stderr, "\n*** Mismatch at gblock = %u, dchunk = %u\n", gblock, dchunk);    print_fillword(fw);    return 1;  } else if(fw->padding != PADNUM) {    fprintf(stderr, "\n*** Bad padding at gblock = %u, dchunk = %u\n", gblock, dchunk);    print_fillword(fw);    return 1;  }  return 0;}int check_block_buf(const char* buf, unsigned gblock, unsigned dchunk){  int pos;  int rc;  for(pos = 0; pos != GBLK_SIZE / sizeof(struct fillword); pos++)     if((rc = check_fillword((const struct fillword*)(buf + sizeof(struct fillword) * pos), gblock, dchunk)))      return rc;  return 0;}void ary_progress(const char* dev, unsigned now, unsigned total){  fprintf(stderr, "\r%s:  %9u/%-9u  ~%3i%%", dev, now, total, now * 100 / total);  fflush(stderr);}void endary_progress(const char* dev){  fprintf(stderr, "\r%s:  all done.                  \n", dev);}int write_single(void){  FILE * fp = 0;  unsigned blocks;  if(!args[0] || args[1]) {    fprintf(stderr, "Must have precisely one device\n");    return -1;  }  if(!(fp = fopen(args[0], "w"))) {    fprintf(stderr, "Cannot open %s for writing\n", args[0]);    return -1;  }  for(blocks = 0; blocks != array_size; blocks++) {    char buf[GBLK_SIZE];    init_block_buf(buf, blocks, blocks / chunk_size);    fwrite(buf, GBLK_SIZE, 1, fp);    ary_progress(args[0], blocks, array_size);  }  endary_progress(args[0]);  fclose(fp);  return 0;}int read_single(void){  FILE * fp = 0;  unsigned blocks;  if(!args[0] || args[1]) {    fprintf(stderr, "Must have precisely one device\n");    return -1;  }  if(!(fp = fopen(args[0], "r"))) {    fprintf(stderr, "Cannot open %s for writing\n", args[0]);    return -1;  }  for(blocks = 0; blocks != array_size; blocks++) {    char buf[GBLK_SIZE];    int rc;    if(1 != fread(buf, GBLK_SIZE, 1, fp)) {      fprintf(stderr, "\nCannot read\n");      return -1;    }    if((rc = check_block_buf(buf, blocks, blocks / chunk_size)))      return rc;    ary_progress(args[0], blocks, array_size);  }  endary_progress(args[0]);  fclose(fp);  return 0;}int write_raid0(void){  FILE * fp = 0;  unsigned blocks;  char ** cur_dev;  mdp_super_t sb;  int ndisks = 0;  int curdisk = 0;  if(!args[0]) {    fprintf(stderr, "Must have one or more devices\n");    return -1;  }  for(cur_dev = args; *cur_dev; cur_dev++)    ndisks ++;  for(cur_dev = args; *cur_dev; cur_dev++,curdisk++) {    if(!(fp = fopen(*cur_dev, "w"))) {      fprintf(stderr, "Cannot open %s for writing\n", *cur_dev);      return -1;    }        for(blocks = curdisk; blocks-curdisk < array_size; blocks += ndisks) {      char buf[GBLK_SIZE];      init_block_buf(buf, blocks, (blocks-curdisk) / chunk_size);      fwrite(buf, GBLK_SIZE, 1, fp);      ary_progress(*cur_dev, blocks, array_size);    }    endary_progress(*cur_dev);    /* Put a superblock in there too */    if(fseek(fp, 1024 * MD_NEW_SIZE_BLOCKS(array_size/ndisks), SEEK_SET)) {      fprintf(stderr, "Cannot seek to superblock position: %s\n", strerror(errno));      return -1;    } else fprintf(stderr, "Pos: %lu\n", MD_NEW_SIZE_BLOCKS(array_size/ndisks));    memset(&sb, 0, sizeof(sb));    sb.md_magic = MD_SB_MAGIC;    sb.state = (1 << MD_SB_CLEAN);    fwrite(&sb, sizeof(sb), 1, fp);    fclose(fp);  }  return 0;}int read_raid0(void){  FILE * fp = 0;  unsigned blocks;  char ** cur_dev;  int ndisks = 0;  int curdisk = 0;  if(!args[0]) {    fprintf(stderr, "Must have one or more devices\n");    return -1;  }  for(cur_dev = args; *cur_dev; cur_dev++)    ndisks ++;  for(cur_dev = args; *cur_dev; cur_dev++,curdisk++) {    unsigned dblocks_read = 0;    if(!(fp = fopen(*cur_dev, "r"))) {      fprintf(stderr, "Cannot open %s for writing\n", *cur_dev);      return -1;    }        for(blocks = curdisk; blocks-curdisk < array_size; blocks += ndisks) {      char buf[GBLK_SIZE];      int rc;      fread(buf, GBLK_SIZE, 1, fp);      dblocks_read ++;      if(dblocks_read == MD_NEW_SIZE_BLOCKS(array_size/ndisks))	break;      if((rc = check_block_buf(buf, blocks, (blocks-curdisk) / chunk_size)))	return rc;      ary_progress(*cur_dev, blocks, array_size);    }    endary_progress(*cur_dev);    fclose(fp);  }  return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲1区2区3区视频| 偷拍一区二区三区四区| 亚洲黄色免费电影| 蜜臀av亚洲一区中文字幕| 国产91精品一区二区麻豆网站| 色老头久久综合| www国产成人| 亚州成人在线电影| 欧美一区二区成人| 中文字幕一区二区三区四区不卡 | 国产精品久久久久久久久图文区| 亚洲精品成人在线| 国产成人免费在线| 欧美成va人片在线观看| 性做久久久久久| 欧美午夜电影网| 亚洲美腿欧美偷拍| 99久久久国产精品| 亚洲国产成人在线| 国产高清精品久久久久| 日韩欧美123| 蜜桃91丨九色丨蝌蚪91桃色| 欧美日韩情趣电影| 亚洲sss视频在线视频| 暴力调教一区二区三区| 国产色91在线| 国产麻豆精品视频| 久久精品欧美一区二区三区不卡 | 欧美日韩二区三区| 亚洲最新在线观看| 91国产免费看| 亚洲主播在线观看| 欧美视频在线观看一区| 亚洲综合色网站| 欧美日韩视频在线第一区 | 欧美一二三四在线| 日韩精品久久久久久| 国产精品影音先锋| 久久er99精品| 日韩高清在线电影| 黄色日韩网站视频| 成人v精品蜜桃久久一区| 色综合色综合色综合色综合色综合| 91视视频在线观看入口直接观看www | 精品一区二区免费视频| 91影视在线播放| 亚洲天堂成人网| 91成人免费在线视频| 亚洲国产成人av| 18欧美亚洲精品| 亚洲精品一区二区三区影院| 三级影片在线观看欧美日韩一区二区| 欧美高清视频一二三区 | 欧美日韩在线播| 五月天激情综合| 精品国产免费人成电影在线观看四季| 国产在线精品一区二区| 中文字幕欧美日本乱码一线二线| 成人18视频日本| 亚洲成人av电影| 2022国产精品视频| 99久久伊人网影院| 亚洲成av人**亚洲成av**| 精品卡一卡二卡三卡四在线| 97精品国产97久久久久久久久久久久| 一区二区三区日韩精品视频| 日韩一级欧美一级| 成人免费毛片aaaaa**| 亚洲自拍偷拍九九九| 久久久噜噜噜久久人人看 | 久久精品国产成人一区二区三区| 精品捆绑美女sm三区| 91麻豆文化传媒在线观看| 美国十次了思思久久精品导航| 欧美高清一级片在线观看| 欧美日本免费一区二区三区| 国产一区二区在线视频| 亚洲精品v日韩精品| 精品国一区二区三区| 91丝袜美腿高跟国产极品老师| 日本欧美肥老太交大片| 成人免费视频在线观看| 欧美电影精品一区二区| 色综合天天狠狠| 国产呦精品一区二区三区网站| 亚洲欧美一区二区三区极速播放| 日韩视频在线永久播放| 99久久免费精品高清特色大片| 麻豆精品精品国产自在97香蕉| 中文字幕字幕中文在线中不卡视频| 欧美一区二区三区人| 国产精品天天看| 欧美日韩一区二区三区不卡| 欧美国产精品一区| 精品一区二区免费视频| 亚洲视频在线一区| 久久只精品国产| 91精品国产高清一区二区三区蜜臀| 99亚偷拍自图区亚洲| 国产综合色在线视频区| 日本免费在线视频不卡一不卡二| 一区二区三区欧美日韩| 中文字幕乱码日本亚洲一区二区| 精品国一区二区三区| 日韩欧美一级在线播放| 91精品国产欧美一区二区| 欧美日韩免费不卡视频一区二区三区| 成人动漫在线一区| 国产一区亚洲一区| 九色综合国产一区二区三区| 美腿丝袜亚洲一区| 久久精品国产一区二区| 麻豆精品在线观看| 另类小说图片综合网| 精品视频免费在线| 裸体一区二区三区| 亚洲乱码中文字幕综合| 亚洲视频一区二区在线| 亚洲伦理在线精品| 亚洲国产精品久久人人爱| 亚洲成人三级小说| 日本伊人色综合网| 久久国产精品99久久人人澡| 久久国产生活片100| 国产曰批免费观看久久久| 国产剧情一区在线| 成人a级免费电影| 色噜噜狠狠成人网p站| 欧美福利电影网| 精品噜噜噜噜久久久久久久久试看| 精品成人一区二区| 国产亚洲视频系列| 亚洲日本韩国一区| 亚洲不卡在线观看| 国产综合久久久久久久久久久久 | 精品一区二区在线视频| 国产麻豆成人精品| 91猫先生在线| 欧美一区2区视频在线观看| 久久精品一区蜜桃臀影院| 国产精品久久久久aaaa樱花| 亚洲综合偷拍欧美一区色| 日本欧美一区二区三区乱码| 国产成人午夜99999| 在线国产亚洲欧美| 91精品国产综合久久精品图片| 精品毛片乱码1区2区3区| 国产精品传媒在线| 日韩国产欧美在线播放| 国产精品一区三区| 91成人在线免费观看| 精品福利在线导航| 亚洲精品网站在线观看| 麻豆91精品91久久久的内涵| 99精品偷自拍| 精品国产乱码久久久久久久| 亚洲精品国产a久久久久久| 蓝色福利精品导航| 91在线免费播放| 久久久综合视频| 亚洲国产日韩精品| 成人黄色在线看| 欧美不卡视频一区| 一区二区在线免费| 国产精品一区2区| 欧美精品在欧美一区二区少妇| 国产精品拍天天在线| 日韩va亚洲va欧美va久久| 91视频com| 国产日韩欧美高清在线| 免费一级欧美片在线观看| 色婷婷精品久久二区二区蜜臀av| 精品裸体舞一区二区三区| 亚洲bt欧美bt精品777| 不卡av电影在线播放| 精品av久久707| 日本女优在线视频一区二区| 欧美午夜精品理论片a级按摩| 国产欧美日韩另类视频免费观看 | 99久久综合国产精品| 亚洲精品一区二区三区影院| 爽好多水快深点欧美视频| 91美女在线视频| 国产精品麻豆一区二区| 国产精品亚洲成人| 精品国产三级a在线观看| 日韩av成人高清| 欧美日韩美少妇| 亚洲国产美国国产综合一区二区| 色综合天天综合狠狠| 中国色在线观看另类| 国产精品18久久久久久久网站| 日韩精品在线一区二区| 蜜桃av噜噜一区| 精品免费99久久| 精品一区二区三区免费观看| 日韩三区在线观看| 激情久久五月天| 久久久久国色av免费看影院| 国模冰冰炮一区二区|