This is an archive of the discontinued LLVM Phabricator instance.

[gn build] Add infrastructure to create symlinks and use it to create lld's symlinks
ClosedPublic

Authored by thakis on Dec 12 2018, 10:32 AM.

Details

Diff Detail

Event Timeline

thakis created this revision.Dec 12 2018, 10:32 AM
thakis marked an inline comment as done.Dec 12 2018, 10:49 AM
thakis added inline comments.
llvm/utils/gn/secondary/lld/tools/lld/BUILD.gn
15

Not sure if root_out_dir is the right thing here once we do cross builds. Is there something like "root of current toolchain"?

thakis marked an inline comment as done.Dec 12 2018, 11:00 AM
thakis added inline comments.
llvm/utils/gn/secondary/lld/tools/lld/BUILD.gn
15

Oh, root_out_dir is per-toolchain. Then this is good as-is I think.

smeenai added inline comments.
llvm/utils/gn/build/symlink_or_copy.py
3

Starting with Windows 10 RS2 (version 1703, released April 2017), you can create symlinks without needing to elevate to administrator if you have developer mode configured. I would imagine that's a reasonably common configuration for LLVM devs, and the symlinks end up saving a bunch of space. Do you think it's worth considering (not necessarily as a part of this patch; it could be done later) attempting to create a symlink even on Windows, and falling back to a copy if you get a permission denied error? I've been meaning to implement something similar on the CMake side.

thakis marked an inline comment as done.Dec 12 2018, 11:31 AM
thakis added inline comments.
llvm/utils/gn/build/symlink_or_copy.py
3

I think that'd be great. We probably wouldn't want this for releases (since users might have older Windows versions), but since the gn build is primarily for day-to-day development it makes a lot of sense to me.

I'd try that in a follow-up so I can test it on my Windows box if that's alright. (Or you could try making the change, it should be a < 10 line change in just this script.)

thakis marked an inline comment as done.Dec 12 2018, 11:37 AM
thakis added inline comments.
llvm/utils/gn/build/symlink_or_copy.py
3

(ps: Once we no longer need to worry about old Windows versions that don't have symlinks, we can use the LHS on https://github.com/nico/llvm-project-20170507/commit/f24e0f0152d22eecad27f63b58149942c4b9bc22 instead)

smeenai added inline comments.Dec 12 2018, 11:43 AM
llvm/utils/gn/build/symlink_or_copy.py
3

I'll play around with this ... I've been meaning to experiment with the gn build for a while :)

I actually think it would be fine to use symlinks for releases as well. Symlinks have been around since Windows Vista, but you had to elevate to administrator to be able to create or modify them, so they were rarely used. Once created, you could use them without elevation though. Windows 10 RS2 removed the elevation requirement when you were in developer mode, making them much more convenient. See https://blogs.windows.com/buildingapps/2016/12/02/symlinks-windows-10/ for more details (which also reminds me, we'd have to make sure Python was actually passing SYMBOLIC_LINK_FLAG_ALLOW_UNPRIVILEGED_CREATE to its CreateSymbolicLink calls for this to work...)

thakis marked an inline comment as done.Dec 12 2018, 12:15 PM
thakis added inline comments.
llvm/utils/gn/build/symlink_or_copy.py
3

Ah, I didn't know about using symlinks not requiring privileges! That would be super nice for distribution then, actually.

I'd expect this would have to go through ctypes.windll.kernel32.CreateSymbolicLinkW instead of os.symlink; py2.7 probably precedes SYMBOLIC_LINK_FLAG_ALLOW_UNPRIVILEGED_CREATE.

smeenai added inline comments.Dec 12 2018, 12:23 PM
llvm/utils/gn/build/symlink_or_copy.py
3

Yup, Python 2.7 doesn't expose os.symlink at all on Windows, and even 3.7.1 doesn't use SYMBOLIC_LINK_FLAG_ALLOW_UNPRIVILEGED_CREATE (which is disappointing).

I started playing with this:

gn gen --dotfile=llvm/utils/gn/.gn --root=. out/gn
ERROR at //llvm/utils/gn/build/BUILD.gn:46:5: Undefined identifier.
    defines += [
    ^------
See //llvm/utils/gn/build/BUILDCONFIG.gn:6:3: which caused the file to be included.
  "//llvm/utils/gn/build:compiler_defaults",
  ^----------------------------------------

The following fixed it, though idk if it's the right fix:

diff --git a/llvm/utils/gn/build/BUILD.gn b/llvm/utils/gn/build/BUILD.gn
index 0f369ec7395..37aa4311651 100644
--- a/llvm/utils/gn/build/BUILD.gn
+++ b/llvm/utils/gn/build/BUILD.gn
@@ -3,9 +3,11 @@ import("//llvm/utils/gn/build/mac_sdk.gni")
 import("//llvm/utils/gn/build/toolchain/compiler.gni")

 config("compiler_defaults") {
+  defines = []
+
   # FIXME: Don't define this globally here.
   if (host_os != "win") {
-    defines = [ "LLVM_ON_UNIX" ]
+    defines += [ "LLVM_ON_UNIX" ]
   }

   if (!llvm_enable_assertions) {

I started playing with this:

gn gen --dotfile=llvm/utils/gn/.gn --root=. out/gn
ERROR at //llvm/utils/gn/build/BUILD.gn:46:5: Undefined identifier.
    defines += [
    ^------
See //llvm/utils/gn/build/BUILDCONFIG.gn:6:3: which caused the file to be included.
  "//llvm/utils/gn/build:compiler_defaults",
  ^----------------------------------------

The following fixed it, though idk if it's the right fix:

diff --git a/llvm/utils/gn/build/BUILD.gn b/llvm/utils/gn/build/BUILD.gn
index 0f369ec7395..37aa4311651 100644
--- a/llvm/utils/gn/build/BUILD.gn
+++ b/llvm/utils/gn/build/BUILD.gn
@@ -3,9 +3,11 @@ import("//llvm/utils/gn/build/mac_sdk.gni")
 import("//llvm/utils/gn/build/toolchain/compiler.gni")

 config("compiler_defaults") {
+  defines = []
+
   # FIXME: Don't define this globally here.
   if (host_os != "win") {
-    defines = [ "LLVM_ON_UNIX" ]
+    defines += [ "LLVM_ON_UNIX" ]
   }

   if (!llvm_enable_assertions) {

That looks like the right fix. Looks like I haven't trie d this on Windows in a while :-/ Want to send a patch?

smeenai added inline comments.Dec 12 2018, 5:04 PM
llvm/utils/gn/build/symlink_or_copy.py
3

https://github.com/python/cpython/pull/3652 will fix os.symlink, but directly calling ctypes.windll.kernel32.CreateSymbolicLinkW in the meantime will work. I'll put up a patch.

phosek: 24h ping :-)

phosek accepted this revision.Dec 13 2018, 2:08 PM

One aspect of this change I'm not super excited about is the fact that it duplicates information from the toolchain, specifically the file extension. What's worse, people can override the output_extension on individual targets. symlink_or_copy would break in those cases (or if we change the default extension e.g. for a new toolchain). Unfortunately, handling this in a proper way is tricky. Changing the link tool to also create symlinks as you mentioned is the only way I could think of that avoids that duplication, but that's pretty ugly. Ideally, we would be able to use a copy target, but even that doesn't work since you still have to specify the source which has the same issue. So this change is LGTM as is, but I think this is something we should maybe raise on gn-dev as this is not the first time it came up.

This revision is now accepted and ready to land.Dec 13 2018, 2:08 PM

One aspect of this change I'm not super excited about is the fact that it duplicates information from the toolchain, specifically the file extension. What's worse, people can override the output_extension on individual targets. symlink_or_copy would break in those cases (or if we change the default extension e.g. for a new toolchain). Unfortunately, handling this in a proper way is tricky. Changing the link tool to also create symlinks as you mentioned is the only way I could think of that avoids that duplication, but that's pretty ugly. Ideally, we would be able to use a copy target, but even that doesn't work since you still have to specify the source which has the same issue. So this change is LGTM as is, but I think this is something we should maybe raise on gn-dev as this is not the first time it came up.

That's a great point, thanks. I added a FIXME to the py script saying that this shouldn't look at the host os but the target os.

This revision was automatically updated to reflect the committed changes.

Norton is an Antivirus, Anti Malware and internet security software that is designed and developed by Symantec. It uses techniques like signature and heuristics to identify the potential virus. In addition, it has more features like email spam filtering and anti-phishing. Norton is next-gen antivirus security software that offers powerful protection for all your PC, Mac, tablets and smartphones.
Norton login

Herald added a project: Restricted Project. · View Herald TranscriptMay 9 2019, 3:55 AM

Avast Account is a portal designed to help you manage all your Avast licenses for different products and devices that are registered to one email address.
Avast Login

Manually Update Avast Virus Definitions – Avast is a very powerful security service provider whose services are available for all kinds of devices including Windows PC, Mac, and Android Smart devices. You can visit My.Avast.com to check all the services available. Also, Avast also offers a subscription for both personal use and business purposes.
avast login

my.avast.com - Get Avast Login to My Avast Account at my.avast.com or id.avast.com and Access Avast Services like Avast Login, Sign in, Sign up Here."
my.avast.com

Kaspersky Total Security Stay Safe Online – Surfing online and using the internet has become a daily need. We use the web for multiple things such as general surfing, education, banking, e-commerce and many more.
Activation.kaspersky.com

amazing work done really helped a lot in installing office
https://settup-office.com/setup