mirror of https://github.com/BOINC/boinc.git
client: keep array subscripts in bounds.
This commit is contained in:
parent
b37cf4cd9a
commit
64d76198ea
|
@ -37,6 +37,7 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "coproc.h"
|
#include "coproc.h"
|
||||||
|
#include "gpu_detect.h"
|
||||||
#include "file_names.h"
|
#include "file_names.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "str_replace.h"
|
#include "str_replace.h"
|
||||||
|
@ -60,7 +61,7 @@ vector<COPROC_INTEL> intel_gpus;
|
||||||
vector<OPENCL_DEVICE_PROP> ati_opencls;
|
vector<OPENCL_DEVICE_PROP> ati_opencls;
|
||||||
vector<OPENCL_DEVICE_PROP> nvidia_opencls;
|
vector<OPENCL_DEVICE_PROP> nvidia_opencls;
|
||||||
vector<OPENCL_DEVICE_PROP> intel_gpu_opencls;
|
vector<OPENCL_DEVICE_PROP> intel_gpu_opencls;
|
||||||
vector<OPENCL_DEVICE_PROP> other_opencls[MAX_RSC];
|
vector<OPENCL_DEVICE_PROP> other_opencls[MAX_OTHER_OPENCLS];
|
||||||
vector<OPENCL_CPU_PROP> cpu_opencls;
|
vector<OPENCL_CPU_PROP> cpu_opencls;
|
||||||
|
|
||||||
// Number of OpenCL coproc vendors other than AMD, NVIDIA or Intel
|
// Number of OpenCL coproc vendors other than AMD, NVIDIA or Intel
|
||||||
|
@ -281,7 +282,7 @@ void COPROCS::correlate_gpus(
|
||||||
ati_opencls.clear();
|
ati_opencls.clear();
|
||||||
nvidia_opencls.clear();
|
nvidia_opencls.clear();
|
||||||
intel_gpu_opencls.clear();
|
intel_gpu_opencls.clear();
|
||||||
for (j=0; j<MAX_RSC; j++) {
|
for (j=0; j<MAX_OTHER_OPENCLS; j++) {
|
||||||
other_opencls[j].clear();
|
other_opencls[j].clear();
|
||||||
}
|
}
|
||||||
cpu_opencls.clear();
|
cpu_opencls.clear();
|
||||||
|
@ -373,7 +374,7 @@ int COPROCS::read_coproc_info_file(vector<string> &warnings) {
|
||||||
ati_opencls.clear();
|
ati_opencls.clear();
|
||||||
nvidia_opencls.clear();
|
nvidia_opencls.clear();
|
||||||
intel_gpu_opencls.clear();
|
intel_gpu_opencls.clear();
|
||||||
for (int j=0; j<MAX_RSC; j++) {
|
for (int j=0; j<MAX_OTHER_OPENCLS; j++) {
|
||||||
other_opencls[j].clear();
|
other_opencls[j].clear();
|
||||||
}
|
}
|
||||||
cpu_opencls.clear();
|
cpu_opencls.clear();
|
||||||
|
@ -482,7 +483,7 @@ int COPROCS::read_coproc_info_file(vector<string> &warnings) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vendor_index >= MAX_RSC) {
|
if (vendor_index >= MAX_OTHER_OPENCLS) {
|
||||||
// Too many OpenCL device vendors found (should never happen here)
|
// Too many OpenCL device vendors found (should never happen here)
|
||||||
continue; // Discard this coprocessor's info
|
continue; // Discard this coprocessor's info
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,14 +15,25 @@
|
||||||
// You should have received a copy of the GNU Lesser General Public License
|
// You should have received a copy of the GNU Lesser General Public License
|
||||||
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
|
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#ifndef _GPU_DETECT_H_
|
||||||
|
#define _GPU_DETECT_H_
|
||||||
|
|
||||||
|
#include "coproc.h"
|
||||||
|
|
||||||
|
using std::vector;
|
||||||
|
|
||||||
|
// NOTE: coprocs[0] is reserved for CPU, leaving MAX_RSC-1
|
||||||
|
#define MAX_OTHER_OPENCLS MAX_RSC-1
|
||||||
|
|
||||||
extern vector<COPROC_ATI> ati_gpus;
|
extern vector<COPROC_ATI> ati_gpus;
|
||||||
extern vector<COPROC_NVIDIA> nvidia_gpus;
|
extern vector<COPROC_NVIDIA> nvidia_gpus;
|
||||||
extern vector<COPROC_INTEL> intel_gpus;
|
extern vector<COPROC_INTEL> intel_gpus;
|
||||||
extern vector<OPENCL_DEVICE_PROP> nvidia_opencls;
|
extern vector<OPENCL_DEVICE_PROP> nvidia_opencls;
|
||||||
extern vector<OPENCL_DEVICE_PROP> ati_opencls;
|
extern vector<OPENCL_DEVICE_PROP> ati_opencls;
|
||||||
extern vector<OPENCL_DEVICE_PROP> intel_gpu_opencls;
|
extern vector<OPENCL_DEVICE_PROP> intel_gpu_opencls;
|
||||||
extern vector<OPENCL_DEVICE_PROP> other_opencls[MAX_RSC];
|
extern vector<OPENCL_DEVICE_PROP> other_opencls[MAX_OTHER_OPENCLS];
|
||||||
extern vector<OPENCL_CPU_PROP> cpu_opencls;
|
extern vector<OPENCL_CPU_PROP> cpu_opencls;
|
||||||
|
|
||||||
extern int num_other_opencl_types;
|
extern int num_other_opencl_types;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
|
@ -537,7 +537,7 @@ void COPROCS::get_opencl(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vendor_index >= MAX_RSC) {
|
if (vendor_index >= MAX_OTHER_OPENCLS) {
|
||||||
warnings.push_back("Too many OpenCL device vendors found");
|
warnings.push_back("Too many OpenCL device vendors found");
|
||||||
continue; // Discard this coprocessor's info
|
continue; // Discard this coprocessor's info
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue