Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enable IDN on Windows when building with clang #12606

Closed
wants to merge 2 commits into from

Conversation

mraunak
Copy link

@mraunak mraunak commented Dec 28, 2023

This PR aims to enable IDN on the Windows platform with CLANG compiler version 17 which is required to successfully
build TensorFlow-CPU on the Windows
Changed https://github.com/curl/curl/blob/master/lib/idn.c to use an inbuilt Windows function IdnToAscii on the Clang Compiler

Below is the screenshot of the error:

image

@github-actions github-actions bot added the name lookup DNS and related tech label Dec 28, 2023
@bagder bagder added the Windows Windows-specific label Dec 28, 2023
@bagder bagder changed the title Add Clang support Windows enable IDN on Windows when building with clang Dec 28, 2023
@gvanem
Copy link
Contributor

gvanem commented Dec 29, 2023

So why isn't -D_WIN32_WINNT >= 0x600 defined for Clang?

@vszakats
Copy link
Member

vszakats commented Dec 29, 2023

It doesn't look right to enable Windows SDK-specific code based on compiler vendor.
The official Windows binaries are built with clang 17 + IDN without this issue.

What needs to be seen is why this build env is missing these Windows declarations
or why it sets USE_WIN32_IDN without _WIN32, or why its Windows headers
are missing these declarations without a matching _WIN32_WINNT?

What build tool, build config, curl version is this happening with?

@vszakats vszakats added the build label Jan 2, 2024
@mraunak mraunak changed the title enable IDN on Windows when building with clang Enable IDN on Windows when building with clang Jan 2, 2024
@bagder
Copy link
Member

bagder commented Jan 4, 2024

@mraunak: this PR awaits info from you...

@mraunak
Copy link
Author

mraunak commented Jan 8, 2024

Hi Team, Thank you very much for your input.

idn.c gets compiled successfully with CLANG 15.0.7 but has the error shown above when compiled with CLANG 17

Build tool: Bazel version 6.4.0

Build config:
ERROR: D:/ockagzuo/external/curl/BUILD.bazel:31:11: Compiling lib/idn.c failed: (Exit 1): clang-cl.exe failed: error executing command (from target @curl//:curl)
cd /d D:/ockagzuo/execroot/org_tensorflow
SET INCLUDE=C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.38.33130\include;C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.38.33130\ATLMFC\include;C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\VS\include;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\ucrt;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\um;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\shared;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\winrt;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\cppwinrt;C:\Program Files (x86)\Windows Kits\NETFXSDK\4.8\include\um;D:\user\mraunak\LLVM\lib\clang\17\include
SET PATH=C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.38.33130\bin\HostX64\x64;C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\IDE\VC\VCPackages;C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\IDE\CommonExtensions\Microsoft\TestWindow;C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\IDE\CommonExtensions\Microsoft\TeamFoundation\Team Explorer;C:\Program Files\Microsoft Visual Studio\2022\Community\MSBuild\Current\bin\Roslyn;C:\Program Files\Microsoft Visual Studio\2022\Community\Team Tools\Performance Tools\x64;C:\Program Files\Microsoft Visual Studio\2022\Community\Team Tools\Performance Tools;C:\Program Files (x86)\Microsoft Visual Studio\Shared\Common\VSPerfCollectionTools\vs2019\x64;C:\Program Files (x86)\Microsoft Visual Studio\Shared\Common\VSPerfCollectionTools\vs2019;C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools\x64;C:\Program Files\Microsoft Visual Studio\2022\Community\Team Tools\DiagnosticsHub\Collector;C:\Program Files (x86)\Windows Kits\10\bin\10.0.22621.0\x64;C:\Program Files (x86)\Windows Kits\10\bin\x64;C:\Program Files\Microsoft Visual Studio\2022\Community\MSBuild\Current\Bin\amd64;C:\Windows\Microsoft.NET\Framework64\v4.0.30319;C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\IDE;C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\Tools;;C:\Windows\system32;C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\Llvm\x64\bin;C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\IDE\CommonExtensions\Microsoft\CMake\CMake\bin;C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\IDE\CommonExtensions\Microsoft\CMake\Ninja;C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\IDE\VC\Linux\bin\ConnectionManagerExe
SET PWD=/proc/self/cwd
SET PYTHON_BIN_PATH=D:/user/mraunak/venv310_new1/Scripts/python.exe
SET PYTHON_LIB_PATH=D:/user/mraunak/venv310_new1/lib/site-packages
SET TEMP=C:\Users\mraunak\AppData\Local\Temp\2
SET TF2_BEHAVIOR=1
SET TMP=C:\Users\mraunak\AppData\Local\Temp\2
SET VSLANG=1033
D:\user\mraunak\LLVM\bin\clang-cl.exe @bazel-out/x64_windows-opt/bin/external/curl/_objs/curl/idn.obj.params
"#Configuration: d9c220ac8112bcb55e4eecee5f7704306287d5558f345559f8f07e36e16a82c0"
"#Execution platform: //tensorflow/tools/toolchains/win:x64_windows-clang-cl"

Curl version: curl 8.4.0 (Windows) libcurl/8.4.0 Schannel WinIDN
Release-Date: 2023-10-11

Clang version: 17.0.6

@dfandrich
Copy link
Contributor

Could you show the actual compile error? That's not included in that snippet.

@mraunak
Copy link
Author

mraunak commented Jan 8, 2024

clang-17.txt

Hi @dfandrich, please find the attached log with the error. Please let me know if any further information is needed from my end

@dfandrich
Copy link
Contributor

The underlying errors seem to be the same as in your initial screenshot:

error: call to undeclared function 'IdnToUnicode';
error: call to undeclared function 'IdnToAscii

So, the question from vszakats still stands: why this build env is missing these Windows declarations?

@mraunak
Copy link
Author

mraunak commented Jan 9, 2024

Hi Team,

IdnToUnicode and IdnToASCII function is handled by WinNls.h
https://github.com/tpn/winsdk-10/blob/master/Include/10.0.10240.0/um/WinNls.h#L2445
https://learn.microsoft.com/en-us/cpp/porting/modifying-winver-and-win32-winnt?view=msvc-170. As per the above documentation, WINVER <0x600 was added to fix the issue. Please let me know if it is an acceptable solution

The other solution is to update the TensorFlow configuration file for the Windows platform, for this approach, there is no need for a PR to Curl.

@vszakats
Copy link
Member

vszakats commented Jan 9, 2024

If this is caused by mismatched _WIN32_WINNT and WINVER values setup by the build environment, I'd vote to fix this in the build configuration.

Edit: As seen in Windows SDK 7.1 and mingw-w64 Windows headers, if undefined, WINVER is made equal to _WIN32_WINNT in the header sdkddkver.h, which is one of the first headers included by windows.h. Meaning this issue should be fixed by Windows headers automatically. It's still a pending question why this built-in mechanism fails in this case. Based on what we know so far, this isn't a curl issue, and as such, the correct place to fix this isn't curl's idn.c.

@mihaimaruseac
Copy link

This could be caused by missing defines/includes/files to compile&link in https://github.com/tensorflow/tensorflow/blob/master/third_party/curl.BUILD

@vszakats
Copy link
Member

vszakats commented Jan 10, 2024

Is this correct though?
https://github.com/tensorflow/tensorflow/blob/83b3fbfa32de0ff95f52e86a1370d7e3156acac0/third_party/curl.BUILD#L17-L21

According to the comment it's trying to fix something in curl
(would be useful to know what), but with this particular setup,
which isn't SDK 7.1, but SDK 10 and not MSVC but clang-cl, it
might rather be breaking things.

The Tensorflow build hack triggers some logic in curl, which
messes with WINVER:

curl/lib/config-win32.h

Lines 320 to 380 in 24ae4a0

/* Define some minimum and default build targets for Visual Studio */
#if defined(_MSC_VER)
/* Officially, Microsoft's Windows SDK versions 6.X does not support Windows
2000 as a supported build target. VS2008 default installations provides
an embedded Windows SDK v6.0A along with the claim that Windows 2000 is a
valid build target for VS2008. Popular belief is that binaries built with
VS2008 using Windows SDK versions v6.X and Windows 2000 as a build target
are functional. */
# define VS2008_MIN_TARGET 0x0500
/* The minimum build target for VS2012 is Vista unless Update 1 is installed
and the v110_xp toolset is chosen. */
# if defined(_USING_V110_SDK71_)
# define VS2012_MIN_TARGET 0x0501
# else
# define VS2012_MIN_TARGET 0x0600
# endif
/* VS2008 default build target is Windows Vista. We override default target
to be Windows XP. */
# define VS2008_DEF_TARGET 0x0501
/* VS2012 default build target is Windows Vista unless Update 1 is installed
and the v110_xp toolset is chosen. */
# if defined(_USING_V110_SDK71_)
# define VS2012_DEF_TARGET 0x0501
# else
# define VS2012_DEF_TARGET 0x0600
# endif
#endif
/* VS2008 default target settings and minimum build target check. */
#if defined(_MSC_VER) && (_MSC_VER >= 1500) && (_MSC_VER <= 1600)
# ifndef _WIN32_WINNT
# define _WIN32_WINNT VS2008_DEF_TARGET
# endif
# ifndef WINVER
# define WINVER VS2008_DEF_TARGET
# endif
# if (_WIN32_WINNT < VS2008_MIN_TARGET) || (WINVER < VS2008_MIN_TARGET)
# error VS2008 does not support Windows build targets prior to Windows 2000
# endif
#endif
/* VS2012 default target settings and minimum build target check. */
#if defined(_MSC_VER) && (_MSC_VER >= 1700)
# ifndef _WIN32_WINNT
# define _WIN32_WINNT VS2012_DEF_TARGET
# endif
# ifndef WINVER
# define WINVER VS2012_DEF_TARGET
# endif
# if (_WIN32_WINNT < VS2012_MIN_TARGET) || (WINVER < VS2012_MIN_TARGET)
# if defined(_USING_V110_SDK71_)
# error VS2012 does not support Windows build targets prior to Windows XP
# else
# error VS2012 does not support Windows build targets prior to Windows \
Vista
# endif
# endif
#endif

This logic in curl seems dangerous and possibly obsolete, but
since it's MSVC-specific, I haven't looked at it. Touching either
_WIN32_WINNT or WINVER by any project is generally
best to avoid and these are up to the builders to set (or leave as is).
If there is a combination that is broken, I'd vote to put out an
#error rather than trying to fix it locally.

I haven't tried but this problem might be fixed by deleting either
the Tensorflow hack or the curl hack that it triggers. Or both.

The other logic in curl that touches WINVER is this in autotools:

curl/configure.ac

Lines 2471 to 2488 in 24ae4a0

dnl WinIDN requires a minimum supported OS version of at least Vista (0x0600)
AC_COMPILE_IFELSE([
AC_LANG_PROGRAM([[
#include <windows.h>
]],[[
#if (WINVER < 0x600) && (_WIN32_WINNT < 0x600)
#error
#endif
]])
],[
],[
CFLAGS=`echo $CFLAGS | $SED -e 's/-DWINVER=[[^ ]]*//g'`
CFLAGS=`echo $CFLAGS | $SED -e 's/-D_WIN32_WINNT=[[^ ]]*//g'`
CPPFLAGS=`echo $CPPFLAGS | $SED -e 's/-DWINVER=[[^ ]]*//g'`
CPPFLAGS=`echo $CPPFLAGS | $SED -e 's/-D_WIN32_WINNT=[[^ ]]*//g'`
WINIDN_CPPFLAGS="$WINIDN_CPPFLAGS -DWINVER=0x0600"
])
#

Added as part of a commit fixing legacy-mingw issues in 37f1c21.
The commit message doesn't mention IDN while this logic specifically
tries to address some issues with it. If this is legacy-mingw specific,
I think it'd be best to delete it, because we no longer support legacy-mingw.

@mraunak
Copy link
Author

mraunak commented Jan 11, 2024

Hi Team, Thank you very much for your input, removing the hack (D_USING_V110_SDK71_) works.
https://github.com/tensorflow/tensorflow/blob/83b3fbfa32de0ff95f52e86a1370d7e3156acac0/third_party/curl.BUILD#L17-L21
If we remove line 21, we won't see the IDNTOASCII/IDNTOUNICODE error.

jay added a commit to jay/curl that referenced this pull request Jan 12, 2024
- If the minimum Windows target OS is pre-Vista (_WIN32_WINNT < 0x600)
  then error.

- Stop comparing against WINVER when making the minimum OS
  determinations (ie check only _WIN32_WINNT instead of both since
  that's the one that matters).

Prior to this change, if --with-winidn was used in such a case configure
would change the minimum target OS to Vista (0x600) so the build would
compile. That was done primarily as a workaround for original MinGW
which we no longer support.

Bug: curl#12606 (comment)
Reported-by: Viktor Szakats

Closes #xxxxx
@jay
Copy link
Member

jay commented Jan 12, 2024

This logic in curl seems dangerous and possibly obsolete, but
since it's MSVC-specific, I haven't looked at it. Touching either
_WIN32_WINNT or WINVER by any project is generally
best to avoid and these are up to the builders to set (or leave as is).
If there is a combination that is broken, I'd vote to put out an
#error rather than trying to fix it locally.

I will check this with some old Visual Studio versions. I think it was primarily meant as workarounds for old versions (which are still supported via winbuild and pregenerated projects). I don't know why it would be applied to new versions. Regardless that tensor hack is fishy.

Added as part of a commit fixing legacy-mingw issues in 37f1c21.
The commit message doesn't mention IDN while this logic specifically
tries to address some issues with it. If this is legacy-mingw specific,
I think it'd be best to delete it, because we no longer support legacy-mingw.

#12684

jay added a commit to jay/curl that referenced this pull request Jan 12, 2024
- If the minimum Windows target OS is pre-Vista (_WIN32_WINNT < 0x600)
  then error.

- Stop comparing against WINVER when making the minimum OS
  determinations (ie check only _WIN32_WINNT instead of both since
  that's the one that matters).

Prior to this change, if --with-winidn was used in such a case configure
would change the minimum target OS to Vista (0x600) so the build would
compile. That was done primarily as a workaround for original MinGW
which we no longer support.

Bug: curl#12606 (comment)
Reported-by: Viktor Szakats

Closes #xxxxx
@bagder
Copy link
Member

bagder commented Apr 11, 2024

@mraunak I take it this PR is no longer actually necessary or wanted?

@mraunak
Copy link
Author

mraunak commented Apr 11, 2024

Hi @bagder, yes, we can close it. Thank you!

@bagder
Copy link
Member

bagder commented Apr 11, 2024

Thanks!

@bagder bagder closed this Apr 11, 2024
vszakats added a commit to vszakats/curl that referenced this pull request Aug 25, 2024
vszakats added a commit to vszakats/curl that referenced this pull request Aug 25, 2024
Originall added in 37f1c21 curl#7581
for classic mingw. curl no longer supports building with classic mingw.

Ref: curl#12684
Ref: curl#12606 (comment)
vszakats added a commit to vszakats/curl that referenced this pull request Aug 25, 2024
Originall added in 37f1c21 curl#7581
for classic mingw. curl no longer supports building with classic mingw.

Ref: curl#12684
Ref: curl#12606 (comment)
vszakats added a commit to vszakats/curl that referenced this pull request Aug 25, 2024
vszakats added a commit to vszakats/curl that referenced this pull request Aug 25, 2024
Originall added in 37f1c21 curl#7581
for classic mingw. curl no longer supports building with classic mingw.

Ref: curl#12684
Ref: curl#12606 (comment)
vszakats added a commit to vszakats/curl that referenced this pull request Aug 25, 2024
vszakats added a commit to vszakats/curl that referenced this pull request Aug 25, 2024
Originall added in 37f1c21 curl#7581
for classic mingw. curl no longer supports building with classic mingw.

Ref: curl#12684
Ref: curl#12606 (comment)
vszakats added a commit to vszakats/curl that referenced this pull request Aug 26, 2024
vszakats added a commit to vszakats/curl that referenced this pull request Aug 26, 2024
Originall added in 37f1c21 curl#7581
for classic mingw. curl no longer supports building with classic mingw.

Ref: curl#12684
Ref: curl#12606 (comment)
vszakats added a commit to vszakats/curl that referenced this pull request Aug 26, 2024
Originall added in 37f1c21 curl#7581
for classic mingw. curl no longer supports building with classic mingw.

Ref: curl#12684
Ref: curl#12606 (comment)
vszakats added a commit to vszakats/curl that referenced this pull request Aug 26, 2024
vszakats added a commit to vszakats/curl that referenced this pull request Aug 26, 2024
Originall added in 37f1c21 curl#7581
for classic mingw. curl no longer supports building with classic mingw.

Ref: curl#12684
Ref: curl#12606 (comment)
vszakats added a commit to vszakats/curl that referenced this pull request Aug 26, 2024
vszakats added a commit to vszakats/curl that referenced this pull request Aug 26, 2024
Originall added in 37f1c21 curl#7581
for classic mingw. curl no longer supports building with classic mingw.

Ref: curl#12684
Ref: curl#12606 (comment)
vszakats added a commit that referenced this pull request Aug 27, 2024
1. GHA/windows: enable WinIDN in Linux cross-builds.
   (to reveal the issue in CI.)

2. fix compiler warning when building with mingw-w64 supporting
   WinIDN, while targeting pre-Vista Windows, with a `WINVER` set to
   target Vista or newer. (Such was Ubuntu's mingw-w64 with the
   classic-mingw-specific trick in point 3 of this PR.)
   ```
   ../../lib/idn.c:154:23: error: redundant redeclaration of ‘IdnToAscii’ [-Werror=redundant-decls]
     154 | WINBASEAPI int WINAPI IdnToAscii(DWORD dwFlags,
         |                       ^~~~~~~~~~
   In file included from /usr/share/mingw-w64/include/windows.h:73,
                    from /usr/share/mingw-w64/include/winsock2.h:23,
                    from ../../lib/setup-win32.h:91,
                    from ../../lib/curl_setup.h:308,
                    from ../../lib/idn.c:29:
   /usr/share/mingw-w64/include/winnls.h:1075:30: note: previous declaration of ‘IdnToAscii’ was here
    1075 |   WINNORMALIZEAPI int WINAPI IdnToAscii (DWORD dwFlags, LPCWSTR lpUnicodeCharStr, int cchUnicodeChar, LPWSTR lpASCIICharStr, int cchASCIIChar);
         |                              ^~~~~~~~~~
   [...same for IdnToUnicode...]
   ```
   Ref: https://github.com/curl/curl/actions/runs/10542832783/job/29210098553#step:7:89

3. drop `WINVER` override for classic-mingw. curl no longer supports
   building with classic-mingw.
   Reverts 37f1c21 #7581

4. sync `if IdnToUnicode can be linked` detection snippet with the live
   code in `lib/idn.c`. It fixes detection for the scenario in point 2.

5. delete unused `WINIDN_DIR` variable.

Bug: #12606 (comment)
Previous abandoned attempt: #12684
Reviewed-by: Jay Satiro
Closes #14680
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
build name lookup DNS and related tech needs-info Windows Windows-specific
Development

Successfully merging this pull request may close these issues.

7 participants