forked from OSchip/llvm-project
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 llvm-svn: 362125
This commit is contained in:
parent
778e445c58
commit
ec1b4d1f6f
|
@ -1250,11 +1250,11 @@ static void __kmp_stg_parse_target_offload(char const *name, char const *value,
|
||||||
if (*next == '\0')
|
if (*next == '\0')
|
||||||
return;
|
return;
|
||||||
scan = next;
|
scan = next;
|
||||||
if (__kmp_match_str("MANDATORY", scan, &next)) {
|
if (!__kmp_strcasecmp_with_sentinel("mandatory", scan, 0)) {
|
||||||
__kmp_target_offload = tgt_mandatory;
|
__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;
|
__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;
|
__kmp_target_offload = tgt_default;
|
||||||
} else {
|
} else {
|
||||||
KMP_WARNING(SyntaxErrorUsing, name, "DEFAULT");
|
KMP_WARNING(SyntaxErrorUsing, name, "DEFAULT");
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
Loading…
Reference in New Issue