summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSwift Kim <swift.kim@samsung.com>2019-08-01 15:10:49 +0900
committer이형주/Common Platform Lab(SR)/Staff Engineer/삼성전자 <leee.lee@samsung.com>2020-04-22 19:19:59 +0900
commit3a482e273fe78af736920144e67f6c193c9d6625 (patch)
tree2d5dbcc1c560e014e23751d42417ae6cbfea0120
parent4feb5cbcbeea277f7addb372b3c632e89f9ed1ae (diff)
downloadcoreclr-3a482e273fe78af736920144e67f6c193c9d6625.tar.gz
coreclr-3a482e273fe78af736920144e67f6c193c9d6625.tar.bz2
coreclr-3a482e273fe78af736920144e67f6c193c9d6625.zip
[Tizen] Add a config knob for importing ibc files
-rw-r--r--Documentation/project-docs/clr-configuration-knobs.md1
-rw-r--r--src/inc/clrconfigvalues.h2
-rw-r--r--src/zap/zapimage.cpp15
3 files changed, 16 insertions, 2 deletions
diff --git a/Documentation/project-docs/clr-configuration-knobs.md b/Documentation/project-docs/clr-configuration-knobs.md
index 9786bc4b8d..4e9a772ed0 100644
--- a/Documentation/project-docs/clr-configuration-knobs.md
+++ b/Documentation/project-docs/clr-configuration-knobs.md
@@ -283,6 +283,7 @@ Name | Description | Type | Class | Default Value | Flags
`DisableHotCold` | Master hot/cold splitting switch in Jit64 | `DWORD` | `UNSUPPORTED` | |
`DisableIBC` | Disables the use of IBC data | `DWORD` | `UNSUPPORTED` | `0` | REGUTIL_default
`UseIBCFile` | | `DWORD` | `EXTERNAL` | `0` | REGUTIL_default
+`IBCFileDir` | Directory to search for IBC files | `STRING` | `EXTERNAL` | |
#### Interop Configuration Knobs
diff --git a/src/inc/clrconfigvalues.h b/src/inc/clrconfigvalues.h
index 2cb127ca80..98e03e008f 100644
--- a/src/inc/clrconfigvalues.h
+++ b/src/inc/clrconfigvalues.h
@@ -325,7 +325,7 @@ RETAIL_CONFIG_DWORD_INFO_EX(UNSUPPORTED_ConvertIbcData, W("ConvertIbcData"), 1,
RETAIL_CONFIG_DWORD_INFO_DIRECT_ACCESS(UNSUPPORTED_DisableHotCold, W("DisableHotCold"), "Master hot/cold splitting switch in Jit64")
RETAIL_CONFIG_DWORD_INFO_EX(UNSUPPORTED_DisableIBC, W("DisableIBC"), 0, "Disables the use of IBC data", CLRConfig::REGUTIL_default)
RETAIL_CONFIG_DWORD_INFO_EX(EXTERNAL_UseIBCFile, W("UseIBCFile"), 0, "", CLRConfig::REGUTIL_default)
-
+RETAIL_CONFIG_STRING_INFO(EXTERNAL_IBCFileDir, W("IBCFileDir"), "Directory to search for IBC files")
///
/// JIT
diff --git a/src/zap/zapimage.cpp b/src/zap/zapimage.cpp
index 4a11405a73..228ef2aa48 100644
--- a/src/zap/zapimage.cpp
+++ b/src/zap/zapimage.cpp
@@ -2475,7 +2475,20 @@ HRESULT ZapImage::LocateProfileData()
// Couldn't find profile resource--let's see if there's an ibc file to use instead
//
- SString path(m_pModuleFileName);
+ SString path;
+
+ LPWSTR ibcDir = CLRConfig::GetConfigValue(CLRConfig::EXTERNAL_IBCFileDir);
+ if (ibcDir != NULL)
+ {
+ LPCWSTR moduleFileName = wcsrchr(m_pModuleFileName, DIRECTORY_SEPARATOR_CHAR_W);
+ path.Set(ibcDir);
+ path.Append(DIRECTORY_SEPARATOR_CHAR_W);
+ path.Append(moduleFileName);
+ }
+ else
+ {
+ path.Set(m_pModuleFileName); // the same directory as the IL dll
+ }
SString::Iterator dot = path.End();
if (path.FindBack(dot, '.'))