disksim_redun.c

来自「disksim是一个非常优秀的磁盘仿真工具」· C语言 代码 · 共 1,296 行 · 第 1/3 页

C
1,296
字号
/* * DiskSim Storage Subsystem Simulation Environment (Version 4.0) * Revision Authors: John Bucy, Greg Ganger * Contributors: John Griffin, Jiri Schindler, Steve Schlosser * * Copyright (c) of Carnegie Mellon University, 2001-2008. * * This software is being provided by the copyright holders under the * following license. By obtaining, using and/or copying this software, * you agree that you have read, understood, and will comply with the * following terms and conditions: * * Permission to reproduce, use, and prepare derivative works of this * software is granted provided the copyright and "No Warranty" statements * are included with all reproductions and derivative works and associated * documentation. This software may also be redistributed without charge * provided that the copyright and "No Warranty" statements are included * in all redistributions. * * NO WARRANTY. THIS SOFTWARE IS FURNISHED ON AN "AS IS" BASIS. * CARNEGIE MELLON UNIVERSITY MAKES NO WARRANTIES OF ANY KIND, EITHER * EXPRESSED OR IMPLIED AS TO THE MATTER INCLUDING, BUT NOT LIMITED * TO: WARRANTY OF FITNESS FOR PURPOSE OR MERCHANTABILITY, EXCLUSIVITY * OF RESULTS OR RESULTS OBTAINED FROM USE OF THIS SOFTWARE. CARNEGIE * MELLON UNIVERSITY DOES NOT MAKE ANY WARRANTY OF ANY KIND WITH RESPECT * TO FREEDOM FROM PATENT, TRADEMARK, OR COPYRIGHT INFRINGEMENT. * COPYRIGHT HOLDERS WILL BEAR NO LIABILITY FOR ANY USE OF THIS SOFTWARE * OR DOCUMENTATION. * *//* * DiskSim Storage Subsystem Simulation Environment (Version 2.0) * Revision Authors: Greg Ganger * Contributors: Ross Cohen, John Griffin, Steve Schlosser * * Copyright (c) of Carnegie Mellon University, 1999. * * Permission to reproduce, use, and prepare derivative works of * this software for internal use is granted provided the copyright * and "No Warranty" statements are included with all reproductions * and derivative works. This software may also be redistributed * without charge provided that the copyright and "No Warranty" * statements are included in all redistributions. * * NO WARRANTY. THIS SOFTWARE IS FURNISHED ON AN "AS IS" BASIS. * CARNEGIE MELLON UNIVERSITY MAKES NO WARRANTIES OF ANY KIND, EITHER * EXPRESSED OR IMPLIED AS TO THE MATTER INCLUDING, BUT NOT LIMITED * TO: WARRANTY OF FITNESS FOR PURPOSE OR MERCHANTABILITY, EXCLUSIVITY * OF RESULTS OR RESULTS OBTAINED FROM USE OF THIS SOFTWARE. CARNEGIE * MELLON UNIVERSITY DOES NOT MAKE ANY WARRANTY OF ANY KIND WITH RESPECT * TO FREEDOM FROM PATENT, TRADEMARK, OR COPYRIGHT INFRINGEMENT. *//* * DiskSim Storage Subsystem Simulation Environment * Authors: Greg Ganger, Bruce Worthington, Yale Patt * * Copyright (C) 1993, 1995, 1997 The Regents of the University of Michigan  * * This software is being provided by the copyright holders under the * following license. By obtaining, using and/or copying this software, * you agree that you have read, understood, and will comply with the * following terms and conditions: * * Permission to use, copy, modify, distribute, and sell this software * and its documentation for any purpose and without fee or royalty is * hereby granted, provided that the full text of this NOTICE appears on * ALL copies of the software and documentation or portions thereof, * including modifications, that you make. * * THIS SOFTWARE IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKE NO * REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED. BY WAY OF EXAMPLE, * BUT NOT LIMITATION, COPYRIGHT HOLDERS MAKE NO REPRESENTATIONS OR * WARRANTIES OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR * THAT THE USE OF THE SOFTWARE OR DOCUMENTATION WILL NOT INFRINGE ANY * THIRD PARTY PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS. COPYRIGHT * HOLDERS WILL BEAR NO LIABILITY FOR ANY USE OF THIS SOFTWARE OR * DOCUMENTATION. * *  This software is provided AS IS, WITHOUT REPRESENTATION FROM THE * UNIVERSITY OF MICHIGAN AS TO ITS FITNESS FOR ANY PURPOSE, AND * WITHOUT WARRANTY BY THE UNIVERSITY OF MICHIGAN OF ANY KIND, EITHER * EXPRESSED OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE REGENTS * OF THE UNIVERSITY OF MICHIGAN SHALL NOT BE LIABLE FOR ANY DAMAGES, * INCLUDING SPECIAL , INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, * WITH RESPECT TO ANY CLAIM ARISING OUT OF OR IN CONNECTION WITH THE * USE OF OR IN CONNECTION WITH THE USE OF THE SOFTWARE, EVEN IF IT HAS * BEEN OR IS HEREAFTER ADVISED OF THE POSSIBILITY OF SUCH DAMAGES * * The names and trademarks of copyright holders or authors may NOT be * used in advertising or publicity pertaining to the software without * specific, written prior permission. Title to copyright in this software * and any associated documentation will at all times remain with copyright * holders. */#include "disksim_global.h"#include "disksim_stat.h"#include "disksim_iosim.h"#include "disksim_orgface.h"#include "disksim_logorg.h"#include "disksim_ioqueue.h"static int logorg_modulus_update (int inc, int val, int maxval){   int ret;   ret = val + inc;   if (ret < 0) {      ret += maxval;   } else if (ret >= maxval) {      ret -= maxval;   }   return(ret);}int logorg_tabular_rottype (int maptype, int reduntype, int rottype, int stripeunit){   if (reduntype != PARITY_ROTATED) {      return(FALSE);   }   if (maptype != STRIPED) {      return(FALSE);   }   if (stripeunit == 0) {      return(FALSE);   }   switch (rottype) {      case PARITY_LEFT_SYM:      case PARITY_LEFT_ASYM:      case PARITY_RIGHT_SYM:      case PARITY_RIGHT_ASYM:      return(TRUE);   }   return(FALSE);}static void logorg_parity_rotate_ideal (logorg *currlogorg, ioreq_event *curr){   if (curr->flags & READ) {      return;   }   curr->next = ioreq_copy(curr);   curr->next->devno = currlogorg->idealno;   currlogorg->idealno = (currlogorg->idealno + 1) % currlogorg->numdisks;}static void logorg_parity_rotate_random (logorg *currlogorg, ioreq_event *curr){   if (curr->flags & READ) {      return;   }   curr->next = ioreq_copy(curr);   while (curr->next->devno == curr->devno) {      curr->next->devno = (int)((double)currlogorg->numdisks * DISKSIM_drand48());   }}static int logorg_shadowed_get_short_dist (logorg *currlogorg, ioreq_event *curr, int numtocheck, int *checklist){   int i, j;   int dist;   int shortdev = -1;   int shortdist = 999999999;   int ties[MAXCOPIES];   int no;   j = -1;   for (i = 0; i < numtocheck; i++) {      no = checklist[i];      dist = ioqueue_get_dist(currlogorg->devs[(curr->devno + (no * currlogorg->numdisks))].queue, (curr->blkno + currlogorg->devs[(curr->devno + (no * currlogorg->numdisks))].startblkno));      if (dist >= 999999999) {	 fprintf(stderr, "Haven't allowed for large enough 'dist's in logorg_shadowed_get_short_dist - %d\n", dist);	 exit(1);      }      if (dist == shortdist) {	 j++;	 if (j >= MAXCOPIES) {	    fprintf(stderr, "Haven't allowed for enough ties in logorg_shadowed_get_short_dist - %d\n", j);	    exit(1);	 }	 ties[j] = no;      }      if (dist < shortdist) {	 shortdist = dist;	 shortdev = no;	 j = -1;      }   }   if (shortdev == -1) {      fprintf(stderr, "Illegal condition in logorg_shadowed_get_short_dist\n");      exit(1);   } else if (j != -1) {      i = (int) (DISKSIM_drand48() * (double) (j+2));      if (i != 0) {	 shortdev = ties[(i-1)];      }   }   return(shortdev);}static int logorg_shadowed_get_short_queue (logorg *currlogorg, ioreq_event *curr, int def){   int i, j;   int len;   int shortdev = -1;   int shortlen = 999999999;   int ties[MAXCOPIES];   j = -1;   for (i = 0; i < currlogorg->copies; i++) {      len = ioqueue_get_number_in_queue(currlogorg->devs[(curr->devno + (i * currlogorg->numdisks))].queue);      if (len >= 999999999) {	 fprintf(stderr, "Haven't allowed for large enough 'dist's in logorg_shadowed_get_short_queue - %d\n", len);	 exit(1);      }      if (len == shortlen) {	 j++;	 if (j >= MAXCOPIES) {	    fprintf(stderr, "Haven't allowed for enough ties in logorg_shadowed_get_short_queue - %d\n", j);	    exit(1);	 }	 ties[j] = i;      }      if (len < shortlen) {	 shortlen = len;	 shortdev = i;	 j = -1;      }   }   if (shortdev == -1) {      fprintf(stderr, "Illegal condition in logorg_shadowed_get_short_queue\n");      exit(1);   } else if (j != -1) {      if (def == 1) {         i = (int) (DISKSIM_drand48() * (double) (j+2));         if (i != 0) {	    shortdev = ties[(i-1)];         }      } else if (def == 2) {	 j++;	 ties[j] = shortdev;	 shortdev = logorg_shadowed_get_short_dist(currlogorg, curr, (j+1), ties);      } else {	 fprintf(stderr, "Unknown default tie breaker in logorg_shadowed_get_short_queue - %d\n", def);	 exit(1);      }   }   return(shortdev);}int logorg_shadowed (logorg *currlogorg, ioreq_event *curr, int numreqs){   int i, j;   ioreq_event *temp;   ioreq_event *newreq;   int checklist[MAXCOPIES];   temp = curr;   if (curr->flags & READ) {      for (i = 0; i < numreqs; i++) {	 switch (currlogorg->copychoice) {	    case SHADOW_PRIMARY:/* May want to move head on secondary device */			  break;	    case SHADOW_RANDOM:			  temp->devno += currlogorg->numdisks * (int) (DISKSIM_drand48() * (double) currlogorg->copies);			  break;	    case SHADOW_ROUNDROBIN:			  temp->devno += currlogorg->numdisks * currlogorg->reduntoggle;			  currlogorg->reduntoggle++;			  currlogorg->reduntoggle %= currlogorg->copies;			  break;	    case SHADOW_SHORTDIST:			  for (j = 0; j < currlogorg->copies; j++)			     checklist[j] = j;			  temp->devno += currlogorg->numdisks * logorg_shadowed_get_short_dist(currlogorg, temp, currlogorg->copies, checklist);			  break;	    case SHADOW_SHORTQUEUE:			  temp->devno += currlogorg->numdisks * logorg_shadowed_get_short_queue(currlogorg, temp, 1);			  break;	    case SHADOW_SHORTQUEUE2:			  temp->devno += currlogorg->numdisks * logorg_shadowed_get_short_queue(currlogorg, temp, 2);			  break;	    default:		    fprintf(stderr, "Unknown shadow choice type at logorg_shadowed\n");		    exit(1);	 }	 temp = temp->next;      }      return(numreqs);   } else {      for (i = 0; i < numreqs; i++) {         for (j = 1; j < currlogorg->copies; j++) {            newreq = ioreq_copy(temp);            temp->next = newreq;            newreq->devno += currlogorg->numdisks;            temp = newreq;         }	 temp = temp->next;      }      return(currlogorg->copies * numreqs);   }}int logorg_parity_disk (logorg *currlogorg, ioreq_event *curr, int numreqs){   depends *depend;   if (curr->flags & READ) {      return(numreqs);   }   if ((currlogorg->maptype == STRIPED) && (currlogorg->stripeunit == 0)) {      curr->next = ioreq_copy(curr);      curr->next->devno = currlogorg->numdisks;      return(numreqs+1);   }   if (numreqs != 1) {      fprintf(stderr, "Too many reqs at logorg_parity_disk - %d\n", numreqs);      exit(1);   }   depend = (depends *) getfromextraq();   depend->blkno = curr->blkno;   depend->devno = curr->devno;   depend->numdeps = 2;   depend->deps[0] = ioreq_copy(curr);   depend->deps[1] = ioreq_copy(curr);   depend->deps[0]->opid = 2;   depend->deps[0]->devno = currlogorg->numdisks;   depend->next = (depends *) getfromextraq();   depend->next->next = NULL;   depend->next->blkno = curr->blkno;   depend->next->devno = currlogorg->numdisks;   depend->next->deps[0] = depend->deps[0];   depend->next->deps[1] = depend->deps[1];   if (currlogorg->writesync == TRUE) {      depend->deps[1]->opid = 2;      depend->next->numdeps = 2;   } else {      depend->deps[1]->opid = 1;      depend->next->numdeps = 1;   }   curr->flags |= READ;   curr->next = ioreq_copy(curr);   curr->next->devno = currlogorg->numdisks;   curr->prev = (ioreq_event *) depend;   return(4);}static int logorg_parity_rotate_updates (logorg *currlogorg, ioreq_event *curr, int inc){   int reqs = 2;   int parityno;   int blksleft;   int bcount;   ioreq_event *newreq;   int parityunit;   int numdisks;   int devno;   int parityblock;   parityunit = currlogorg->parityunit;   numdisks = currlogorg->numdisks;   parityblock = curr->blkno / (parityunit * (numdisks - 1));   parityno = (curr->blkno % (parityunit * (numdisks - 1))) / parityunit;   curr->blkno += parityblock * parityunit;   if (inc == -1) {      devno = numdisks - (parityno % numdisks) - 1;   } else {      devno = parityno % numdisks;   }   if (((inc == 1) && (curr->devno <= devno)) || ((inc == -1) && (curr->devno >=devno))) {      curr->blkno += parityunit;      devno = logorg_modulus_update(inc, devno, numdisks);      parityno++;   }   blksleft = parityunit - (curr->blkno % currlogorg->parityunit);   bcount = curr->bcount;   if ((parityunit != currlogorg->parityunit) && ((bcount > blksleft) || (parityunit > currlogorg->parityunit))) {      fprintf(stderr, "Failed integrity check in logorg_parity_rotate_left\n");      exit(1);   }   while (bcount > blksleft) {      if (!(curr->flags & READ)) {         newreq = ioreq_copy(curr);         newreq->devno = devno;         newreq->bcount = blksleft;         newreq->blkno = curr->blkno + curr->bcount - bcount;         newreq->next = curr->next;         curr->next = newreq;         reqs++;      }      bcount -= blksleft;      devno = logorg_modulus_update(inc, devno, numdisks);      if (devno == curr->devno) {	 curr->bcount += parityunit;         devno = logorg_modulus_update(inc, devno, numdisks);	 parityno++;      }      parityno++;      blksleft = parityunit;   }   if (curr->flags & READ) {      return(1);   }   newreq = ioreq_copy(curr);   newreq->devno = devno;   newreq->blkno = curr->blkno + curr->bcount - bcount;   newreq->bcount = bcount;   newreq->next = curr->next;   curr->next = newreq;   if (parityno > currlogorg->numfull) {      fprintf(stderr, "Integrity check failure in logorg_parity_rotate_left\n");      exit(1);   }   return(reqs);}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?