OLD | NEW |
(Empty) | |
| 1 /* |
| 2 * Copyright 2013 Google Inc. |
| 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. |
| 6 */ |
| 7 |
| 8 #include <time.h> |
| 9 #include <dirent.h> |
| 10 #include "SkOSFile.h" |
| 11 #include "skpdiff_util.h" |
| 12 |
| 13 const char* cl_error_to_string(cl_int err) { |
| 14 switch (err) { |
| 15 case CL_SUCCESS: return "CL_SUCCESS"; |
| 16 case CL_DEVICE_NOT_FOUND: return "CL_DEVICE_NOT_FOUND"; |
| 17 case CL_DEVICE_NOT_AVAILABLE: return "CL_DEVICE_NOT_AVAILABLE
"; |
| 18 case CL_COMPILER_NOT_AVAILABLE: return "CL_COMPILER_NOT_AVAILAB
LE"; |
| 19 case CL_MEM_OBJECT_ALLOCATION_FAILURE: return "CL_MEM_OBJECT_ALLOCATIO
N_FAILURE"; |
| 20 case CL_OUT_OF_RESOURCES: return "CL_OUT_OF_RESOURCES"; |
| 21 case CL_OUT_OF_HOST_MEMORY: return "CL_OUT_OF_HOST_MEMORY"; |
| 22 case CL_PROFILING_INFO_NOT_AVAILABLE: return "CL_PROFILING_INFO_NOT_A
VAILABLE"; |
| 23 case CL_MEM_COPY_OVERLAP: return "CL_MEM_COPY_OVERLAP"; |
| 24 case CL_IMAGE_FORMAT_MISMATCH: return "CL_IMAGE_FORMAT_MISMATC
H"; |
| 25 case CL_IMAGE_FORMAT_NOT_SUPPORTED: return "CL_IMAGE_FORMAT_NOT_SUP
PORTED"; |
| 26 case CL_BUILD_PROGRAM_FAILURE: return "CL_BUILD_PROGRAM_FAILUR
E"; |
| 27 case CL_MAP_FAILURE: return "CL_MAP_FAILURE"; |
| 28 case CL_INVALID_VALUE: return "CL_INVALID_VALUE"; |
| 29 case CL_INVALID_DEVICE_TYPE: return "CL_INVALID_DEVICE_TYPE"
; |
| 30 case CL_INVALID_PLATFORM: return "CL_INVALID_PLATFORM"; |
| 31 case CL_INVALID_DEVICE: return "CL_INVALID_DEVICE"; |
| 32 case CL_INVALID_CONTEXT: return "CL_INVALID_CONTEXT"; |
| 33 case CL_INVALID_QUEUE_PROPERTIES: return "CL_INVALID_QUEUE_PROPER
TIES"; |
| 34 case CL_INVALID_COMMAND_QUEUE: return "CL_INVALID_COMMAND_QUEU
E"; |
| 35 case CL_INVALID_HOST_PTR: return "CL_INVALID_HOST_PTR"; |
| 36 case CL_INVALID_MEM_OBJECT: return "CL_INVALID_MEM_OBJECT"; |
| 37 case CL_INVALID_IMAGE_FORMAT_DESCRIPTOR: return "CL_INVALID_IMAGE_FORMAT
_DESCRIPTOR"; |
| 38 case CL_INVALID_IMAGE_SIZE: return "CL_INVALID_IMAGE_SIZE"; |
| 39 case CL_INVALID_SAMPLER: return "CL_INVALID_SAMPLER"; |
| 40 case CL_INVALID_BINARY: return "CL_INVALID_BINARY"; |
| 41 case CL_INVALID_BUILD_OPTIONS: return "CL_INVALID_BUILD_OPTION
S"; |
| 42 case CL_INVALID_PROGRAM: return "CL_INVALID_PROGRAM"; |
| 43 case CL_INVALID_PROGRAM_EXECUTABLE: return "CL_INVALID_PROGRAM_EXEC
UTABLE"; |
| 44 case CL_INVALID_KERNEL_NAME: return "CL_INVALID_KERNEL_NAME"
; |
| 45 case CL_INVALID_KERNEL_DEFINITION: return "CL_INVALID_KERNEL_DEFIN
ITION"; |
| 46 case CL_INVALID_KERNEL: return "CL_INVALID_KERNEL"; |
| 47 case CL_INVALID_ARG_INDEX: return "CL_INVALID_ARG_INDEX"; |
| 48 case CL_INVALID_ARG_VALUE: return "CL_INVALID_ARG_VALUE"; |
| 49 case CL_INVALID_ARG_SIZE: return "CL_INVALID_ARG_SIZE"; |
| 50 case CL_INVALID_KERNEL_ARGS: return "CL_INVALID_KERNEL_ARGS"
; |
| 51 case CL_INVALID_WORK_DIMENSION: return "CL_INVALID_WORK_DIMENSI
ON"; |
| 52 case CL_INVALID_WORK_GROUP_SIZE: return "CL_INVALID_WORK_GROUP_S
IZE"; |
| 53 case CL_INVALID_WORK_ITEM_SIZE: return "CL_INVALID_WORK_ITEM_SI
ZE"; |
| 54 case CL_INVALID_GLOBAL_OFFSET: return "CL_INVALID_GLOBAL_OFFSE
T"; |
| 55 case CL_INVALID_EVENT_WAIT_LIST: return "CL_INVALID_EVENT_WAIT_L
IST"; |
| 56 case CL_INVALID_EVENT: return "CL_INVALID_EVENT"; |
| 57 case CL_INVALID_OPERATION: return "CL_INVALID_OPERATION"; |
| 58 case CL_INVALID_GL_OBJECT: return "CL_INVALID_GL_OBJECT"; |
| 59 case CL_INVALID_BUFFER_SIZE: return "CL_INVALID_BUFFER_SIZE"
; |
| 60 case CL_INVALID_MIP_LEVEL: return "CL_INVALID_MIP_LEVEL"; |
| 61 default: return "UNKNOWN"; |
| 62 } |
| 63 return "UNKNOWN"; |
| 64 } |
| 65 |
| 66 |
| 67 double get_seconds() { |
| 68 struct timespec currentTime; |
| 69 clock_gettime(CLOCK_REALTIME, ¤tTime); |
| 70 return currentTime.tv_sec + (double)currentTime.tv_nsec / 1e9; |
| 71 } |
| 72 |
| 73 bool get_directory(const char path[], SkTArray<SkString>* entries) { |
| 74 // Open the directory and check for success |
| 75 DIR* dir = opendir(path); |
| 76 if (NULL == dir) { |
| 77 return false; |
| 78 } |
| 79 |
| 80 // Loop through dir entries until there are none left (i.e. readdir returns
NULL) |
| 81 struct dirent* entry; |
| 82 while ((entry = readdir(dir))) { |
| 83 // dirent only gives relative paths, we need to join them to the base pa
th to check if they |
| 84 // are directories. |
| 85 SkString joinedPath = SkOSPath::SkPathJoin(path, entry->d_name); |
| 86 |
| 87 // We only care about files |
| 88 if (!sk_isdir(joinedPath.c_str())) { |
| 89 entries->push_back(SkString(entry->d_name)); |
| 90 } |
| 91 } |
| 92 |
| 93 return true; |
| 94 } |
OLD | NEW |