change ldso path file logic to replace rather than add to search path
authorRich Felker <dalias@aerifal.cx>
Fri, 9 Nov 2012 03:41:16 +0000 (22:41 -0500)
committerRich Felker <dalias@aerifal.cx>
Fri, 9 Nov 2012 03:41:16 +0000 (22:41 -0500)
this change was originally intended just to avoid repeated attempts to
open a nonexistant /etc/ls-musl-$(ARCH).path file, but I realized it
also prevents the default paths from being searched when such a path
file exists. despite the potential to break existing usage, I believe
the new behavior is the right behavior, and it's better to fix it
sooner rather than later. with the old behavior, it was impossible to
inhibit search of default paths which might contain musl-incompatible
libs (or even libs from a different cpu arch, on multi-arch machines).

src/ldso/dynlink.c

index 625f80c..c295301 100644 (file)
@@ -483,8 +483,8 @@ static struct dso *load_library(const char *name)
                                        fclose(f);
                                }
                        }
                                        fclose(f);
                                }
                        }
-                       if (sys_path) fd = path_open(name, sys_path, buf, sizeof buf);
-                       else fd = path_open(name, "/lib:/usr/local/lib:/usr/lib", buf, sizeof buf);
+                       if (!sys_path) sys_path = "/lib:/usr/local/lib:/usr/lib";
+                       fd = path_open(name, sys_path, buf, sizeof buf);
                }
                pathname = buf;
        }
                }
                pathname = buf;
        }