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

[feature] libusb-cmake as libusb provider and added support for MSVC #1440

Merged
merged 11 commits into from
Jan 6, 2025

Conversation

a-michelis
Copy link
Contributor

@a-michelis a-michelis commented Nov 21, 2024

Overview

This pull request alters Findlibusb.cmake in order to add proper Windows MSVC handling. It discards the old MINGW approach and uses the libusb-cmake repository as the main provider instead for both Windows and Linux. As it stands now, if libusb is not installed for these two OSes, the libusb-cmake repository is being cloned and incorporated into the build. This way,stlink has a freshly built libusb, tailored to the system's configuration and needs, installed into the same INSTALL_PREFIX as stlink.

Additionally, this pull request adds Windows/MSVC support into the c/c++ github workflow.

Potential issues

  1. In Windows, there is a possibility that the installation path for all LIBRARY items must be the same as the one of RUNTIME items, as opposed to the Linux paradime, where LIBRARY and ARCHIVE items are the ones that share location. This needs further investigation and potentialy a complementary fix, as I currently have no equipment and a clean environment to test it. I'll get back to it once I manage to prepare the proper testing ground.

  2. One very important note on this PR is that it probably drops support for MINGW. If mingw is still needed I'm going to need assistance, Since I've never worked with it in the past and i do not know how to properly validate such builds.

(Closes #1424)

- Changed Legacy MINGW Checkers for MSVC
- If not available, now `Findlibusb.cmake` fetches `libusb-cmake` repo and includes it at config time
- For MSVC, Added fix for ill-defined `ssize-t`
- For linux build-along, added check whether LIBUDEV is installed/enabled
@Nightwalker-87 Nightwalker-87 self-requested a review November 24, 2024 12:54
@Nightwalker-87 Nightwalker-87 added this to the v1.8.1 milestone Nov 24, 2024
Copy link
Member

@Nightwalker-87 Nightwalker-87 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please solely introduce changes affecting the windows operating system due to the package-based nature of unix-based systems to ensure the verification of system integrity.

@a-michelis
Copy link
Contributor Author

a-michelis commented Nov 25, 2024

Tested the MSVC Build and it needs some additional root cmake modifications to work, but totally easy to do. Will come back with them sometime later today.

As for the library part, This is something that cannot be brought to this PR, since it requres restructuring in both code and CMAKE:

  • Since windows have their own usb.h, it conflicts with stlink's header and, thus, it's required to put the headers within a prefixed subfolder and use them as such (ie #include <stlink/usb.h>). This requires code modifications, as all headers that have #include <someStlinkHeader.h> must be converted to #include <stlink/someStlinkHeader.h>.

  • Windows require __declspec(dllexport/dllimport) to each desired function, in order to properly export functionality. This is solvable by creating an stlink/api.h header with the well-known macro definition (let's call it STLINK_API), that prepends dllexport when building and dllimport when using (via compiler definition). That's easy to address- essentially a templated copy-paste-edit snippet.

CMakeLists.txt Outdated Show resolved Hide resolved
Copy link
Member

@Nightwalker-87 Nightwalker-87 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I consider this a good and very useful contribution, with only a few remaining FMPOV accountable remarks that should be easily addressable. Thank you very much. 👍

@Nightwalker-87
Copy link
Member

@a-michelis: Sorry for the delay. Having swapped hardware recently, I needed some time last WE to finalise the setup of my working environment...
What came to my mind is that we should have a small description in our compiling manual (doc/compiling.md), but I can take cake of that afterwards. However some notes on how to proceed in the original issue could be helpful, I guess.

@a-michelis
Copy link
Contributor Author

What came to my mind is that we should have a small description in our compiling manual (doc/compiling.md), but I can take cake of that afterwards. However some notes on how to proceed in the original issue could be helpful, I guess.

@Nightwalker-87: I totally agree, It won't take much to add some compilation guidance to compiling.md.
I believe I can allocate some time at 26/12 and have it committed by the end of that day!

Small Context & suggestion:
As it is now, Compilation for MSVC uses solely CMAKE commands (CMAKE uses the installed msvc compiler).
It is my understanding that the provided makefile is a wrapper to the appropriate CMake Commands. If my understanding is correct, unifying the testing methodology in all OSes (in C/C++ Workflow) to use cmake would be a good practice imho. That would be a separate PR of course, but I leave it here as food for thought.

@a-michelis
Copy link
Contributor Author

I'm sorry for being late on my promise, Holidays got the better of me! Added the compilation manual, as discussed!

@Nightwalker-87
Copy link
Member

It is my understanding that the provided makefile is a wrapper to the appropriate CMake Commands. If my understanding is correct, unifying the testing methodology in all OSes (in C/C++ Workflow) to use cmake would be a good practice imho. That would be a separate PR of course, but I leave it here as food for thought.

True, surely a good attempt. Maybe one may update and reuse the other Draft-PR for this.

Thanks again for your valuable contribution @a-michelis. I believe we are now ready to merge.

@Nightwalker-87 Nightwalker-87 changed the title libusb-cmake as libusb provider and added MSVC Support [feature] libusb-cmake as libusb provider and added support for MSVC Jan 6, 2025
@Nightwalker-87 Nightwalker-87 merged commit e734619 into stlink-org:testing Jan 6, 2025
11 checks passed
@stlink-org stlink-org locked as resolved and limited conversation to collaborators Jan 6, 2025
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

[feature] Proper MSVC Building without needing MINGW
2 participants