diff options
author | Jeff Hatch <jhatch@multitech.com> | 2020-12-18 12:16:50 -0600 |
---|---|---|
committer | Jeff Hatch <jhatch@multitech.com> | 2020-12-18 12:16:50 -0600 |
commit | 7c0fe5b37fbc717b03754ff0f7e2349990f7e4f1 (patch) | |
tree | 3d088932174342a90e37b693d0dd71bd6a55d050 /include | |
parent | 0dbb4ef906dad01bce313f7de51ad2253599ca97 (diff) | |
parent | f3626b3090ceb81bb16f4a8a5f21486347b690de (diff) | |
download | mts-io-sysfs-7c0fe5b37fbc717b03754ff0f7e2349990f7e4f1.tar.gz mts-io-sysfs-7c0fe5b37fbc717b03754ff0f7e2349990f7e4f1.tar.bz2 mts-io-sysfs-7c0fe5b37fbc717b03754ff0f7e2349990f7e4f1.zip |
Merge branch 'ms/MTX-3769_new_capa_tpm' into 'master'
[MTX-3769] Conduit 300: New Capability - TPM
See merge request !3
Diffstat (limited to 'include')
-rw-r--r-- | include/Utility/Utility.h | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/include/Utility/Utility.h b/include/Utility/Utility.h index bd6019e..8d68baa 100644 --- a/include/Utility/Utility.h +++ b/include/Utility/Utility.h @@ -3,6 +3,7 @@ #include "General.h" #include "Version.h" +#include <glob.h> /********************************************************************** * COPYRIGHT 2020 MULTI-TECH SYSTEMS, INC. @@ -56,4 +57,26 @@ inline mode_t fileType(std::string file) { } } +/* + findFileGlob() function has been added for generic file name search. + For example: one device has file /dev/tpm0, another one has /dev/tpm3. + And as a search parameter, you can specify the filepath with wildcard, + findFileGlob("/dev/tpm*"). The function will find the required file. +*/ + +inline mode_t findFileGlob(std::string file) { + struct stat buf = {}; + glob_t gl; + mode_t result = -1; + + if (0 == glob(file.c_str(), 0, NULL, &gl)) { + if (0 < gl.gl_pathc && 0 == stat(gl.gl_pathv[0], &buf)) { + result = buf.st_mode & S_IFMT; + } + globfree(&gl); + } + + return result; +} + #endif /* UTILITIES_H_ */ |