Procházet zdrojové kódy

ext-toolchain-wrapper: fix paths if executable was resolved by PATH

If ext-toolchain-wrapper or any symbolic link to it was resolved by PATH,
the wrapper takes the working directory to calculate the relative paths.

Now '/proc/self/exe' is used to resolve the absolute path to the toolchain
directory if the wrapper was called neither with a relative nor an absolute
path.

[Peter: fix off-by-one, swap value == var checks around]
Signed-off-by: Patrick Ziegler <patrick.ziegler@fh-kl.de>
Tested-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
Patrick Ziegler před 12 roky
rodič
revize
74ae7af927
1 změnil soubory, kde provedl 15 přidání a 2 odebrání
  1. 15 2
      toolchain/toolchain-external/ext-toolchain-wrapper.c

+ 15 - 2
toolchain/toolchain-external/ext-toolchain-wrapper.c

@@ -61,7 +61,7 @@ int main(int argc, char **argv)
 	char *relbasedir, *absbasedir;
 	char *relbasedir, *absbasedir;
 	char *progpath = argv[0];
 	char *progpath = argv[0];
 	char *basename;
 	char *basename;
-	int ret;
+	int ret, i, count = 0;
 
 
 	/* Calculate the relative paths */
 	/* Calculate the relative paths */
 	basename = strrchr(progpath, '/');
 	basename = strrchr(progpath, '/');
@@ -77,7 +77,20 @@ int main(int argc, char **argv)
 		absbasedir = realpath(relbasedir, NULL);
 		absbasedir = realpath(relbasedir, NULL);
 	} else {
 	} else {
 		basename = progpath;
 		basename = progpath;
-		absbasedir = realpath("../..", NULL);
+		absbasedir = malloc(PATH_MAX + 1);
+		ret = readlink("/proc/self/exe", absbasedir, PATH_MAX);
+		if (ret < 0) {
+			perror(__FILE__ ": readlink");
+			return 2;
+		}
+		absbasedir[ret] = '\0';
+		for (i = ret; i > 0; i--) {
+			if (absbasedir[i] == '/') {
+				absbasedir[i] = '\0';
+				if (++count == 3)
+					break;
+			}
+		}
 	}
 	}
 	if (absbasedir == NULL) {
 	if (absbasedir == NULL) {
 		perror(__FILE__ ": realpath");
 		perror(__FILE__ ": realpath");