1 Star 2 Fork 1

ZhouHeyu/Mix-SSD

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
disksim_iosim.c 24.50 KB
一键复制 编辑 原始数据 按行查看 历史
颜明博 提交于 2018-06-25 19:31 . first commit
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808
/*
* DiskSim Storage Subsystem Simulation Environment (Version 3.0)
* Revision Authors: John Bucy, Greg Ganger
* Contributors: John Griffin, Jiri Schindler, Steve Schlosser
*
* Copyright (c) of Carnegie Mellon University, 2001, 2002, 2003.
*
* 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_ioface.h"
#include "disksim_orgface.h"
#include "disksim_iosim.h"
#include "disksim_iotrace.h"
#include "disksim_stat.h"
#include "disksim_iodriver.h"
#include "disksim_bus.h"
#include "disksim_controller.h"
#include "config.h"
#include "modules/disksim_iosim_param.h"
#include "modules/disksim_iomap_param.h"
#define TRACEMAPPINGS MAXDEVICES
#define PRINTTRACESTATS TRUE
/* read-only globals used during readparams phase */
static char *statdesc_tracequeuestats = "Trace queue time";
static char *statdesc_tracerespstats = "Trace response time";
static char *statdesc_traceaccstats = "Trace access time";
static char *statdesc_traceqlenstats = "Trace queue length";
static char *statdesc_tracenoqstats = "Trace non-queue time";
static char *statdesc_traceaccdiffstats = "Trace access diff time";
static char *statdesc_traceaccwritestats = "Trace write access time";
static char *statdesc_traceaccdiffwritestats = "Trace write access diff time";
typedef struct iosim_info {
event * io_extq;
int io_extqlen;
int io_extq_type;
double ioscale;
double last_request_arrive;
double constintarrtime;
int validatebuf[10];
int tracemappings;
int tracemap[TRACEMAPPINGS];
int tracemap1[TRACEMAPPINGS];
int tracemap2[TRACEMAPPINGS];
int tracemap3[TRACEMAPPINGS];
int tracemap4[TRACEMAPPINGS];
statgen *tracestats;
statgen *tracestats1;
statgen *tracestats2;
statgen *tracestats3;
statgen *tracestats4;
statgen *tracestats5;
} iosim_info_t;
/* one remapping #define for each variable in iosim_info_t */
#define io_extq (disksim->iosim_info->io_extq)
#define io_extqlen (disksim->iosim_info->io_extqlen)
#define io_extq_type (disksim->iosim_info->io_extq_type)
#define ioscale (disksim->iosim_info->ioscale)
#define last_request_arrive (disksim->iosim_info->last_request_arrive)
#define constintarrtime (disksim->iosim_info->constintarrtime)
#define validatebuf (disksim->iosim_info->validatebuf)
#define tracemappings (disksim->iosim_info->tracemappings)
#define tracemap (disksim->iosim_info->tracemap)
#define tracemap1 (disksim->iosim_info->tracemap1)
#define tracemap2 (disksim->iosim_info->tracemap2)
#define tracemap3 (disksim->iosim_info->tracemap3)
#define tracemap4 (disksim->iosim_info->tracemap4)
#define tracestats (disksim->iosim_info->tracestats)
#define tracestats1 (disksim->iosim_info->tracestats1)
#define tracestats2 (disksim->iosim_info->tracestats2)
#define tracestats3 (disksim->iosim_info->tracestats3)
#define tracestats4 (disksim->iosim_info->tracestats4)
#define tracestats5 (disksim->iosim_info->tracestats5)
void iosim_initialize_iosim_info ()
{
disksim->iosim_info = DISKSIM_malloc (sizeof(iosim_info_t));
bzero ((char *)disksim->iosim_info, sizeof(iosim_info_t));
/* initializations that get remapped into iosim_info */
ioscale = 1.0;
last_request_arrive = 0.0;
constintarrtime = 0.0;
}
ioreq_event * ioreq_copy (ioreq_event *old)
{
ioreq_event *new = (ioreq_event *) getfromextraq();
memmove ((char *)new, (char *)old, sizeof(ioreq_event));
/* bcopy ((char *)old, (char *)new, sizeof (ioreq_event)); */
return(new);
}
int ioreq_compare (ioreq_event *first, ioreq_event *second)
{
int diff = 0;
diff |= first->time != second->time;
diff |= first->type != second->type;
//diff |= first->next != second->next;
//diff |= first->prev != second->prev;
diff |= first->bcount != second->bcount;
diff |= first->blkno != second->blkno;
diff |= first->flags != second->flags;
diff |= first->busno != second->busno;
diff |= first->slotno != second->slotno;
diff |= first->devno != second->devno;
diff |= first->opid != second->opid;
diff |= first->buf != second->buf;
diff |= first->cause != second->cause;
diff |= first->tempint1 != second->tempint1;
diff |= first->tempint2 != second->tempint2;
diff |= first->tempptr1 != second->tempptr1;
diff |= first->tempptr2 != second->tempptr2;
return(diff);
}
void io_catch_stray_events (ioreq_event *curr)
{
switch (curr->type) {
case DEVICE_DATA_TRANSFER_COMPLETE:
curr->time = device_get_blktranstime(curr);
curr->time = simtime + (curr->time * (double) curr->bcount);
addtointq((event *) curr);
break;
default:
fprintf(stderr, "Unknown event type at io_catch_stray_events\n");
exit(1);
}
}
event * io_request (ioreq_event *curr)
{
curr->type = IO_REQUEST_ARRIVE;
return (iodriver_request(0, curr));
}
void io_schedule (ioreq_event *curr)
{
curr->type = IO_ACCESS_ARRIVE;
iodriver_schedule(0, curr);
}
double io_tick()
{
return (iodriver_tick());
}
double io_raise_priority (int opid, int devno, int blkno, void *chan)
{
return (iodriver_raise_priority(0, opid, devno, blkno, chan));
}
void io_interrupt_arrive (ioreq_event *intrp)
{
intrp->type = IO_INTERRUPT_ARRIVE;
iodriver_interrupt_arrive (0, (intr_event *)intrp);
}
void io_interrupt_complete (ioreq_event *intrp)
{
intrp->type = IO_INTERRUPT_COMPLETE;
iodriver_interrupt_complete (0, (intr_event *)intrp);
}
void io_internal_event(ioreq_event *curr)
{
ASSERT(curr != NULL);
/*
fprintf (outputfile, "%f: io_internal_event entered with event type %d, %f\n", curr->time, curr->type, simtime);
*/
switch (curr->type) {
case IO_REQUEST_ARRIVE:
iodriver_request(0, curr);
break;
case IO_ACCESS_ARRIVE:
iodriver_schedule(0, curr);
break;
case IO_INTERRUPT_ARRIVE:
iodriver_interrupt_arrive(0, (intr_event *) curr);
break;
case IO_RESPOND_TO_DEVICE:
iodriver_respond_to_device(0, (intr_event *) curr->tempptr1);
addtoextraq((event *) curr);
break;
case IO_ACCESS_COMPLETE:
iodriver_access_complete(0, (intr_event *) curr->tempptr1);
addtoextraq((event *) curr);
break;
case IO_INTERRUPT_COMPLETE:
iodriver_interrupt_complete(0, (intr_event *) curr);
break;
case DEVICE_OVERHEAD_COMPLETE:
case DEVICE_ACCESS_COMPLETE:
case DEVICE_DATA_TRANSFER_COMPLETE:
case DEVICE_PREPARE_FOR_DATA_TRANSFER:
case DEVICE_BUFFER_SEEKDONE:
case DEVICE_BUFFER_TRACKACC_DONE:
case DEVICE_BUFFER_SECTOR_DONE:
case DEVICE_GOT_REMAPPED_SECTOR:
case DEVICE_GOTO_REMAPPED_SECTOR:
case MEMS_SLED_SCHEDULE:
case MEMS_SLED_SEEK:
case MEMS_SLED_SERVO:
case MEMS_SLED_DATA:
case MEMS_SLED_UPDATE:
case MEMS_BUS_INITIATE:
case MEMS_BUS_TRANSFER:
case MEMS_BUS_UPDATE:
device_event_arrive(curr);
break;
case BUS_OWNERSHIP_GRANTED:
case BUS_DELAY_COMPLETE:
bus_event_arrive(curr);
break;
case CONTROLLER_DATA_TRANSFER_COMPLETE:
controller_event_arrive(curr->tempint2, curr);
break;
case TIMESTAMP_LOGORG:
logorg_timestamp(curr);
break;
case IO_TRACE_REQUEST_START:
iodriver_trace_request_start(0, curr);
break;
default:
fprintf(stderr, "Unknown event type passed to io_internal_events\n");
exit(1);
}
/*
fprintf (outputfile, "Leaving io_internal_event\n");
*/
}
void iosim_get_path_to_controller (int iodriverno, int ctlno, intchar *buspath, intchar *slotpath)
{
int depth;
int currbus;
char inslotno;
char outslotno;
int master;
depth = controller_get_depth(ctlno);
currbus = controller_get_inbus(ctlno);
inslotno = (char) controller_get_slotno(ctlno);
master = controller_get_bus_master(currbus);
while (depth > 0) {
/*
fprintf (outputfile, "ctlno %d, depth %d, currbus %d, inslotno %d, master %d\n", ctl->ctlno, depth, currbus, inslotno, master);
*/
outslotno = (char) controller_get_outslot(master, currbus);
buspath->byte[depth] = (char) currbus;
slotpath->byte[depth] = (inslotno & 0x0F) | (outslotno << 4);
depth--;
currbus = controller_get_inbus(master);
inslotno = (char) controller_get_slotno(master);
master = controller_get_bus_master(currbus);
/* Bus must have at least one controller */
ASSERT1((master != -1) || (depth <= 0), "currbus", currbus);
}
outslotno = (char) iodriverno;
buspath->byte[depth] = currbus;
slotpath->byte[depth] = (inslotno & 0x0F) | (outslotno << 4);
}
void iosim_get_path_to_device (int iodriverno, int devno, intchar *buspath, intchar *slotpath)
{
int depth;
int currbus;
char inslotno;
char outslotno;
int master;
depth = device_get_depth(devno);
currbus = device_get_inbus(devno);
inslotno = (char) device_get_slotno(devno);
master = controller_get_bus_master(currbus);
while (depth > 0) {
/*
fprintf (outputfile, "devno %d, depth %d, currbus %d, inslotno %d, master %d\n", devno, depth, currbus, inslotno, master);
*/
outslotno = (char) controller_get_outslot(master, currbus);
buspath->byte[depth] = (char) currbus;
slotpath->byte[depth] = (inslotno & 0x0F) | (outslotno << 4);
depth--;
currbus = controller_get_inbus(master);
inslotno = (char) controller_get_slotno(master);
master = controller_get_bus_master(currbus);
/* Bus must have at least one controller */
ASSERT1((master != -1) || (depth <= 0), "currbus", currbus);
}
outslotno = (char) iodriverno;
buspath->byte[depth] = currbus;
slotpath->byte[depth] = (inslotno & 0x0F) | (outslotno << 4);
}
static int iosim_load_map(struct lp_block *b, int n) {
int c;
int i = 0;
char *s = 0;
#include "modules/disksim_iomap_param.c"
if (tracemap2[n] == 512) {
tracemap2[n] = 0;
}
else if (tracemap2[n] > 512) {
tracemap2[n] = -(tracemap2[n] / 512);
}
else {
tracemap2[n] = 512 / tracemap2[n];
}
return 1;
}
static int iosim_load_mappings(struct lp_list *l) {
int c;
int mapno = 0;
if(l->values_len > TRACEMAPPINGS) {
fprintf(stderr, "*** error: too many io mappings.\n");
return -1;
}
for(c = 0; c < l->values_len; c++) {
if(!l->values[c]) continue;
if(l->values[c]->t == BLOCK) {
assert(iosim_load_map(l->values[c]->v.b, mapno));
tracemappings++;
}
mapno++;
}
return 1;
}
int disksim_iomap_loadparams(struct lp_block *b) {
ddbg_assert2(0, "this is a dummy and isn't supposed to be called");
return 0;
}
int disksim_iosim_loadparams(struct lp_block *b) {
if(!disksim->iosim_info)
iosim_initialize_iosim_info();
#include "modules/disksim_iosim_param.c"
return 1;
}
/* OBSELETE */
void io_readparams (FILE *parfile)
{
ddbg_assert(0);
/* fscanf(parfile, "\nI/O Subsystem Input Parameters\n"); */
/* fprintf(outputfile, "\nI/O Subsystem Input Parameters\n"); */
/* fscanf(parfile, "------------------------------\n"); */
/* fprintf(outputfile, "------------------------------\n"); */
/* fscanf(parfile, "\nPRINTED I/O SUBSYSTEM STATISTICS\n\n"); */
/* fprintf(outputfile, "\nPRINTED I/O SUBSYSTEM STATISTICS\n\n"); */
/* iodriver_read_toprints(parfile); */
/* bus_read_toprints(parfile); */
/* controller_read_toprints(parfile); */
/* device_read_toprints(parfile); */
/* fscanf(parfile, "\nGENERAL I/O SUBSYSTEM PARAMETERS\n\n"); */
/* fprintf(outputfile, "\nGENERAL I/O SUBSYSTEM PARAMETERS\n\n"); */
/* io_read_generalparms(parfile); */
/* fscanf(parfile, "\nCOMPONENT SPECIFICATIONS\n"); */
/* fprintf(outputfile, "\nCOMPONENT SPECIFICATIONS\n"); */
/* iodriver_read_specs(parfile); */
/* bus_read_specs(parfile); */
/* controller_read_specs(parfile); */
/* device_read_specs(parfile); */
/* fscanf(parfile, "\nPHYSICAL ORGANIZATION\n"); */
/* fprintf(outputfile, "\nPHYSICAL ORGANIZATION\n"); */
/* iodriver_read_physorg(parfile); */
/* controller_read_physorg(parfile); */
/* bus_read_physorg(parfile); */
/* fscanf(parfile, "\nSYNCHRONIZATION\n"); */
/* fprintf(outputfile, "\nSYNCHRONIZATION\n"); */
/* device_read_syncsets(parfile); */
/* fscanf(parfile, "\nLOGICAL ORGANIZATION\n"); */
/* fprintf(outputfile, "\nLOGICAL ORGANIZATION\n"); */
/* iodriver_read_logorg(parfile); */
/* controller_read_logorg(parfile); */
/*
bus_print_phys_config();
*/
}
void io_validate_do_stats1 ()
{
int i;
if (tracestats2 == NULL) {
tracestats2 = (statgen *)DISKSIM_malloc(sizeof(statgen));
tracestats3 = (statgen *)DISKSIM_malloc(sizeof(statgen));
tracestats4 = (statgen *)DISKSIM_malloc(sizeof(statgen));
tracestats5 = (statgen *)DISKSIM_malloc(sizeof(statgen));
stat_initialize(statdeffile, statdesc_traceaccstats, tracestats2);
stat_initialize(statdeffile, statdesc_traceaccdiffstats, tracestats3);
stat_initialize(statdeffile, statdesc_traceaccwritestats, tracestats4);
stat_initialize(statdeffile, statdesc_traceaccdiffwritestats, tracestats5);
for (i=0; i<10; i++) {
validatebuf[i] = 0;
}
} else {
stat_update(tracestats3, (validate_lastserv - disksim->lastphystime));
if (!validate_lastread) {
stat_update(tracestats5, (validate_lastserv - disksim->lastphystime));
}
}
}
void io_validate_do_stats2 (ioreq_event *new)
{
stat_update(tracestats2, validate_lastserv);
if (new->flags == WRITE) {
stat_update(tracestats4, validate_lastserv);
}
if (strcmp(validate_buffaction, "Doub") == 0) {
validatebuf[0]++;
} else if (strcmp(validate_buffaction, "Trip") == 0) {
validatebuf[1]++;
} else if (strcmp(validate_buffaction, "Miss") == 0) {
validatebuf[2]++;
} else if (strcmp(validate_buffaction, "Hit") == 0) {
validatebuf[3]++;
} else {
fprintf(stderr, "Unrecognized buffaction in validate trace: %s\n", validate_buffaction);
exit(1);
}
}
static void io_hpl_do_stats1 ()
{
int i;
if (tracestats == NULL) {
tracestats = (statgen *)DISKSIM_malloc(tracemappings * sizeof(statgen));
tracestats1 = (statgen *)DISKSIM_malloc(tracemappings * sizeof(statgen));
tracestats2 = (statgen *)DISKSIM_malloc(tracemappings * sizeof(statgen));
tracestats3 = (statgen *)DISKSIM_malloc(tracemappings * sizeof(statgen));
tracestats4 = (statgen *)DISKSIM_malloc(tracemappings * sizeof(statgen));
for (i=0; i<tracemappings; i++) {
stat_initialize(statdeffile, statdesc_tracequeuestats, &tracestats[i]);
stat_initialize(statdeffile, statdesc_tracerespstats, &tracestats1[i]);
stat_initialize(statdeffile, statdesc_traceaccstats, &tracestats2[i]);
stat_initialize(statdeffile, statdesc_traceqlenstats, &tracestats3[i]);
stat_initialize(statdeffile, statdesc_tracenoqstats, &tracestats4[i]);
}
}
}
void io_map_trace_request (ioreq_event *temp)
{
int i;
for (i=0; i<tracemappings; i++) {
if (temp->devno == tracemap[i]) {
temp->devno = tracemap1[i];
if (tracemap2[i]) {
if (tracemap2[i] < 1) {
temp->blkno *= -tracemap2[i];
} else {
if (temp->blkno % tracemap2[i]) {
fprintf(stderr, "Small sector size disk using odd sector number: %d\n", temp->blkno);
exit(1);
}
/*
fprintf (outputfile, "mapping block number %d to %d\n", temp->blkno, (temp->blkno / tracemap2[i]));
*/
temp->blkno /= tracemap2[i];
}
}
temp->bcount *= tracemap3[i];
temp->blkno += tracemap4[i];
if (tracestats) {
stat_update(&tracestats[i], ((double) temp->tempint1 / (double) 1000));
stat_update(&tracestats1[i],((double) (temp->tempint1 + temp->tempint2) / (double) 1000));
stat_update(&tracestats2[i],((double) temp->tempint2 / (double) 1000));
stat_update(&tracestats3[i], (double) temp->slotno);
if (temp->slotno == 1) {
stat_update(&tracestats4[i], ((double) temp->tempint1 / (double) 1000));
}
}
return;
}
}
/*
fprintf(stderr, "Requested device not mapped - %x\n", temp->devno);
exit(1);
*/
}
event * io_get_next_external_event (FILE *iotracefile)
{
ioreq_event *temp;
ASSERT(io_extq == NULL);
//fprintf (outputfile, "Near beginning of io_get_next_external_event\n");
temp = (ioreq_event *) getfromextraq();
switch (disksim->traceformat) {
case VALIDATE: io_validate_do_stats1();
break;
case HPL: io_hpl_do_stats1();
break;
}
temp = iotrace_get_ioreq_event(iotracefile, disksim->traceformat, temp);
if (temp) {
switch (disksim->traceformat) {
case VALIDATE: io_validate_do_stats2 (temp);
break;
}
temp->type = IO_REQUEST_ARRIVE;
if (constintarrtime > 0.0) {
temp->time = last_request_arrive + constintarrtime;
last_request_arrive = temp->time;
}
temp->time = (temp->time * ioscale) + tracebasetime;
if ((temp->time < simtime) && (!disksim->closedios)) {
fprintf(stderr, "Trace event appears out of time order in trace - simtime %f, time %f\n", simtime, temp->time);
fprintf(stderr, "ioscale %f, tracebasetime %f\n", ioscale, tracebasetime);
fprintf(stderr, "devno %d, blkno %d, bcount %d, flags %d\n", temp->devno, temp->blkno, temp->bcount, temp->flags);
exit(1);
}
if (tracemappings) {
io_map_trace_request(temp);
}
io_extq = (event *)temp;
io_extq_type = temp->type;
}
/*
fprintf (outputfile, "leaving io_get_next_external_event\n");
*/
return ((event *)temp);
}
int io_using_external_event (event *curr)
{
if (io_extq == curr) {
curr->type = io_extq_type;
io_extq = NULL;
return(1);
}
return(0);
}
void io_printstats()
{
int i;
int cnt = 0;
char prefix[80];
fprintf (outputfile, "\nSTORAGE SUBSYSTEM STATISTICS\n");
fprintf (outputfile, "----------------------------\n");
iotrace_printstats (outputfile);
if ((tracestats) && (PRINTTRACESTATS)) {
/* info relevant to HPL traces */
for (i=0; i<tracemappings; i++) {
sprintf(prefix, "Mapped disk #%d ", i);
stat_print(&tracestats[i], prefix);
stat_print(&tracestats1[i], prefix);
stat_print(&tracestats2[i], prefix);
stat_print(&tracestats3[i], prefix);
stat_print(&tracestats4[i], prefix);
}
} else if ((tracestats2) && (PRINTTRACESTATS)) {
/* info to help with validation */
fprintf (outputfile, "\n");
stat_print(tracestats2, "VALIDATE ");
stat_print(tracestats3, "VALIDATE ");
stat_print(tracestats4, "VALIDATE ");
stat_print(tracestats5, "VALIDATE ");
for (i=0; i<10; i++) {
cnt += validatebuf[i];
}
fprintf (outputfile, "VALIDATE double disconnects: %5d \t%f\n", validatebuf[0], ((double) validatebuf[0] / (double) cnt));
fprintf (outputfile, "VALIDATE triple disconnects: %5d \t%f\n", validatebuf[1], ((double) validatebuf[1] / (double) cnt));
fprintf (outputfile, "VALIDATE read buffer hits: %5d \t%f\n", validatebuf[3], ((double) validatebuf[3] / (double) cnt));
fprintf (outputfile, "VALIDATE buffer misses: %5d \t%f\n", validatebuf[2], ((double) validatebuf[2] / (double) cnt));
}
iodriver_printstats();
device_printstats();
controller_printstats();
bus_printstats();
}
void io_setcallbacks ()
{
device_setcallbacks ();
bus_setcallbacks ();
controller_setcallbacks ();
iodriver_setcallbacks ();
}
void io_initialize (int standalone)
{
if (disksim->iosim_info == NULL) {
iosim_initialize_iosim_info ();
}
bus_set_depths();
// fprintf (outputfile, "Back from bus_set_depths\n");
StaticAssert (sizeof(ioreq_event) <= DISKSIM_EVENT_SIZE);
device_initialize();
bus_initialize();
controller_initialize();
iodriver_initialize(standalone);
}
void io_resetstats()
{
iodriver_resetstats();
device_resetstats();
bus_resetstats();
controller_resetstats();
}
void io_cleanstats()
{
iodriver_cleanstats();
device_cleanstats();
bus_cleanstats();
controller_cleanstats();
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C
1
https://gitee.com/ZhouHeyu/Flashsim-origin.git
git@gitee.com:ZhouHeyu/Flashsim-origin.git
ZhouHeyu
Flashsim-origin
Mix-SSD
master

搜索帮助