Skip to content

[Driver][SYCL] Initial support for allowing fat static -lname processing #5413

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

Merged
merged 2 commits into from
Feb 3, 2022

Conversation

mdtoguchi
Copy link
Contributor

When processing for fat static libraries, add searches for -lname type
libraries passed on the command line. This also takes advantage of
the -Ldir options and LIBRARY_PATH environment variable for locating
the libraries.

When a library is found (with a .a extension) that is what is used for
unbundling and added to the device link.

NOTE: This behavior does not match the recent implementation done for OpenMP
offloading with fat static libraries. That implementation is directly
integrated into the llvm-link call. It would be good to also follow this
for consistency, but will require some refactoring to accomplish.

When processing for fat static libraries, add searches for -lname type
libraries passed on the command line.  This also takes advantage of
the -Ldir options and LIBRARY_PATH environment variable for locating
the libraries.

When a library is found (with a .a extension) that is what is used for
unbundling and added to the device link.

NOTE:  This behavior does not match the recent implementation done for OpenMP
offloading with fat static libraries.  That implementation is directly
integrated into the llvm-link call.  It would be good to also follow this
for consistency, but will require some refactoring to accomplish.
@mdtoguchi mdtoguchi requested a review from a team as a code owner January 28, 2022 01:29
@mdtoguchi
Copy link
Contributor Author

@intel/dpcpp-clang-driver-reviewers ping

@bader bader merged commit 35e32d8 into intel:sycl Feb 3, 2022
alexbatashev added a commit to alexbatashev/llvm that referenced this pull request Feb 5, 2022
* upstream/sycl: (3571 commits)
  [ESIMD] Doxygen update part III - core APIs. (intel#5472)
  [SYCL][DOC] Move proposed FPGA extensions (intel#5453)
  [SYCL] Add -fsycl-fp32-prec-sqrt flag (intel#5309)
  [SYCL] Emit program build logs for warning levels >= 2 (intel#5319)
  [SYCL] Add clang support for code_location in KernelInfo (intel#5335)
  [SYCL][Doc] Move FPGA extensions (intel#5470)
  [ESIMD] Fix public simd and simd_view APIs. (intel#5465)
  [SYCL] Deprecate sycl::atomics in SYCL 2020 mode (intel#5440)
  [SYCL] Add unit test for PR 5414 (intel#5450)
  [XPTI] Allow arbitrary data types in metadata (intel#4998)
  [SYCL][DOC] Move discard queue events to supported (intel#5452)
  [Driver][SYCL] Initial support for allowing fat static -lname processing (intel#5413)
  [SYCL] Fix dead pointer usage if leaf buffer overflows (intel#5417)
  [SYCL][L0] Fix memory leak in USM prefetch (intel#5461)
  [SYCL][Doc] Add new free function queries proposal (intel#5106)
  [SYCL][ESIMD] Update vc-intrinsics deps to the top of the trunk (intel#5460)
  [SYCL][DOC] Move old spec constant extension spec (intel#5456)
  [SYCL][DOC] Move deprecated extensions (intel#5458)
  [SYCL][DOC] Fix links to old SubGroupMask doc (intel#5459)
  [ESIMD] Doxygen update part II - memory APIs. (intel#5443)
  ...
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants