Exemplo n.º 1
0
void MDT::OpenStateMachine(ThreadLocalData *tld)
{
	Processor *p = tld->p;
	Message *msg = tld->m;
	FileObject *obj = (FileObject *)msg->req;
	Thread *t = tld->t;

	switch (tld->state) {
	case mdt_OpenFileState:
		/* It will take 5ms to open/create a new file. Very simple... */
		t->RunAfter(params.io.OpenTicks + SignRand(params.io.OpenTicks / 10)); 
		tld->state = mdt_OpenCompleteState;
		break;
	case mdt_OpenCompleteState:
		Print(NOW "%s Finished OPEN for OBJ@%llu.\n",
			now, name, obj->GetId());
		msg->SetLength(1024);
		Send(msg);
		p->TaskCompletion(tld);
		msg->phase = RPC_PHASE_COMPLETE;
		break;
	}
}
Exemplo n.º 2
0
void PIOS:: OneRun(run_arg *args)
{
	Thread *t;
	ThreadLocalData *tld;

	args->fs = new FileSystem;
	t = new Thread;
	tld = new ThreadLocalData;
	memset(tld, 0, sizeof(*tld));
	tld->v = args;
	tld->t = t;

	Event::SetClock(0);

	args->fs->Start();
	t->CreateThread(do_one_run, tld);
	t->RunAfter(1);

	Event::Schedule();
	
	delete args->fs;
	delete tld;
	delete t;
}
Exemplo n.º 3
0
void PIOS::do_one_run(void *data)
{
	ThreadLocalData *tld = (ThreadLocalData *) data;
	run_arg *args = (run_arg *)tld->v;
	
	switch (tld->state) {
	case pios_RunOneStartState: {
		int i;

		args->startime = Event::Clock();
		Print(NOW "Start run: T %lu N %llu C %llu S %llu O %llu\n",
			args->startime, args->threadcount, args->regioncount,
			args->chunksize, args->regionsize, args->offset);

		/* Setup stream */
		args->streams = new pios_stream [args->regioncount];
		for (i = 0; i < args->regioncount; i++) {
			if (args->fpp) {
				args->streams[i].fid = i;
				args->streams[i].offset = args->offset;
				args->streams[i].max_offset = args->offset + args->regionsize;
				args->num_open_files++;
			} else {
				args->streams[i].fid = 0;
				args->streams[i].offset = args->offset * i;
				args->streams[i].max_offset = args->offset * i + args->regionsize;
			}
			args->streams[i].iotime = 0;
		}

		/* Setup pios thread data */
		args->ptds = new pios_thdata [args->threadcount];
		args->tlds = new ThreadLocalData [args->threadcount];

		memset(args->ptds, 0, sizeof(pios_thdata) * args->threadcount);
		memset(args->tlds, 0, sizeof(ThreadLocalData) * args->threadcount);
		for (i = 0; i < args->threadcount; i++) {
			Thread *t;

			t = new Thread;

			args->ptds[i].parent = tld->t;
			args->ptds[i].args = args;
			args->ptds[i].io.cmd = WRITE;
			args->ptds[i].io.count = 0;
			args->ptds[i].io.fid = 0;
			args->ptds[i].io.off = 0;
			args->ptds[i].io.waiter = t;
			args->ptds[i].io.left = 0;
			args->ptds[i].io.parent = NULL;
			args->ptds[i].io.ref = 0;

			args->tlds[i].t = t;
			args->tlds[i].id = i;
			args->tlds[i].f = do_one_thread;
			args->tlds[i].v = &args->ptds[i];
			args->tlds[i].flags |= TLD_CTX_SWITCH;
			t->CreateThread(do_one_thread, &args->tlds[i]);

			t->RunAfter(/*Event::Rand(args->threadcount * 10)*/1);
		}
		tld->state = pios_RunOneAllFinishState;
		break;
	}
	case pios_RunOneAllFinishState:
		args->iotime = Event::Clock() - args->startime;
		print_stats(args);
	case pios_RunOneLastState:
		/* cleanup all resource. */
		delete [] args->streams;
		delete [] args->ptds;
		delete [] args->tlds;
		break;
	}
}