[Openmp-commits] [openmp] r362125 - Fix OMP_TARGET_OFFLOAD parsing
Hansang Bae via Openmp-commits
openmp-commits at lists.llvm.org
Thu May 30 11:35:08 PDT 2019
Author: hbae
Date: Thu May 30 11:35:07 2019
New Revision: 362125
URL: http://llvm.org/viewvc/llvm-project?rev=362125&view=rev
Log:
Fix OMP_TARGET_OFFLOAD parsing
Current parsing allows trailing string after the permitted value,
MANDATORY|DISABLED|DEFAULT -- e.g., "mandatorynot" is also recognized
as "MANDATORY". Such cases should be recognized as incorrect/unknown
value.
Differential Revision: https://reviews.llvm.org/D62431
Added:
openmp/trunk/runtime/test/env/omp_target_offload.c
Modified:
openmp/trunk/runtime/src/kmp_settings.cpp
Modified: openmp/trunk/runtime/src/kmp_settings.cpp
URL: http://llvm.org/viewvc/llvm-project/openmp/trunk/runtime/src/kmp_settings.cpp?rev=362125&r1=362124&r2=362125&view=diff
==============================================================================
--- openmp/trunk/runtime/src/kmp_settings.cpp (original)
+++ openmp/trunk/runtime/src/kmp_settings.cpp Thu May 30 11:35:07 2019
@@ -1250,11 +1250,11 @@ static void __kmp_stg_parse_target_offlo
if (*next == '\0')
return;
scan = next;
- if (__kmp_match_str("MANDATORY", scan, &next)) {
+ if (!__kmp_strcasecmp_with_sentinel("mandatory", scan, 0)) {
__kmp_target_offload = tgt_mandatory;
- } else if (__kmp_match_str("DISABLED", scan, &next)) {
+ } else if (!__kmp_strcasecmp_with_sentinel("disabled", scan, 0)) {
__kmp_target_offload = tgt_disabled;
- } else if (__kmp_match_str("DEFAULT", scan, &next)) {
+ } else if (!__kmp_strcasecmp_with_sentinel("default", scan, 0)) {
__kmp_target_offload = tgt_default;
} else {
KMP_WARNING(SyntaxErrorUsing, name, "DEFAULT");
Added: openmp/trunk/runtime/test/env/omp_target_offload.c
URL: http://llvm.org/viewvc/llvm-project/openmp/trunk/runtime/test/env/omp_target_offload.c?rev=362125&view=auto
==============================================================================
--- openmp/trunk/runtime/test/env/omp_target_offload.c (added)
+++ openmp/trunk/runtime/test/env/omp_target_offload.c Thu May 30 11:35:07 2019
@@ -0,0 +1,62 @@
+// RUN: %libomp-compile-and-run
+#include <string.h>
+#include <stdlib.h>
+
+enum kmp_target_offload_kind {
+ tgt_disabled = 0,
+ tgt_default = 1,
+ tgt_mandatory = 2
+};
+
+extern int __kmpc_get_target_offload();
+
+const char *disabled_examples[] = {
+ // Allowed inputs
+ "disabled", "DISABLED", "Disabled", "dIsAbLeD", "DiSaBlEd"};
+
+const char *default_examples[] = {
+ // Allowed inputs
+ "default", "DEFAULT", "Default", "deFAulT", "DEfaULt",
+ // These should be changed to default (failed match)
+ "mandatry", "defaults", "disable", "enabled", "mandatorynot"};
+
+const char *mandatory_examples[] = {
+ // Allowed inputs
+ "mandatory", "MANDATORY", "Mandatory", "manDatoRy", "MANdATOry"};
+
+// Return target-offload-var ICV
+int get_target_offload_icv() {
+#pragma omp parallel
+ {}
+ return __kmpc_get_target_offload();
+}
+
+int main() {
+ int i;
+ const char *omp_target_offload = "OMP_TARGET_OFFLOAD=";
+ char buf[80];
+
+ for (i = 0; i < sizeof(disabled_examples) / sizeof(char *); ++i) {
+ strcpy(buf, omp_target_offload);
+ strcat(buf, disabled_examples[i]);
+ kmp_set_defaults(buf);
+ if (tgt_disabled != get_target_offload_icv())
+ return EXIT_FAILURE;
+ }
+ for (i = 0; i < sizeof(default_examples) / sizeof(char *); ++i) {
+ strcpy(buf, omp_target_offload);
+ strcat(buf, default_examples[i]);
+ kmp_set_defaults(buf);
+ if (tgt_default != get_target_offload_icv())
+ return EXIT_FAILURE;
+ }
+ for (i = 0; i < sizeof(mandatory_examples) / sizeof(char *); ++i) {
+ strcpy(buf, omp_target_offload);
+ strcat(buf, mandatory_examples[i]);
+ kmp_set_defaults(buf);
+ if (tgt_mandatory != get_target_offload_icv())
+ return EXIT_FAILURE;
+ }
+
+ return EXIT_SUCCESS;
+}
More information about the Openmp-commits
mailing list