// This file is part of BOINC. // http://boinc.berkeley.edu // Copyright (C) 2008 University of California // // BOINC is free software; you can redistribute it and/or modify it // under the terms of the GNU Lesser General Public License // as published by the Free Software Foundation, // either version 3 of the License, or (at your option) any later version. // // BOINC 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 Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with BOINC. If not, see . #ifndef _COPROC_ #define _COPROC_ #include #include #include #ifdef _USING_FCGI_ #include "boinc_fcgi.h" #endif #include "miofile.h" #define MAX_COPROC_INSTANCES 8 struct COPROC { char type[256]; // must be unique int count; // how many are present int used; // how many are in use (used by client) void* owner[MAX_COPROC_INSTANCES]; // which ACTIVE_TASK each one is allocated to #ifndef _USING_FCGI_ virtual void write_xml(MIOFILE&); #endif COPROC(const char* t){ strcpy(type, t); count = 0; used = 0; memset(&owner, 0, sizeof(owner)); } virtual ~COPROC(){} int parse(MIOFILE&); }; struct COPROCS { std::vector coprocs; // not deleted in destructor // so any structure that includes this needs to do it manually COPROCS(){} ~COPROCS(){} void delete_coprocs(){ for (unsigned int i=0; iwrite_xml(out); } } #endif std::vector get(); int parse(FILE*); void summary_string(char*, int); COPROC* lookup(char*); bool sufficient_coprocs(COPROCS&, bool log_flag, const char* prefix); void reserve_coprocs(COPROCS&, void*, bool log_flag, const char* prefix); void free_coprocs(COPROCS&, void*, bool log_flag, const char* prefix); bool fully_used() { for (unsigned int i=0; iused < cp->count) return false; } return true; } // Copy a coproc set, setting usage to zero. // used in round-robin simulator and CPU scheduler, // to avoid messing w/ master copy // void clone(COPROCS& c, bool copy_used) { for (unsigned int i=0; itype); cp2->count = cp->count; if (copy_used) cp2->used = cp->used; coprocs.push_back(cp2); } } }; // the following copied from /usr/local/cuda/include/driver_types.h // struct cudaDeviceProp { char name[256]; size_t totalGlobalMem; // not used on the server; dtotalGlobalMem is used instead // (since some boards have >= 4GB) size_t sharedMemPerBlock; int regsPerBlock; int warpSize; size_t memPitch; int maxThreadsPerBlock; int maxThreadsDim[3]; int maxGridSize[3]; int clockRate; size_t totalConstMem; int major; int minor; size_t textureAlignment; int deviceOverlap; int multiProcessorCount; int __cudaReserved[40]; double dtotalGlobalMem; }; struct COPROC_CUDA : public COPROC { cudaDeviceProp prop; #ifndef _USING_FCGI_ virtual void write_xml(MIOFILE&); #endif COPROC_CUDA(): COPROC("CUDA"){} virtual ~COPROC_CUDA(){} static std::string get(COPROCS&); void clear(); int parse(FILE*); // rough estimate of FLOPS // The following is based on SETI@home CUDA, // which gets 50 GFLOPS on a Quadro FX 3700, // which has 14 MPs and a clock rate of 1.25 MHz // inline double flops_estimate() { double x = (prop.clockRate * prop.multiProcessorCount)*5e10/(14*1.25e6); return x?x:5e10; } }; struct COPROC_CELL_SPE : public COPROC { static std::string get(COPROCS&); COPROC_CELL_SPE() : COPROC("Cell SPE"){} virtual ~COPROC_CELL_SPE(){} }; void fake_cuda(COPROCS&, int); extern COPROC_CUDA* coproc_cuda; #endif